add List of delivery methods for a warehouse
This commit is contained in:
		@@ -71,7 +71,7 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
## Warehouses
 | 
					## Warehouses
 | 
				
			||||||
- [x] List of warehouses
 | 
					- [x] List of warehouses
 | 
				
			||||||
- [ ] List of delivery methods for a warehouse
 | 
					- [x] List of delivery methods for a warehouse
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## Polygons
 | 
					## Polygons
 | 
				
			||||||
- [ ] Create delivery polygon
 | 
					- [ ] Create delivery polygon
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -2,6 +2,7 @@ package ozon
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
import (
 | 
					import (
 | 
				
			||||||
	"net/http"
 | 
						"net/http"
 | 
				
			||||||
 | 
						"time"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	core "github.com/diphantxm/ozon-api-client"
 | 
						core "github.com/diphantxm/ozon-api-client"
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
@@ -89,3 +90,91 @@ func (c Client) GetListOfWarehouses() (*GetListOfWarehousesResponse, error) {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	return resp, nil
 | 
						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