From b4897fbd6ba4df4acb745483dddd91ae942c6f41 Mon Sep 17 00:00:00 2001 From: diPhantxm Date: Sat, 9 Dec 2023 15:40:59 +0300 Subject: [PATCH 1/6] Added a method for checking if return shipments can be picked up by barcode --- ozon/returns.go | 24 ++++++++++++++++++++++++ ozon/returns_test.go | 42 ++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 66 insertions(+) diff --git a/ozon/returns.go b/ozon/returns.go index 7dc3345..a719901 100644 --- a/ozon/returns.go +++ b/ozon/returns.go @@ -647,3 +647,27 @@ func (c Returns) RefundRFBS(ctx context.Context, params *RefundRFBSParams) (*Ref return resp, nil } + +type IsGiveoutEnabledResponse struct { + core.CommonResponse + + // `true` if you can pick up a return shipment by barcode. + Enabled bool `json:"enabled"` +} + +// Check the ability to receive return shipments by barcode +// +// The `enabled` parameter is true if you can pick up return shipments by barcode. +func (c Returns) IsGiveoutEnabled(ctx context.Context) (*IsGiveoutEnabledResponse, error) { + url := "/v1/return/giveout/is-enabled" + + resp := &IsGiveoutEnabledResponse{} + + response, err := c.client.Request(ctx, http.MethodPost, url, struct{}{}, resp, nil) + if err != nil { + return nil, err + } + response.CopyCommonResponse(&resp.CommonResponse) + + return resp, nil +} diff --git a/ozon/returns_test.go b/ozon/returns_test.go index 9b9c496..58d61ac 100644 --- a/ozon/returns_test.go +++ b/ozon/returns_test.go @@ -603,3 +603,45 @@ func TestRefundRFBS(t *testing.T) { } } } + +func TestIsGiveoutEnabled(t *testing.T) { + t.Parallel() + + tests := []struct { + statusCode int + headers map[string]string + response string + }{ + // Test Ok + { + http.StatusOK, + map[string]string{"Client-Id": "my-client-id", "Api-Key": "my-api-key"}, + `{ + "enabled": true + }`, + }, + // Test No Client-Id or Api-Key + { + http.StatusUnauthorized, + map[string]string{}, + `{ + "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)) + + ctx, _ := context.WithTimeout(context.Background(), testTimeout) + resp, err := c.Returns().IsGiveoutEnabled(ctx) + 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) + } + } +} From fb6c5869164bc7a022de2f4401ad66caa59f8548 Mon Sep 17 00:00:00 2001 From: diPhantxm Date: Sat, 9 Dec 2023 15:45:20 +0300 Subject: [PATCH 2/6] Added methods for getting the return shipment barcode as PDF and PNG --- ozon/returns.go | 47 +++++++++++++++++++++++ ozon/returns_test.go | 88 ++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 135 insertions(+) diff --git a/ozon/returns.go b/ozon/returns.go index a719901..2179a3f 100644 --- a/ozon/returns.go +++ b/ozon/returns.go @@ -671,3 +671,50 @@ func (c Returns) IsGiveoutEnabled(ctx context.Context) (*IsGiveoutEnabledRespons return resp, nil } + +type GetGiveoutResponse struct { + core.CommonResponse + + // PDF file with barcode in binary format + FileContent string `json:"file_content"` + + // File name + FileName string `json:"file_name"` + + // File type + ContentType string `json:"content_type"` +} + +// Barcode for return shipment in PDF format +// +// Returns a PDF file with a barcode +func (c Returns) GetGiveoutPDF(ctx context.Context) (*GetGiveoutResponse, error) { + url := "/v1/return/giveout/get-pdf" + + resp := &GetGiveoutResponse{} + + response, err := c.client.Request(ctx, http.MethodPost, url, struct{}{}, resp, nil) + if err != nil { + return nil, err + } + response.CopyCommonResponse(&resp.CommonResponse) + + return resp, nil +} + +// Barcode for return shipment in PNG format +// +// Returns a PNG file with a barcode +func (c Returns) GetGiveoutPNG(ctx context.Context) (*GetGiveoutResponse, error) { + url := "/v1/return/giveout/get-png" + + resp := &GetGiveoutResponse{} + + response, err := c.client.Request(ctx, http.MethodPost, url, struct{}{}, resp, nil) + if err != nil { + return nil, err + } + response.CopyCommonResponse(&resp.CommonResponse) + + return resp, nil +} diff --git a/ozon/returns_test.go b/ozon/returns_test.go index 58d61ac..ed471b6 100644 --- a/ozon/returns_test.go +++ b/ozon/returns_test.go @@ -645,3 +645,91 @@ func TestIsGiveoutEnabled(t *testing.T) { } } } + +func TestGetGiveoutPDF(t *testing.T) { + t.Parallel() + + tests := []struct { + statusCode int + headers map[string]string + response string + }{ + // Test Ok + { + http.StatusOK, + map[string]string{"Client-Id": "my-client-id", "Api-Key": "my-api-key"}, + `{ + "content_type": "application/pdf", + "file_name": "string", + "file_content": "string" + }`, + }, + // Test No Client-Id or Api-Key + { + http.StatusUnauthorized, + map[string]string{}, + `{ + "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)) + + ctx, _ := context.WithTimeout(context.Background(), testTimeout) + resp, err := c.Returns().GetGiveoutPDF(ctx) + 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) + } + } +} + +func TestGetGiveoutPNG(t *testing.T) { + t.Parallel() + + tests := []struct { + statusCode int + headers map[string]string + response string + }{ + // Test Ok + { + http.StatusOK, + map[string]string{"Client-Id": "my-client-id", "Api-Key": "my-api-key"}, + `{ + "content_type": "image/png", + "file_name": "string", + "file_content": "string" + }`, + }, + // Test No Client-Id or Api-Key + { + http.StatusUnauthorized, + map[string]string{}, + `{ + "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)) + + ctx, _ := context.WithTimeout(context.Background(), testTimeout) + resp, err := c.Returns().GetGiveoutPNG(ctx) + 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) + } + } +} From c6e767d41257a1bacb6f549a01c969e3c2eb8c69 Mon Sep 17 00:00:00 2001 From: diPhantxm Date: Sat, 9 Dec 2023 15:47:35 +0300 Subject: [PATCH 3/6] Added a method for getting the return shipment barcode as text --- ozon/returns.go | 25 +++++++++++++++++++++++++ ozon/returns_test.go | 42 ++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 67 insertions(+) diff --git a/ozon/returns.go b/ozon/returns.go index 2179a3f..e102d1d 100644 --- a/ozon/returns.go +++ b/ozon/returns.go @@ -718,3 +718,28 @@ func (c Returns) GetGiveoutPNG(ctx context.Context) (*GetGiveoutResponse, error) return resp, nil } + +type GetGiveoutBarcodeResponse struct { + core.CommonResponse + + // Barcode value in text format + Barcode string `json:"barcode"` +} + +// Value of barcode for return shipments +// +// Use this method to get the barcode from the response of the +// `/v1/return/giveout/get-png` and `/v1/return/giveout/get-pdf` methods in text format +func (c Returns) GetGiveoutBarcode(ctx context.Context) (*GetGiveoutBarcodeResponse, error) { + url := "/v1/return/giveout/get-png" + + resp := &GetGiveoutBarcodeResponse{} + + response, err := c.client.Request(ctx, http.MethodPost, url, struct{}{}, resp, nil) + if err != nil { + return nil, err + } + response.CopyCommonResponse(&resp.CommonResponse) + + return resp, nil +} diff --git a/ozon/returns_test.go b/ozon/returns_test.go index ed471b6..f3254b9 100644 --- a/ozon/returns_test.go +++ b/ozon/returns_test.go @@ -733,3 +733,45 @@ func TestGetGiveoutPNG(t *testing.T) { } } } + +func TestGetGiveoutBarcode(t *testing.T) { + t.Parallel() + + tests := []struct { + statusCode int + headers map[string]string + response string + }{ + // Test Ok + { + http.StatusOK, + map[string]string{"Client-Id": "my-client-id", "Api-Key": "my-api-key"}, + `{ + "barcode": "string" + }`, + }, + // Test No Client-Id or Api-Key + { + http.StatusUnauthorized, + map[string]string{}, + `{ + "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)) + + ctx, _ := context.WithTimeout(context.Background(), testTimeout) + resp, err := c.Returns().GetGiveoutBarcode(ctx) + 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) + } + } +} From 2af801ffeab41ec49f298543fafb2522932ef20c Mon Sep 17 00:00:00 2001 From: diPhantxm Date: Sat, 9 Dec 2023 15:49:32 +0300 Subject: [PATCH 4/6] Added a method for updating the return shipment barcode --- ozon/returns.go | 21 ++++++++++++++++++++- ozon/returns_test.go | 44 ++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 64 insertions(+), 1 deletion(-) diff --git a/ozon/returns.go b/ozon/returns.go index e102d1d..cfa7cff 100644 --- a/ozon/returns.go +++ b/ozon/returns.go @@ -731,7 +731,26 @@ type GetGiveoutBarcodeResponse struct { // Use this method to get the barcode from the response of the // `/v1/return/giveout/get-png` and `/v1/return/giveout/get-pdf` methods in text format func (c Returns) GetGiveoutBarcode(ctx context.Context) (*GetGiveoutBarcodeResponse, error) { - url := "/v1/return/giveout/get-png" + url := "/v1/return/giveout/barcode" + + resp := &GetGiveoutBarcodeResponse{} + + response, err := c.client.Request(ctx, http.MethodPost, url, struct{}{}, resp, nil) + if err != nil { + return nil, err + } + response.CopyCommonResponse(&resp.CommonResponse) + + return resp, nil +} + +// Use this method if an unauthorized person has gained access to your barcode. +// +// The method returns a PNG file with the new barcode. Once the method is used, +// you won't be able to get a return shipment using the old barcodes. +// To get a new barcode in PDF format, use the /v1/return/giveout/get-pdf method +func (c Returns) ResetGiveoutBarcode(ctx context.Context) (*GetGiveoutBarcodeResponse, error) { + url := "/v1/return/giveout/barcode-reset" resp := &GetGiveoutBarcodeResponse{} diff --git a/ozon/returns_test.go b/ozon/returns_test.go index f3254b9..101ec9d 100644 --- a/ozon/returns_test.go +++ b/ozon/returns_test.go @@ -775,3 +775,47 @@ func TestGetGiveoutBarcode(t *testing.T) { } } } + +func TestResetGiveoutBarcode(t *testing.T) { + t.Parallel() + + tests := []struct { + statusCode int + headers map[string]string + response string + }{ + // Test Ok + { + http.StatusOK, + map[string]string{"Client-Id": "my-client-id", "Api-Key": "my-api-key"}, + `{ + "content_type": "image/png", + "file_name": "string", + "file_content": "string" + }`, + }, + // Test No Client-Id or Api-Key + { + http.StatusUnauthorized, + map[string]string{}, + `{ + "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)) + + ctx, _ := context.WithTimeout(context.Background(), testTimeout) + resp, err := c.Returns().ResetGiveoutBarcode(ctx) + 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) + } + } +} From 997eb60858a834683518b0eb1ac6bf83e960fce1 Mon Sep 17 00:00:00 2001 From: diPhantxm Date: Sat, 9 Dec 2023 15:57:55 +0300 Subject: [PATCH 5/6] Added a method for getting a list of return shipments --- ozon/common.go | 19 ++++++++++++++ ozon/returns.go | 56 +++++++++++++++++++++++++++++++++++++++++ ozon/returns_test.go | 59 ++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 134 insertions(+) diff --git a/ozon/common.go b/ozon/common.go index 515315b..77bd22b 100644 --- a/ozon/common.go +++ b/ozon/common.go @@ -634,3 +634,22 @@ const ( // Yuan GetRFBSReturnsCurrencyCNY GetRFBSReturnsCurrency = "CNY" ) + +type GiveoutStatus string + +const ( + // Undefined, contact support team + GiveoutStatusUnspecified GiveoutStatus = "GIVEOUT_STATUS_UNSPECIFIED" + + // Created + GiveoutStatusCreated GiveoutStatus = "GIVEOUT_STATUS_CREATED" + + // Approved + GiveoutStatusApproved GiveoutStatus = "GIVEOUT_STATUS_APPROVED" + + // Completed + GiveoutStatusCompleted GiveoutStatus = "GIVEOUT_STATUS_COMPLETED" + + // Cancelled + GiveoutStatusCancelled GiveoutStatus = "GIVEOUT_STATUS_CANCELLED" +) diff --git a/ozon/returns.go b/ozon/returns.go index cfa7cff..53ab7a4 100644 --- a/ozon/returns.go +++ b/ozon/returns.go @@ -762,3 +762,59 @@ func (c Returns) ResetGiveoutBarcode(ctx context.Context) (*GetGiveoutBarcodeRes return resp, nil } + +type GetGiveoutListParams struct { + // Identifier of the last value on the page + LastId int64 `json:"last_id"` + + // Number of values in the response + Limit int64 `json:"limit"` +} + +type GetGiveoutListResponse struct { + core.CommonResponse + + // Shipment identifier + Giveouts []GetGiveoutListGiveout `json:"giveouts"` +} + +type GetGiveoutListGiveout struct { + // Number of products in shipment + ApprovedArticlesCount int32 `json:"approved_articles_count"` + + // Creation date and time + CreatedAt time.Time `json:"created_at"` + + // Shipment identifier + GiveoutId int64 `json:"giveout_id"` + + // Return shipment status + GiveoutStatus GiveoutStatus `json:"giveout_status"` + + // Total number of products to be picked up from the warehouse + TotalArticlesCount int32 `json:"total_articles_count"` + + // Warehouse address + WarehouseAddress string `json:"warehouse_address"` + + // Warehouse identifier + WarehouseId int64 `json:"warehouse_id"` + + // Warehouse name + WarehouseName string `json:"warehouse_name"` +} + +// Return shipments list +func (c Returns) GetGiveoutList(ctx context.Context, params *GetGiveoutListParams) (*GetGiveoutListResponse, error) { + url := "/v1/return/giveout/list" + + resp := &GetGiveoutListResponse{} + + response, err := c.client.Request(ctx, http.MethodPost, url, struct{}{}, resp, nil) + if err != nil { + return nil, err + } + response.CopyCommonResponse(&resp.CommonResponse) + + return resp, nil +} diff --git a/ozon/returns_test.go b/ozon/returns_test.go index 101ec9d..cd5c7e9 100644 --- a/ozon/returns_test.go +++ b/ozon/returns_test.go @@ -819,3 +819,62 @@ func TestResetGiveoutBarcode(t *testing.T) { } } } + +func TestGetGiveoutList(t *testing.T) { + t.Parallel() + + tests := []struct { + statusCode int + headers map[string]string + params *GetGiveoutListParams + response string + }{ + // Test Ok + { + http.StatusOK, + map[string]string{"Client-Id": "my-client-id", "Api-Key": "my-api-key"}, + &GetGiveoutListParams{ + LastId: 0, + Limit: 0, + }, + `{ + "giveouts": [ + { + "approved_articles_count": 0, + "created_at": "2019-08-24T14:15:22Z", + "giveout_id": 0, + "giveout_status": "string", + "total_articles_count": 0, + "warehouse_address": "string", + "warehouse_id": 0, + "warehouse_name": "string" + } + ] + }`, + }, + // Test No Client-Id or Api-Key + { + http.StatusUnauthorized, + map[string]string{}, + &GetGiveoutListParams{}, + `{ + "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)) + + ctx, _ := context.WithTimeout(context.Background(), testTimeout) + resp, err := c.Returns().GetGiveoutList(ctx, 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) + } + } +} From 6c63a009d80b834c242ade81e0a99371cf75f2ed Mon Sep 17 00:00:00 2001 From: diPhantxm Date: Sat, 9 Dec 2023 16:04:09 +0300 Subject: [PATCH 6/6] Added a method for getting information about return shipments --- ozon/common.go | 13 ++++++++++ ozon/returns.go | 53 ++++++++++++++++++++++++++++++++++++++ ozon/returns_test.go | 61 ++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 127 insertions(+) diff --git a/ozon/common.go b/ozon/common.go index 77bd22b..6cb1bcd 100644 --- a/ozon/common.go +++ b/ozon/common.go @@ -653,3 +653,16 @@ const ( // Cancelled GiveoutStatusCancelled GiveoutStatus = "GIVEOUT_STATUS_CANCELLED" ) + +type GiveoutDeliverySchema string + +const ( + // Undefined, contact support team + GiveoutDeliverySchemaUnspecified GiveoutDeliverySchema = "GIVEOUT_DELIVERY_SCHEMA_UNSPECIFIED" + + // FBO + GiveoutDeliverySchemaFBO GiveoutDeliverySchema = "GIVEOUT_DELIVERY_SCHEMA_FBO" + + // FBS + GiveoutDeliverySchemaFBS GiveoutDeliverySchema = "GIVEOUT_DELIVERY_SCHEMA_FBS" +) diff --git a/ozon/returns.go b/ozon/returns.go index 53ab7a4..33b6b3b 100644 --- a/ozon/returns.go +++ b/ozon/returns.go @@ -818,3 +818,56 @@ func (c Returns) GetGiveoutList(ctx context.Context, params *GetGiveoutListParam return resp, nil } + +type GetGiveoutInfoParams struct { + // Shipment identifier + GiveoutId int64 `json:"giveout_id"` +} + +type GetGiveoutInfoResponse struct { + core.CommonResponse + + // Product IDs + Articles []GetGiveoutInfoArticle `json:"articles"` + + // Shipment identifier + GiveoutId int64 `json:"giveout_id"` + + // Return shipment status + GiveoutStatus GiveoutStatus `json:"giveout_status"` + + // Warehouse address + WarehouseAddress string `json:"warehouse_address"` + + // Warehouse name + WarehouseName string `json:"warehouse_name"` +} + +type GetGiveoutInfoArticle struct { + // `true` if the shipment is confirmed + Approved bool `json:"approved"` + + // Delivery schema + DeliverySchema GiveoutDeliverySchema `json:"delivery_schema"` + + // Product name + Name string `json:"name"` + + // Seller identifier + SellerId int64 `json:"seller_id"` +} + +// Information on return shipment +func (c Returns) GetGiveoutInfo(ctx context.Context, params *GetGiveoutInfoParams) (*GetGiveoutInfoResponse, error) { + url := "/v1/return/giveout/info" + + resp := &GetGiveoutInfoResponse{} + + response, err := c.client.Request(ctx, http.MethodPost, url, struct{}{}, resp, nil) + if err != nil { + return nil, err + } + response.CopyCommonResponse(&resp.CommonResponse) + + return resp, nil +} diff --git a/ozon/returns_test.go b/ozon/returns_test.go index cd5c7e9..c3ad555 100644 --- a/ozon/returns_test.go +++ b/ozon/returns_test.go @@ -878,3 +878,64 @@ func TestGetGiveoutList(t *testing.T) { } } } + +func TestGetGiveoutInfo(t *testing.T) { + t.Parallel() + + tests := []struct { + statusCode int + headers map[string]string + params *GetGiveoutInfoParams + response string + }{ + // Test Ok + { + http.StatusOK, + map[string]string{"Client-Id": "my-client-id", "Api-Key": "my-api-key"}, + &GetGiveoutInfoParams{ + GiveoutId: 11, + }, + `{ + "articles": [ + { + "approved": true, + "delivery_schema": "string", + "name": "string", + "seller_id": 0 + } + ], + "giveout_id": 11, + "giveout_status": "string", + "warehouse_address": "string", + "warehouse_name": "string" + }`, + }, + // Test No Client-Id or Api-Key + { + http.StatusUnauthorized, + map[string]string{}, + &GetGiveoutInfoParams{}, + `{ + "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)) + + ctx, _ := context.WithTimeout(context.Background(), testTimeout) + resp, err := c.Returns().GetGiveoutInfo(ctx, 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) + } + if resp.GiveoutId != test.params.GiveoutId { + t.Errorf("expected giveout id to be equal: got: %d, expected: %d", resp.GiveoutId, test.params.GiveoutId) + } + } +}