C
C
Amazon SP-API Get Orders
See more Amazon SP-API Examples
Demonstrates Amazon SP-API Sellers API -- get orders. Returns orders created or updated during the time frame indicated by the specified parameters.Chilkat C Downloads
#include <C_CkAuthAws.h>
#include <C_CkRest.h>
#include <C_CkJsonObject.h>
#include <C_CkStringBuilder.h>
void ChilkatSample(void)
{
BOOL success;
HCkAuthAws authAws;
HCkRest rest;
BOOL bTls;
int port;
BOOL bAutoReconnect;
HCkJsonObject jsonToken;
const char *rdt_token;
HCkStringBuilder sbResponse;
const char *uri;
int statusCode;
HCkJsonObject json;
const char *AmazonOrderId;
const char *PurchaseDate;
const char *LastUpdateDate;
const char *OrderStatus;
const char *FulfillmentChannel;
const char *SalesChannel;
const char *ShipServiceLevel;
const char *CurrencyCode;
const char *Amount;
int NumberOfItemsShipped;
int NumberOfItemsUnshipped;
const char *PaymentMethod;
BOOL IsReplacementOrder;
const char *MarketplaceId;
const char *ShipmentServiceLevelCategory;
const char *OrderType;
const char *EarliestShipDate;
const char *LatestShipDate;
const char *EarliestDeliveryDate;
const char *LatestDeliveryDate;
BOOL IsBusinessOrder;
BOOL IsPrime;
BOOL IsGlobalExpressEnabled;
BOOL IsPremiumOrder;
BOOL IsSoldByAB;
BOOL IsIBA;
const char *Name;
const char *AddressLine1;
const char *City;
const char *StateOrRegion;
const char *PostalCode;
const char *CountryCode;
const char *Phone;
const char *AddressType;
const char *FulfillmentSupplySourceId;
BOOL IsISPU;
BOOL IsAccessPointOrder;
BOOL HasAutomatedShippingSettings;
const char *EasyShipShipmentStatus;
const char *ElectronicInvoiceStatus;
int j;
int count_j;
const char *strVal;
const char *CreatedBefore;
int i;
int count_i;
success = FALSE;
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
// IMPORTANT:
// You'll need to make changes to use values specific to your own region and account.
//
// Here is a list of values you'll need to change or provide:
//
// 1) The access key. Change AWS_ACCESS_KEY to your actual access key.
// 2) The secret key. Change AWS_SECRET_KEY to your actual access key.
// 3) Your region. Change "ew-west-1" to your region.
// 4) The domain to which you connect. Change sandbox.sellingpartnerapi-eu.amazon.com to non-sandbox by removing the "sandbox."
// and change the "-eu" part of the domain to your region. See https://developer-docs.amazon.com/sp-api/docs/sp-api-endpoints
// 5) Use the restricted data token (RDT) obtained from your code that previously obtained the RDT.
// If you saved the RDT to a file, update the relative file path "qa_data/tokens/sp_api_rdt_token.json" to your actual file path.
// 6) Update your Marketplace ID(s), such as ATVPDKIKX0DER
// 7) If using the non-sandbox, change the CreatedAfter from "TEST_CASE_200" to an actual date, such as "2022-12-25"
authAws = CkAuthAws_Create();
CkAuthAws_putAccessKey(authAws,"AWS_ACCESS_KEY");
CkAuthAws_putSecretKey(authAws,"AWS_SECRET_KEY");
CkAuthAws_putServiceName(authAws,"execute-api");
// Use the region that is correct for your needs.
CkAuthAws_putRegion(authAws,"eu-west-1");
rest = CkRest_Create();
bTls = TRUE;
port = 443;
bAutoReconnect = TRUE;
// Make sure to use the correct domain.
// This example is using the sandbox
success = CkRest_Connect(rest,"sandbox.sellingpartnerapi-eu.amazon.com",port,bTls,bAutoReconnect);
if (success == FALSE) {
printf("%s\n",CkRest_lastErrorText(rest));
CkAuthAws_Dispose(authAws);
CkRest_Dispose(rest);
return;
}
success = CkRest_SetAuthAws(rest,authAws);
// Here's the example to get the RDT access token: Get SP-API Restricted Data Token
// Load the previously obtained RDT access token.
// See Fetch SP-API RDT Access Token
jsonToken = CkJsonObject_Create();
success = CkJsonObject_LoadFile(jsonToken,"qa_data/tokens/sp_api_rdt_token.json");
if (success == FALSE) {
printf("Failed to load RDT access token.\n");
CkAuthAws_Dispose(authAws);
CkRest_Dispose(rest);
CkJsonObject_Dispose(jsonToken);
return;
}
// Add the x-amz-access-token request header.
rdt_token = CkJsonObject_stringOf(jsonToken,"restrictedDataToken");
CkRest_ClearAllHeaders(rest);
CkRest_AddHeader(rest,"x-amz-access-token",rdt_token);
// Indicate the marketplace IDs. Use the marketplace ID for your needs. See https://developer-docs.amazon.com/sp-api/docs/marketplace-ids
CkRest_ClearAllQueryParams(rest);
// When using the sandbox, use these params literally and exactly has shown here:
CkRest_AddQueryParam(rest,"MarketplaceIds","ATVPDKIKX0DER");
CkRest_AddQueryParam(rest,"CreatedAfter","TEST_CASE_200");
sbResponse = CkStringBuilder_Create();
uri = "/orders/v0/orders";
success = CkRest_FullRequestNoBodySb(rest,"GET",uri,sbResponse);
if (success == FALSE) {
printf("%s\n",CkRest_lastErrorText(rest));
CkAuthAws_Dispose(authAws);
CkRest_Dispose(rest);
CkJsonObject_Dispose(jsonToken);
CkStringBuilder_Dispose(sbResponse);
return;
}
// Examine the response status.
statusCode = CkRest_getResponseStatusCode(rest);
if (statusCode != 200) {
printf("Response status text: %s\n",CkRest_responseStatusText(rest));
printf("Response body: \n");
printf("%s\n",CkStringBuilder_getAsString(sbResponse));
printf("Failed.\n");
CkAuthAws_Dispose(authAws);
CkRest_Dispose(rest);
CkJsonObject_Dispose(jsonToken);
CkStringBuilder_Dispose(sbResponse);
return;
}
printf("%s\n",CkStringBuilder_getAsString(sbResponse));
// If successful, gets a JSON response such as the following:
// {
// "payload": {
// "CreatedBefore": "1.569521782042E9",
// "Orders": [
// {
// "AmazonOrderId": "902-1845936-5435065",
// "PurchaseDate": "1970-01-19T03:58:30Z",
// "LastUpdateDate": "1970-01-19T03:58:32Z",
// "OrderStatus": "Unshipped",
// "FulfillmentChannel": "MFN",
// "SalesChannel": "Amazon.com",
// "ShipServiceLevel": "Std US D2D Dom",
// "OrderTotal": {
// "CurrencyCode": "USD",
// "Amount": "11.01"
// },
// "NumberOfItemsShipped": 0,
// "NumberOfItemsUnshipped": 1,
// "PaymentMethod": "Other",
// "PaymentMethodDetails": [
// "Standard"
// ],
// "IsReplacementOrder": false,
// "MarketplaceId": "ATVPDKIKX0DER",
// "ShipmentServiceLevelCategory": "Standard",
// "OrderType": "StandardOrder",
// "EarliestShipDate": "1970-01-19T03:59:27Z",
// "LatestShipDate": "1970-01-19T04:05:13Z",
// "EarliestDeliveryDate": "1970-01-19T04:06:39Z",
// "LatestDeliveryDate": "1970-01-19T04:15:17Z",
// "IsBusinessOrder": false,
// "IsPrime": false,
// "IsGlobalExpressEnabled": false,
// "IsPremiumOrder": false,
// "IsSoldByAB": false,
// "IsIBA": false,
// "DefaultShipFromLocationAddress": {
// "Name": "MFNIntegrationTestMerchant",
// "AddressLine1": "2201 WESTLAKE AVE",
// "City": "SEATTLE",
// "StateOrRegion": "WA",
// "PostalCode": "98121-2778",
// "CountryCode": "US",
// "Phone": "+1 480-386-0930 ext. 73824",
// "AddressType": "Commercial"
// },
// "FulfillmentInstruction": {
// "FulfillmentSupplySourceId": "sampleSupplySourceId"
// },
// "IsISPU": false,
// "IsAccessPointOrder": false,
// "AutomatedShippingSettings": {
// "HasAutomatedShippingSettings": false
// },
// "EasyShipShipmentStatus": "PendingPickUp",
// "ElectronicInvoiceStatus": "NotRequired"
// },
// {
// "AmazonOrderId": "902-8745147-1934268",
// "PurchaseDate": "1970-01-19T03:58:30Z",
// "LastUpdateDate": "1970-01-19T03:58:32Z",
// "OrderStatus": "Unshipped",
// "FulfillmentChannel": "MFN",
// "SalesChannel": "Amazon.com",
// "ShipServiceLevel": "Std US D2D Dom",
// "OrderTotal": {
// "CurrencyCode": "USD",
// "Amount": "11.01"
// },
// "NumberOfItemsShipped": 0,
// "NumberOfItemsUnshipped": 1,
// "PaymentMethod": "Other",
// "PaymentMethodDetails": [
// "Standard"
// ],
// "IsReplacementOrder": false,
// "MarketplaceId": "ATVPDKIKX0DER",
// "ShipmentServiceLevelCategory": "Standard",
// "OrderType": "StandardOrder",
// "EarliestShipDate": "1970-01-19T03:59:27Z",
// "LatestShipDate": "1970-01-19T04:05:13Z",
// "EarliestDeliveryDate": "1970-01-19T04:06:39Z",
// "LatestDeliveryDate": "1970-01-19T04:15:17Z",
// "IsBusinessOrder": false,
// "IsPrime": false,
// "IsAccessPointOrder": false,
// "IsGlobalExpressEnabled": false,
// "IsPremiumOrder": false,
// "IsSoldByAB": false,
// "IsIBA": false,
// "EasyShipShipmentStatus": "PendingPickUp",
// "ElectronicInvoiceStatus": "NotRequired"
// }
// ]
// }
// }
// Use this online tool to generate parsing code from sample JSON:
// Generate Parsing Code from JSON
json = CkJsonObject_Create();
CkJsonObject_LoadSb(json,sbResponse);
CreatedBefore = CkJsonObject_stringOf(json,"payload.CreatedBefore");
i = 0;
count_i = CkJsonObject_SizeOfArray(json,"payload.Orders");
while (i < count_i) {
CkJsonObject_putI(json,i);
AmazonOrderId = CkJsonObject_stringOf(json,"payload.Orders[i].AmazonOrderId");
PurchaseDate = CkJsonObject_stringOf(json,"payload.Orders[i].PurchaseDate");
LastUpdateDate = CkJsonObject_stringOf(json,"payload.Orders[i].LastUpdateDate");
OrderStatus = CkJsonObject_stringOf(json,"payload.Orders[i].OrderStatus");
FulfillmentChannel = CkJsonObject_stringOf(json,"payload.Orders[i].FulfillmentChannel");
SalesChannel = CkJsonObject_stringOf(json,"payload.Orders[i].SalesChannel");
ShipServiceLevel = CkJsonObject_stringOf(json,"payload.Orders[i].ShipServiceLevel");
CurrencyCode = CkJsonObject_stringOf(json,"payload.Orders[i].OrderTotal.CurrencyCode");
Amount = CkJsonObject_stringOf(json,"payload.Orders[i].OrderTotal.Amount");
NumberOfItemsShipped = CkJsonObject_IntOf(json,"payload.Orders[i].NumberOfItemsShipped");
NumberOfItemsUnshipped = CkJsonObject_IntOf(json,"payload.Orders[i].NumberOfItemsUnshipped");
PaymentMethod = CkJsonObject_stringOf(json,"payload.Orders[i].PaymentMethod");
IsReplacementOrder = CkJsonObject_BoolOf(json,"payload.Orders[i].IsReplacementOrder");
MarketplaceId = CkJsonObject_stringOf(json,"payload.Orders[i].MarketplaceId");
ShipmentServiceLevelCategory = CkJsonObject_stringOf(json,"payload.Orders[i].ShipmentServiceLevelCategory");
OrderType = CkJsonObject_stringOf(json,"payload.Orders[i].OrderType");
EarliestShipDate = CkJsonObject_stringOf(json,"payload.Orders[i].EarliestShipDate");
LatestShipDate = CkJsonObject_stringOf(json,"payload.Orders[i].LatestShipDate");
EarliestDeliveryDate = CkJsonObject_stringOf(json,"payload.Orders[i].EarliestDeliveryDate");
LatestDeliveryDate = CkJsonObject_stringOf(json,"payload.Orders[i].LatestDeliveryDate");
IsBusinessOrder = CkJsonObject_BoolOf(json,"payload.Orders[i].IsBusinessOrder");
IsPrime = CkJsonObject_BoolOf(json,"payload.Orders[i].IsPrime");
IsGlobalExpressEnabled = CkJsonObject_BoolOf(json,"payload.Orders[i].IsGlobalExpressEnabled");
IsPremiumOrder = CkJsonObject_BoolOf(json,"payload.Orders[i].IsPremiumOrder");
IsSoldByAB = CkJsonObject_BoolOf(json,"payload.Orders[i].IsSoldByAB");
IsIBA = CkJsonObject_BoolOf(json,"payload.Orders[i].IsIBA");
Name = CkJsonObject_stringOf(json,"payload.Orders[i].DefaultShipFromLocationAddress.Name");
AddressLine1 = CkJsonObject_stringOf(json,"payload.Orders[i].DefaultShipFromLocationAddress.AddressLine1");
City = CkJsonObject_stringOf(json,"payload.Orders[i].DefaultShipFromLocationAddress.City");
StateOrRegion = CkJsonObject_stringOf(json,"payload.Orders[i].DefaultShipFromLocationAddress.StateOrRegion");
PostalCode = CkJsonObject_stringOf(json,"payload.Orders[i].DefaultShipFromLocationAddress.PostalCode");
CountryCode = CkJsonObject_stringOf(json,"payload.Orders[i].DefaultShipFromLocationAddress.CountryCode");
Phone = CkJsonObject_stringOf(json,"payload.Orders[i].DefaultShipFromLocationAddress.Phone");
AddressType = CkJsonObject_stringOf(json,"payload.Orders[i].DefaultShipFromLocationAddress.AddressType");
FulfillmentSupplySourceId = CkJsonObject_stringOf(json,"payload.Orders[i].FulfillmentInstruction.FulfillmentSupplySourceId");
IsISPU = CkJsonObject_BoolOf(json,"payload.Orders[i].IsISPU");
IsAccessPointOrder = CkJsonObject_BoolOf(json,"payload.Orders[i].IsAccessPointOrder");
HasAutomatedShippingSettings = CkJsonObject_BoolOf(json,"payload.Orders[i].AutomatedShippingSettings.HasAutomatedShippingSettings");
EasyShipShipmentStatus = CkJsonObject_stringOf(json,"payload.Orders[i].EasyShipShipmentStatus");
ElectronicInvoiceStatus = CkJsonObject_stringOf(json,"payload.Orders[i].ElectronicInvoiceStatus");
j = 0;
count_j = CkJsonObject_SizeOfArray(json,"payload.Orders[i].PaymentMethodDetails");
while (j < count_j) {
CkJsonObject_putJ(json,j);
strVal = CkJsonObject_stringOf(json,"payload.Orders[i].PaymentMethodDetails[j]");
j = j + 1;
}
i = i + 1;
}
printf("Success!\n");
CkAuthAws_Dispose(authAws);
CkRest_Dispose(rest);
CkJsonObject_Dispose(jsonToken);
CkStringBuilder_Dispose(sbResponse);
CkJsonObject_Dispose(json);
}