add List of delivery methods for a warehouse
This commit is contained in:
@@ -71,7 +71,7 @@
|
||||
|
||||
## Warehouses
|
||||
- [x] List of warehouses
|
||||
- [ ] List of delivery methods for a warehouse
|
||||
- [x] List of delivery methods for a warehouse
|
||||
|
||||
## Polygons
|
||||
- [ ] Create delivery polygon
|
||||
|
||||
@@ -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