add List of delivery methods for a warehouse
This commit is contained in:
		@@ -2,6 +2,7 @@ package ozon
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"net/http"
 | 
			
		||||
	"time"
 | 
			
		||||
 | 
			
		||||
	core "github.com/diphantxm/ozon-api-client"
 | 
			
		||||
)
 | 
			
		||||
@@ -89,3 +90,91 @@ func (c Client) GetListOfWarehouses() (*GetListOfWarehousesResponse, error) {
 | 
			
		||||
 | 
			
		||||
	return resp, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type GetListOfDeliveryMethodsParams struct {
 | 
			
		||||
	// Search filter for delivery methods
 | 
			
		||||
	Filter GetListOfDeliveryMethodsFilter `json:"filter"`
 | 
			
		||||
 | 
			
		||||
	// Number of items in a response. Maximum is 50, minimum is 1
 | 
			
		||||
	Limit int64 `json:"limit"`
 | 
			
		||||
 | 
			
		||||
	// Number of elements that will be skipped in the response.
 | 
			
		||||
	// For example, if offset=10, the response will start with the 11th element found
 | 
			
		||||
	Offset int64 `json:"offset"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type GetListOfDeliveryMethodsFilter struct {
 | 
			
		||||
	// Delivery service identifier
 | 
			
		||||
	ProviderId int64 `json:"provider_id"`
 | 
			
		||||
 | 
			
		||||
	// Delivery method status:
 | 
			
		||||
	//   - NEW—created
 | 
			
		||||
	//   - EDITED—being edited
 | 
			
		||||
	//   - ACTIVE—active
 | 
			
		||||
	//   - DISABLED—inactive
 | 
			
		||||
	Status string `json:"status"`
 | 
			
		||||
 | 
			
		||||
	// Warehouse identifier
 | 
			
		||||
	WarehouseId int64 `json:"warehouse_id"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type GetListOfDeliveryMethodsResponse struct {
 | 
			
		||||
	core.CommonResponse
 | 
			
		||||
 | 
			
		||||
	// Indication that only part of delivery methods was returned in the response:
 | 
			
		||||
	//   - true — make a request with a new offset parameter value for getting the rest of delivery methods;
 | 
			
		||||
	//   - false — all delivery methods were returned
 | 
			
		||||
	HasNext bool `json:"has_next"`
 | 
			
		||||
 | 
			
		||||
	// Method result
 | 
			
		||||
	Result []struct {
 | 
			
		||||
		// Company identifier
 | 
			
		||||
		CompanyId int64 `json:"company_id"`
 | 
			
		||||
 | 
			
		||||
		// Date and time of delivery method creation
 | 
			
		||||
		CreatedAt time.Time `json:"created_at"`
 | 
			
		||||
 | 
			
		||||
		// Time before an order must be packaged
 | 
			
		||||
		Cutoff string `json:"cutoff"`
 | 
			
		||||
 | 
			
		||||
		// Delivery method identifier
 | 
			
		||||
		Id int64 `json:"id"`
 | 
			
		||||
 | 
			
		||||
		// Delivery method name
 | 
			
		||||
		Name string `json:"name"`
 | 
			
		||||
 | 
			
		||||
		// Delivery service identifier
 | 
			
		||||
		ProviderId int64 `json:"provider_id"`
 | 
			
		||||
 | 
			
		||||
		// Delivery method status:
 | 
			
		||||
		//   - NEW—created,
 | 
			
		||||
		//   - EDITED—being edited,
 | 
			
		||||
		//   - ACTIVE—active,
 | 
			
		||||
		//   - DISABLED—inactive
 | 
			
		||||
		Status string `json:"status"`
 | 
			
		||||
 | 
			
		||||
		// Order delivery service identifier
 | 
			
		||||
		TemplateId int64 `json:"template_id"`
 | 
			
		||||
 | 
			
		||||
		// Date and time when the delivery method was last updated
 | 
			
		||||
		UpdatedAt time.Time `json:"updated_at"`
 | 
			
		||||
 | 
			
		||||
		// Warehouse identifier
 | 
			
		||||
		WarehouseId int64 `json:"warehouse_id"`
 | 
			
		||||
	} `json:"result"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// This methods allows you to get list of all delivery methods that can be applied for this warehouse
 | 
			
		||||
func (c Client) GetListOfDeliveryMethods(params *GetListOfDeliveryMethodsParams) (*GetListOfDeliveryMethodsResponse, error) {
 | 
			
		||||
	url := "/v1/delivery-method/list"
 | 
			
		||||
 | 
			
		||||
	resp := &GetListOfDeliveryMethodsResponse{}
 | 
			
		||||
 | 
			
		||||
	response, err := c.client.Request(http.MethodPost, url, nil, resp)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	response.CopyCommonResponse(&resp.CommonResponse)
 | 
			
		||||
 | 
			
		||||
	return resp, nil
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -66,3 +66,65 @@ func TestGetListOfWarehouses(t *testing.T) {
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func TestGetListOfDeliveryMethods(t *testing.T) {
 | 
			
		||||
	tests := []struct {
 | 
			
		||||
		statusCode int
 | 
			
		||||
		headers    map[string]string
 | 
			
		||||
		params     *GetListOfDeliveryMethodsParams
 | 
			
		||||
		response   string
 | 
			
		||||
	}{
 | 
			
		||||
		// Test Ok
 | 
			
		||||
		{
 | 
			
		||||
			http.StatusOK,
 | 
			
		||||
			map[string]string{"Client-Id": "my-client-id", "Api-Key": "my-api-key"},
 | 
			
		||||
			&GetListOfDeliveryMethodsParams{
 | 
			
		||||
				Filter: GetListOfDeliveryMethodsFilter{
 | 
			
		||||
					WarehouseId: 15588127982000,
 | 
			
		||||
				},
 | 
			
		||||
				Limit:  100,
 | 
			
		||||
				Offset: 0,
 | 
			
		||||
			},
 | 
			
		||||
			`{
 | 
			
		||||
				"result": [
 | 
			
		||||
				  {
 | 
			
		||||
					"id": 15588127982000,
 | 
			
		||||
					"company_id": 1,
 | 
			
		||||
					"name": "Ozon Логистика курьеру, Есипово",
 | 
			
		||||
					"status": "ACTIVE",
 | 
			
		||||
					"cutoff": "13:00",
 | 
			
		||||
					"provider_id": 24,
 | 
			
		||||
					"template_id": 0,
 | 
			
		||||
					"warehouse_id": 15588127982000,
 | 
			
		||||
					"created_at": "2019-04-04T15:22:31.048202Z",
 | 
			
		||||
					"updated_at": "2021-08-15T10:21:44.854209Z"
 | 
			
		||||
				  }
 | 
			
		||||
				],
 | 
			
		||||
				"has_next": false
 | 
			
		||||
			}`,
 | 
			
		||||
		},
 | 
			
		||||
		// Test No Client-Id or Api-Key
 | 
			
		||||
		{
 | 
			
		||||
			http.StatusUnauthorized,
 | 
			
		||||
			map[string]string{},
 | 
			
		||||
			&GetListOfDeliveryMethodsParams{},
 | 
			
		||||
			`{
 | 
			
		||||
				"code": 16,
 | 
			
		||||
				"message": "Client-Id and Api-Key headers are required"
 | 
			
		||||
			}`,
 | 
			
		||||
		},
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	for _, test := range tests {
 | 
			
		||||
		c := NewMockClient(core.NewMockHttpHandler(test.statusCode, test.response, test.headers))
 | 
			
		||||
 | 
			
		||||
		resp, err := c.GetListOfDeliveryMethods(test.params)
 | 
			
		||||
		if err != nil {
 | 
			
		||||
			t.Error(err)
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		if resp.StatusCode != test.statusCode {
 | 
			
		||||
			t.Errorf("got wrong status code: got: %d, expected: %d", resp.StatusCode, test.statusCode)
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user