add methods for generating returns and shipment reports
This commit is contained in:
		@@ -155,10 +155,10 @@
 | 
				
			|||||||
- [x] Report details
 | 
					- [x] Report details
 | 
				
			||||||
- [x] Reports list
 | 
					- [x] Reports list
 | 
				
			||||||
- [x] Products report
 | 
					- [x] Products report
 | 
				
			||||||
- [ ] Stocks report
 | 
					- [x] Stocks report
 | 
				
			||||||
- [ ] Report on products movement
 | 
					- [x] Report on products movement
 | 
				
			||||||
- [ ] Returns report
 | 
					- [x] Returns report
 | 
				
			||||||
- [ ] Shipment report
 | 
					- [x] Shipment report
 | 
				
			||||||
- [x] Financial report
 | 
					- [x] Financial report
 | 
				
			||||||
- [ ] Issue a report on discounted products
 | 
					- [ ] Issue a report on discounted products
 | 
				
			||||||
- [ ] Report on discounted products
 | 
					- [ ] Report on discounted products
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										165
									
								
								ozon/reports.go
									
									
									
									
									
								
							
							
						
						
									
										165
									
								
								ozon/reports.go
									
									
									
									
									
								
							@@ -304,3 +304,168 @@ func (c Reports) GetStocks(params *GetStocksReportParams) (*GetStocksReportRespo
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	return resp, nil
 | 
						return resp, nil
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type GetProductsMovementReportParams struct {
 | 
				
			||||||
 | 
						// Date from which the data will be in the report
 | 
				
			||||||
 | 
						DateFrom time.Time `json:"date_from"`
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// Date up to which the data will be in the report
 | 
				
			||||||
 | 
						DateTo time.Time `json:"date_to"`
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// Default: "DEFAULT"
 | 
				
			||||||
 | 
						// Response language:
 | 
				
			||||||
 | 
						//   - RU — Russian
 | 
				
			||||||
 | 
						//   - EN — English
 | 
				
			||||||
 | 
						Language string `json:"language" default:"DEFAULT"`
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type GetProductsMovementReportResponse struct {
 | 
				
			||||||
 | 
						core.CommonResponse
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// Method result
 | 
				
			||||||
 | 
						Result struct {
 | 
				
			||||||
 | 
							// Unique report identifier
 | 
				
			||||||
 | 
							Code string `json:"code"`
 | 
				
			||||||
 | 
						} `json:"result"`
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// Report with complete information on products, as well as the number of products with statuses:
 | 
				
			||||||
 | 
					//   - products with defects or in inventory,
 | 
				
			||||||
 | 
					//   - products in transit between the fulfillment centers,
 | 
				
			||||||
 | 
					//   - products in delivery,
 | 
				
			||||||
 | 
					//   - products to be sold
 | 
				
			||||||
 | 
					func (c Reports) GetProductsMovement(params *GetProductsMovementReportParams) (*GetProductsMovementReportResponse, error) {
 | 
				
			||||||
 | 
						url := "/v1/report/products/movement/create"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						resp := &GetProductsMovementReportResponse{}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						response, err := c.client.Request(http.MethodPost, url, params, resp)
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							return nil, err
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						response.CopyCommonResponse(&resp.CommonResponse)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return resp, nil
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type GetReturnsReportParams struct {
 | 
				
			||||||
 | 
						// Filter
 | 
				
			||||||
 | 
						Filter GetReturnsReportsFilter `json:"filter"`
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// Default: "DEFAULT"
 | 
				
			||||||
 | 
						// Response language:
 | 
				
			||||||
 | 
						//   - RU — Russian
 | 
				
			||||||
 | 
						//   - EN — English
 | 
				
			||||||
 | 
						Language string `json:"language" default:"DEFAULT"`
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type GetReturnsReportsFilter struct {
 | 
				
			||||||
 | 
						// Order delivery scheme: fbs — delivery from seller's warehouse
 | 
				
			||||||
 | 
						DeliverySchema string `json:"delivery_schema"`
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// Order identifier
 | 
				
			||||||
 | 
						OrderId int64 `json:"order_id"`
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// Order status
 | 
				
			||||||
 | 
						Status string `json:"status"`
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type GetReturnsReportResponse struct {
 | 
				
			||||||
 | 
						core.CommonResponse
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// Method result
 | 
				
			||||||
 | 
						Result struct {
 | 
				
			||||||
 | 
							// Unique report identifier
 | 
				
			||||||
 | 
							Code string `json:"code"`
 | 
				
			||||||
 | 
						} `json:"result"`
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// The report contains information about returned products that were accepted from the customer, ready for pickup, or delivered to the seller.
 | 
				
			||||||
 | 
					//
 | 
				
			||||||
 | 
					// The method is only suitable for orders shipped from the seller's warehouse
 | 
				
			||||||
 | 
					func (c Reports) GetReturns(params *GetReturnsReportParams) (*GetReturnsReportResponse, error) {
 | 
				
			||||||
 | 
						url := "/v1/report/returns/create"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						resp := &GetReturnsReportResponse{}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						response, err := c.client.Request(http.MethodPost, url, params, resp)
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							return nil, err
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						response.CopyCommonResponse(&resp.CommonResponse)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return resp, nil
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type GetShipmentReportParams struct {
 | 
				
			||||||
 | 
						// Filter
 | 
				
			||||||
 | 
						Filter GetShipmentReportFilter `json:"filter"`
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// Default: "DEFAULT"
 | 
				
			||||||
 | 
						// Response language:
 | 
				
			||||||
 | 
						//   - RU — Russian
 | 
				
			||||||
 | 
						//   - EN — English
 | 
				
			||||||
 | 
						Language string `json:"language"`
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type GetShipmentReportFilter struct {
 | 
				
			||||||
 | 
						// Cancellation reason identifier
 | 
				
			||||||
 | 
						CancelReasonId []int64 `json:"cancel_reason_id"`
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// Work scheme: FBO or FBS.
 | 
				
			||||||
 | 
						//
 | 
				
			||||||
 | 
						// To get an FBO scheme report, pass fbo in this parameter. For an FBS scheme report pass fbs
 | 
				
			||||||
 | 
						DeliverySchema []string `json:"delivery_schema"`
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// Product identifier
 | 
				
			||||||
 | 
						OfferId string `json:"offer_id"`
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// Order processing start date and time
 | 
				
			||||||
 | 
						ProcessedAtFrom time.Time `json:"processed_at_from"`
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// Time when the order appeared in your personal account
 | 
				
			||||||
 | 
						ProcessedAtTo time.Time `json:"processed_at_to"`
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// Product identifier in the Ozon system, SKU
 | 
				
			||||||
 | 
						SKU []int64 `json:"sku"`
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// Status text
 | 
				
			||||||
 | 
						StatusAlias []string `json:"status_alias"`
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// Numerical status
 | 
				
			||||||
 | 
						Statuses []int64 `json:"statused"`
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// Product name
 | 
				
			||||||
 | 
						Title string `json:"title"`
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type GetShipmentReportResponse struct {
 | 
				
			||||||
 | 
						core.CommonResponse
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// Method result
 | 
				
			||||||
 | 
						Result struct {
 | 
				
			||||||
 | 
							// Unique report identifier
 | 
				
			||||||
 | 
							Code string `json:"code"`
 | 
				
			||||||
 | 
						} `json:"result"`
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// Shipment report with orders details:
 | 
				
			||||||
 | 
					//   - order statuses
 | 
				
			||||||
 | 
					//   - processing start date
 | 
				
			||||||
 | 
					//   - order numbers
 | 
				
			||||||
 | 
					//   - shipment numbers
 | 
				
			||||||
 | 
					//   - shipment costs
 | 
				
			||||||
 | 
					//   - shipments contents
 | 
				
			||||||
 | 
					func (c Reports) GetShipment(params *GetShipmentReportParams) (*GetShipmentReportResponse, error) {
 | 
				
			||||||
 | 
						url := "/v1/report/postings/create"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						resp := &GetShipmentReportResponse{}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						response, err := c.client.Request(http.MethodPost, url, params, resp)
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							return nil, err
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						response.CopyCommonResponse(&resp.CommonResponse)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return resp, nil
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -291,3 +291,154 @@ func TestGetStocksReport(t *testing.T) {
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func TestGetProductsMovementReport(t *testing.T) {
 | 
				
			||||||
 | 
						t.Parallel()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						tests := []struct {
 | 
				
			||||||
 | 
							statusCode int
 | 
				
			||||||
 | 
							headers    map[string]string
 | 
				
			||||||
 | 
							params     *GetProductsMovementReportParams
 | 
				
			||||||
 | 
							response   string
 | 
				
			||||||
 | 
						}{
 | 
				
			||||||
 | 
							// Test Ok
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								http.StatusOK,
 | 
				
			||||||
 | 
								map[string]string{"Client-Id": "my-client-id", "Api-Key": "my-api-key"},
 | 
				
			||||||
 | 
								&GetProductsMovementReportParams{
 | 
				
			||||||
 | 
									DateFrom: core.TimeFromString(t, "2006-01-02T15:04:05Z", "2020-08-01T14:15:22Z"),
 | 
				
			||||||
 | 
									DateTo:   core.TimeFromString(t, "2006-01-02T15:04:05Z", "2020-08-01T14:15:22Z"),
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								`{
 | 
				
			||||||
 | 
									"result": {
 | 
				
			||||||
 | 
									  "code": "h56f4917-1346-4e64-9d90-с6e736c1e07c"
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
								}`,
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							// Test No Client-Id or Api-Key
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								http.StatusUnauthorized,
 | 
				
			||||||
 | 
								map[string]string{},
 | 
				
			||||||
 | 
								&GetProductsMovementReportParams{},
 | 
				
			||||||
 | 
								`{
 | 
				
			||||||
 | 
									"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.Reports().GetProductsMovement(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)
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func TestGetReturnsReport(t *testing.T) {
 | 
				
			||||||
 | 
						t.Parallel()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						tests := []struct {
 | 
				
			||||||
 | 
							statusCode int
 | 
				
			||||||
 | 
							headers    map[string]string
 | 
				
			||||||
 | 
							params     *GetReturnsReportParams
 | 
				
			||||||
 | 
							response   string
 | 
				
			||||||
 | 
						}{
 | 
				
			||||||
 | 
							// Test Ok
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								http.StatusOK,
 | 
				
			||||||
 | 
								map[string]string{"Client-Id": "my-client-id", "Api-Key": "my-api-key"},
 | 
				
			||||||
 | 
								&GetReturnsReportParams{
 | 
				
			||||||
 | 
									Filter: GetReturnsReportsFilter{
 | 
				
			||||||
 | 
										DeliverySchema: "fbs",
 | 
				
			||||||
 | 
									},
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								`{
 | 
				
			||||||
 | 
									"result": {
 | 
				
			||||||
 | 
									  "code": "d55f4517-8347-4e24-9d93-d6e736c1c07c"
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
								}`,
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							// Test No Client-Id or Api-Key
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								http.StatusUnauthorized,
 | 
				
			||||||
 | 
								map[string]string{},
 | 
				
			||||||
 | 
								&GetReturnsReportParams{},
 | 
				
			||||||
 | 
								`{
 | 
				
			||||||
 | 
									"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.Reports().GetReturns(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)
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func TestGetShipmentReport(t *testing.T) {
 | 
				
			||||||
 | 
						t.Parallel()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						tests := []struct {
 | 
				
			||||||
 | 
							statusCode int
 | 
				
			||||||
 | 
							headers    map[string]string
 | 
				
			||||||
 | 
							params     *GetShipmentReportParams
 | 
				
			||||||
 | 
							response   string
 | 
				
			||||||
 | 
						}{
 | 
				
			||||||
 | 
							// Test Ok
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								http.StatusOK,
 | 
				
			||||||
 | 
								map[string]string{"Client-Id": "my-client-id", "Api-Key": "my-api-key"},
 | 
				
			||||||
 | 
								&GetShipmentReportParams{
 | 
				
			||||||
 | 
									Filter: GetShipmentReportFilter{
 | 
				
			||||||
 | 
										DeliverySchema:  []string{"fbs", "fbo", "crossborder"},
 | 
				
			||||||
 | 
										ProcessedAtFrom: core.TimeFromString(t, "2006-01-02T15:04:05Z", "2021-09-02T17:10:54.861Z"),
 | 
				
			||||||
 | 
										ProcessedAtTo:   core.TimeFromString(t, "2006-01-02T15:04:05Z", "2021-11-02T17:10:54.861Z"),
 | 
				
			||||||
 | 
									},
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								`{
 | 
				
			||||||
 | 
									"result": {
 | 
				
			||||||
 | 
									  "code": "d55f4517-8347-4e24-9d93-d6e736c1c07c"
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
								}`,
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							// Test No Client-Id or Api-Key
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								http.StatusUnauthorized,
 | 
				
			||||||
 | 
								map[string]string{},
 | 
				
			||||||
 | 
								&GetShipmentReportParams{},
 | 
				
			||||||
 | 
								`{
 | 
				
			||||||
 | 
									"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.Reports().GetShipment(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