-
Notifications
You must be signed in to change notification settings - Fork 53
/
SalesSDK.php
313 lines (276 loc) · 18.7 KB
/
SalesSDK.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
<?php
declare(strict_types=1);
namespace AmazonPHP\SellingPartner\Api\SalesApi;
use AmazonPHP\SellingPartner\AccessToken;
use AmazonPHP\SellingPartner\Configuration;
use AmazonPHP\SellingPartner\Exception\ApiException;
use AmazonPHP\SellingPartner\Exception\InvalidArgumentException;
use AmazonPHP\SellingPartner\HttpFactory;
use AmazonPHP\SellingPartner\HttpSignatureHeaders;
use AmazonPHP\SellingPartner\ObjectSerializer;
use Psr\Http\Client\ClientExceptionInterface;
use Psr\Http\Client\ClientInterface;
use Psr\Http\Message\RequestInterface;
use Psr\Log\LoggerInterface;
/**
* Selling Partner API for Sales.
*
* The Selling Partner API for Sales provides APIs related to sales performance.
*
* The version of the OpenAPI document: v1
*
* This class was auto-generated by https://openapi-generator.tech
* Do not change it, it will be overwritten with next execution of /bin/generate.sh
*/
final class SalesSDK implements SalesSDKInterface
{
public function __construct(private readonly ClientInterface $client, private readonly HttpFactory $httpFactory, private readonly Configuration $configuration, private readonly LoggerInterface $logger)
{
}
/**
* Operation getOrderMetrics.
*
* @param string[] $marketplace_ids A marketplace identifier. This specifies the marketplace in which the order was placed. Only one marketplace can be specified. For example, ATVPDKIKX0DER indicates the US marketplace. (required)
* @param string $interval A time interval used for selecting order metrics. This takes the form of two dates separated by two hyphens (first date is inclusive; second date is exclusive). Dates are in ISO8601 format and must represent absolute time (either Z notation or offset notation). Example: 2018-09-01T00:00:00-07:00--2018-09-04T00:00:00-07:00 requests order metrics for Sept 1st, 2nd and 3rd in the -07:00 zone. (required)
* @param string $granularity The granularity of the grouping of order metrics, based on a unit of time. Specifying granularity=Hour results in a successful request only if the interval specified is less than or equal to 30 days from now. For all other granularities, the interval specified must be less or equal to 2 years from now. Specifying granularity=Total results in order metrics that are aggregated over the entire interval that you specify. If the interval start and end date don’t align with the specified granularity, the head and tail end of the response interval will contain partial data. Example: Day to get a daily breakdown of the request interval, where the day boundary is defined by the granularityTimeZone. (required)
* @param null|string $granularity_time_zone An IANA-compatible time zone for determining the day boundary. Required when specifying a granularity value greater than Hour. The granularityTimeZone value must align with the offset of the specified interval value. For example, if the interval value uses Z notation, then granularityTimeZone must be UTC. If the interval value uses an offset, then granularityTimeZone must be an IANA-compatible time zone that matches the offset. Example: US/Pacific to compute day boundaries, accounting for daylight time savings, for US/Pacific zone. (optional)
* @param null|string $buyer_type Filters the results by the buyer type that you specify, B2B (business to business) or B2C (business to customer). Example: B2B, if you want the response to include order metrics for only B2B buyers. (optional, default to 'All')
* @param null|string $fulfillment_network Filters the results by the fulfillment network that you specify, MFN (merchant fulfillment network) or AFN (Amazon fulfillment network). Do not include this filter if you want the response to include order metrics for all fulfillment networks. Example: AFN, if you want the response to include order metrics for only Amazon fulfillment network. (optional)
* @param null|string $first_day_of_week Specifies the day that the week starts on when granularity=Week, either Monday or Sunday. Default: Monday. Example: Sunday, if you want the week to start on a Sunday. (optional, default to 'Monday')
* @param null|string $asin Filters the results by the ASIN that you specify. Specifying both ASIN and SKU returns an error. Do not include this filter if you want the response to include order metrics for all ASINs. Example: B0792R1RSN, if you want the response to include order metrics for only ASIN B0792R1RSN. (optional)
* @param null|string $sku Filters the results by the SKU that you specify. Specifying both ASIN and SKU returns an error. Do not include this filter if you want the response to include order metrics for all SKUs. Example: TestSKU, if you want the response to include order metrics for only SKU TestSKU. (optional)
*
* @throws ApiException on non-2xx response
* @throws InvalidArgumentException
*/
public function getOrderMetrics(AccessToken $accessToken, string $region, array $marketplace_ids, string $interval, string $granularity, ?string $granularity_time_zone = null, ?string $buyer_type = 'All', ?string $fulfillment_network = null, ?string $first_day_of_week = 'Monday', ?string $asin = null, ?string $sku = null) : \AmazonPHP\SellingPartner\Model\Sales\GetOrderMetricsResponse
{
$request = $this->getOrderMetricsRequest($accessToken, $region, $marketplace_ids, $interval, $granularity, $granularity_time_zone, $buyer_type, $fulfillment_network, $first_day_of_week, $asin, $sku);
$this->configuration->extensions()->preRequest('Sales', 'getOrderMetrics', $request);
try {
$correlationId = $this->configuration->idGenerator()->generate();
$sanitizedRequest = $request;
foreach ($this->configuration->loggingSkipHeaders() as $sensitiveHeader) {
$sanitizedRequest = $sanitizedRequest->withoutHeader($sensitiveHeader);
}
if ($this->configuration->loggingEnabled('Sales', 'getOrderMetrics')) {
$this->logger->log(
$this->configuration->logLevel('Sales', 'getOrderMetrics'),
'Amazon Selling Partner API pre request',
[
'api' => 'Sales',
'operation' => 'getOrderMetrics',
'request_correlation_id' => $correlationId,
'request_body' => (string) $sanitizedRequest->getBody(),
'request_headers' => $sanitizedRequest->getHeaders(),
'request_uri' => (string) $sanitizedRequest->getUri(),
]
);
}
$response = $this->client->sendRequest($request);
$this->configuration->extensions()->postRequest('Sales', 'getOrderMetrics', $request, $response);
if ($this->configuration->loggingEnabled('Sales', 'getOrderMetrics')) {
$sanitizedResponse = $response;
foreach ($this->configuration->loggingSkipHeaders() as $sensitiveHeader) {
$sanitizedResponse = $sanitizedResponse->withoutHeader($sensitiveHeader);
}
$this->logger->log(
$this->configuration->logLevel('Sales', 'getOrderMetrics'),
'Amazon Selling Partner API post request',
[
'api' => 'Sales',
'operation' => 'getOrderMetrics',
'response_correlation_id' => $correlationId,
'response_body' => (string) $sanitizedResponse->getBody(),
'response_headers' => $sanitizedResponse->getHeaders(),
'response_status_code' => $sanitizedResponse->getStatusCode(),
'request_uri' => (string) $sanitizedRequest->getUri(),
'request_body' => (string) $sanitizedRequest->getBody(),
]
);
}
} catch (ClientExceptionInterface $e) {
throw new ApiException(
"[{$e->getCode()}] {$e->getMessage()}",
(int) $e->getCode(),
null,
null,
$e
);
}
$statusCode = $response->getStatusCode();
if ($statusCode < 200 || $statusCode > 299) {
throw new ApiException(
\sprintf(
'[%d] Error connecting to the API (%s)',
$statusCode,
(string) $request->getUri()
),
$statusCode,
$response->getHeaders(),
(string) $response->getBody()
);
}
return ObjectSerializer::deserialize(
$this->configuration,
(string) $response->getBody(),
'\AmazonPHP\SellingPartner\Model\Sales\GetOrderMetricsResponse',
[]
);
}
/**
* Create request for operation 'getOrderMetrics'.
*
* @param string[] $marketplace_ids A marketplace identifier. This specifies the marketplace in which the order was placed. Only one marketplace can be specified. For example, ATVPDKIKX0DER indicates the US marketplace. (required)
* @param string $interval A time interval used for selecting order metrics. This takes the form of two dates separated by two hyphens (first date is inclusive; second date is exclusive). Dates are in ISO8601 format and must represent absolute time (either Z notation or offset notation). Example: 2018-09-01T00:00:00-07:00--2018-09-04T00:00:00-07:00 requests order metrics for Sept 1st, 2nd and 3rd in the -07:00 zone. (required)
* @param string $granularity The granularity of the grouping of order metrics, based on a unit of time. Specifying granularity=Hour results in a successful request only if the interval specified is less than or equal to 30 days from now. For all other granularities, the interval specified must be less or equal to 2 years from now. Specifying granularity=Total results in order metrics that are aggregated over the entire interval that you specify. If the interval start and end date don’t align with the specified granularity, the head and tail end of the response interval will contain partial data. Example: Day to get a daily breakdown of the request interval, where the day boundary is defined by the granularityTimeZone. (required)
* @param null|string $granularity_time_zone An IANA-compatible time zone for determining the day boundary. Required when specifying a granularity value greater than Hour. The granularityTimeZone value must align with the offset of the specified interval value. For example, if the interval value uses Z notation, then granularityTimeZone must be UTC. If the interval value uses an offset, then granularityTimeZone must be an IANA-compatible time zone that matches the offset. Example: US/Pacific to compute day boundaries, accounting for daylight time savings, for US/Pacific zone. (optional)
* @param string $buyer_type Filters the results by the buyer type that you specify, B2B (business to business) or B2C (business to customer). Example: B2B, if you want the response to include order metrics for only B2B buyers. (optional, default to 'All')
* @param null|string $fulfillment_network Filters the results by the fulfillment network that you specify, MFN (merchant fulfillment network) or AFN (Amazon fulfillment network). Do not include this filter if you want the response to include order metrics for all fulfillment networks. Example: AFN, if you want the response to include order metrics for only Amazon fulfillment network. (optional)
* @param string $first_day_of_week Specifies the day that the week starts on when granularity=Week, either Monday or Sunday. Default: Monday. Example: Sunday, if you want the week to start on a Sunday. (optional, default to 'Monday')
* @param null|string $asin Filters the results by the ASIN that you specify. Specifying both ASIN and SKU returns an error. Do not include this filter if you want the response to include order metrics for all ASINs. Example: B0792R1RSN, if you want the response to include order metrics for only ASIN B0792R1RSN. (optional)
* @param null|string $sku Filters the results by the SKU that you specify. Specifying both ASIN and SKU returns an error. Do not include this filter if you want the response to include order metrics for all SKUs. Example: TestSKU, if you want the response to include order metrics for only SKU TestSKU. (optional)
*
* @throws \AmazonPHP\SellingPartner\Exception\InvalidArgumentException
*/
public function getOrderMetricsRequest(AccessToken $accessToken, string $region, array $marketplace_ids, string $interval, string $granularity, ?string $granularity_time_zone = null, string $buyer_type = 'All', ?string $fulfillment_network = null, string $first_day_of_week = 'Monday', ?string $asin = null, ?string $sku = null) : RequestInterface
{
// verify the required parameter 'marketplace_ids' is set
if ($marketplace_ids === null || (\is_array($marketplace_ids) && \count($marketplace_ids) === 0)) {
throw new InvalidArgumentException(
'Missing the required parameter $marketplace_ids when calling getOrderMetrics'
);
}
// verify the required parameter 'interval' is set
if ($interval === null || (\is_array($interval) && \count($interval) === 0)) {
throw new InvalidArgumentException(
'Missing the required parameter $interval when calling getOrderMetrics'
);
}
// verify the required parameter 'granularity' is set
if ($granularity === null || (\is_array($granularity) && \count($granularity) === 0)) {
throw new InvalidArgumentException(
'Missing the required parameter $granularity when calling getOrderMetrics'
);
}
$resourcePath = '/sales/v1/orderMetrics';
$formParams = [];
$queryParams = [];
$headerParams = [];
$multipart = false;
$query = '';
// query params
if (\is_array($marketplace_ids)) {
$marketplace_ids = ObjectSerializer::serializeCollection($marketplace_ids, 'form', true);
}
if ($marketplace_ids !== null) {
$queryParams['marketplaceIds'] = ObjectSerializer::toString($marketplace_ids);
}
// query params
if (\is_array($interval)) {
$interval = ObjectSerializer::serializeCollection($interval, '', true);
}
if ($interval !== null) {
$queryParams['interval'] = ObjectSerializer::toString($interval);
}
// query params
if (\is_array($granularity_time_zone)) {
$granularity_time_zone = ObjectSerializer::serializeCollection($granularity_time_zone, '', true);
}
if ($granularity_time_zone !== null) {
$queryParams['granularityTimeZone'] = ObjectSerializer::toString($granularity_time_zone);
}
// query params
if (\is_array($granularity)) {
$granularity = ObjectSerializer::serializeCollection($granularity, '', true);
}
if ($granularity !== null) {
$queryParams['granularity'] = ObjectSerializer::toString($granularity);
}
// query params
if (\is_array($buyer_type)) {
$buyer_type = ObjectSerializer::serializeCollection($buyer_type, '', true);
}
if ($buyer_type !== null) {
$queryParams['buyerType'] = ObjectSerializer::toString($buyer_type);
}
// query params
if (\is_array($fulfillment_network)) {
$fulfillment_network = ObjectSerializer::serializeCollection($fulfillment_network, '', true);
}
if ($fulfillment_network !== null) {
$queryParams['fulfillmentNetwork'] = ObjectSerializer::toString($fulfillment_network);
}
// query params
if (\is_array($first_day_of_week)) {
$first_day_of_week = ObjectSerializer::serializeCollection($first_day_of_week, '', true);
}
if ($first_day_of_week !== null) {
$queryParams['firstDayOfWeek'] = ObjectSerializer::toString($first_day_of_week);
}
// query params
if (\is_array($asin)) {
$asin = ObjectSerializer::serializeCollection($asin, '', true);
}
if ($asin !== null) {
$queryParams['asin'] = ObjectSerializer::toString($asin);
}
// query params
if (\is_array($sku)) {
$sku = ObjectSerializer::serializeCollection($sku, '', true);
}
if ($sku !== null) {
$queryParams['sku'] = ObjectSerializer::toString($sku);
}
if (\count($queryParams)) {
$query = \http_build_query($queryParams);
}
if ($multipart) {
$headers = [
'accept' => ['application/json'],
'host' => [$this->configuration->apiHost($region)],
'user-agent' => [$this->configuration->userAgent()],
];
} else {
$headers = [
'content-type' => ['application/json'],
'accept' => ['application/json'],
'host' => [$this->configuration->apiHost($region)],
'user-agent' => [$this->configuration->userAgent()],
];
}
$request = $this->httpFactory->createRequest(
'GET',
$this->configuration->apiURL($region) . $resourcePath . '?' . $query
);
// for model (json/xml)
if (\count($formParams) > 0) {
if ($multipart) {
$multipartContents = [];
foreach ($formParams as $formParamName => $formParamValue) {
$formParamValueItems = \is_array($formParamValue) ? $formParamValue : [$formParamValue];
foreach ($formParamValueItems as $formParamValueItem) {
$multipartContents[] = [
'name' => $formParamName,
'contents' => $formParamValueItem,
];
}
}
$request = $request->withParsedBody($multipartContents);
} elseif ($headers['content-type'] === ['application/json']) {
$request = $request->withBody($this->httpFactory->createStreamFromString(\json_encode($formParams, JSON_THROW_ON_ERROR)));
} else {
$request = $request->withParsedBody($formParams);
}
}
foreach (\array_merge($headerParams, $headers) as $name => $header) {
$request = $request->withHeader($name, $header);
}
return HttpSignatureHeaders::forConfig(
$this->configuration,
$accessToken,
$region,
$request
);
}
}