151 lines
3.8 KiB
Go
151 lines
3.8 KiB
Go
package ozon
|
|
|
|
import (
|
|
"net/http"
|
|
"time"
|
|
|
|
core "github.com/diphantxm/ozon-api-client"
|
|
)
|
|
|
|
type Reports struct {
|
|
client *core.Client
|
|
}
|
|
|
|
type GetReportsListParams struct {
|
|
// Page number
|
|
Page int32 `json:"page"`
|
|
|
|
// The number of values on the page:
|
|
// - default value is 100,
|
|
// - maximum value is 1000
|
|
PageSize int32 `json:"page_size"`
|
|
|
|
// Default: "ALL"
|
|
// Report type:
|
|
// - ALL — all reports,
|
|
// - SELLER_PRODUCTS — products report,,
|
|
// - SELLER_TRANSACTIONS — transactions report,
|
|
// - SELLER_PRODUCT_PRICES — product prices report,
|
|
// - SELLER_STOCK — stocks report,
|
|
// - SELLER_PRODUCT_MOVEMENT — products movement report,
|
|
// - SELLER_RETURNS — returns report,
|
|
// - SELLER_POSTINGS — shipments report,
|
|
// - SELLER_FINANCE — financial report
|
|
ReportType string `json:"report_type"`
|
|
}
|
|
|
|
type GetReportsListResponse struct {
|
|
core.CommonResponse
|
|
|
|
// Method result
|
|
Result struct {
|
|
// Unique report identifier
|
|
Code string `json:"code"`
|
|
|
|
// Report creation date
|
|
CreatedAt time.Time `json:"created_at"`
|
|
|
|
// Error code when generating the report
|
|
Error string `json:"error"`
|
|
|
|
// Link to CSV file
|
|
File string `json:"file"`
|
|
|
|
// Array with the filters specified when the seller created the report
|
|
Params struct {
|
|
} `json:"params"`
|
|
|
|
// Report type:
|
|
// - SELLER_PRODUCTS — products report,
|
|
// - SELLER_TRANSACTIONS — transactions report,
|
|
// - SELLER_PRODUCT_PRICES — product prices report,
|
|
// - SELLER_STOCK — stocks report,
|
|
// - SELLER_PRODUCT_MOVEMENT — products movement report,
|
|
// - SELLER_RETURNS — returns report,
|
|
// - SELLER_POSTINGS — shipments report,
|
|
// - SELLER_FINANCE — financial report
|
|
ReportType string `json:"report_type"`
|
|
|
|
// Report generation status
|
|
// - `success`
|
|
// - `failed`
|
|
Status string `json:"status"`
|
|
} `json:"result"`
|
|
|
|
// Total number of reports
|
|
Total int32 `json:"total"`
|
|
}
|
|
|
|
// Returns the list of reports that have been generated before
|
|
func (c Reports) GetList(params *GetReportsListParams) (*GetReportsListResponse, error) {
|
|
url := "/v1/report/list"
|
|
|
|
resp := &GetReportsListResponse{}
|
|
|
|
response, err := c.client.Request(http.MethodPost, url, params, resp)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
response.CopyCommonResponse(&resp.CommonResponse)
|
|
|
|
return resp, nil
|
|
}
|
|
|
|
type GetReportDetailsParams struct {
|
|
// Unique report identifier
|
|
Code string `json:"code"`
|
|
}
|
|
|
|
type GetReportDetailsResponse struct {
|
|
core.CommonResponse
|
|
|
|
// Report details
|
|
Result struct {
|
|
// Unique report identifier
|
|
Code string `json:"code"`
|
|
|
|
// Report creation date
|
|
CreatedAt time.Time `json:"created_at"`
|
|
|
|
// Error code when generating the report
|
|
Error string `json:"error"`
|
|
|
|
// Link to CSV file
|
|
File string `json:"file"`
|
|
|
|
// Array with the filters specified when the seller created the report
|
|
Params map[string]string `json:"params"`
|
|
|
|
// Report type:
|
|
// - SELLER_PRODUCTS — products report,
|
|
// - SELLER_TRANSACTIONS — transactions report,
|
|
// - SELLER_PRODUCT_PRICES — product prices report,
|
|
// - SELLER_STOCK — stocks report,
|
|
// - SELLER_PRODUCT_MOVEMENT — products movement report,
|
|
// - SELLER_RETURNS — returns report,
|
|
// - SELLER_POSTINGS — shipments report,
|
|
// - SELLER_FINANCE — financial report
|
|
ReportType string `json:"report_type"`
|
|
|
|
// Report generation status:
|
|
// - success
|
|
// - failed
|
|
Status string `json:"status"`
|
|
} `json:"result"`
|
|
}
|
|
|
|
// Returns information about a created report by its identifier
|
|
func (c Reports) GetReportDetails(params *GetReportDetailsParams) (*GetReportDetailsResponse, error) {
|
|
url := "/v1/report/list"
|
|
|
|
resp := &GetReportDetailsResponse{}
|
|
|
|
response, err := c.client.Request(http.MethodPost, url, params, resp)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
response.CopyCommonResponse(&resp.CommonResponse)
|
|
|
|
return resp, nil
|
|
}
|