Sample code for 30+ languages & platforms
Tcl

Amazon SP-API Get Order Items

See more Amazon SP-API Examples

Returns detailed order item information for the order that you specify.

Chilkat Tcl Downloads

Tcl

load ./chilkat.dll

set success 0

# This example requires the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.

# Gets detailed order item information for a specified order ID
# The order ID is something like "902-1845936-5435065" and it is the AmazonOrderId returned in the JSON when getting the list of orders.  For example:
# {
#   "payload": {
#     "CreatedBefore": "1.569521782042E9",
#     "Orders": [
#       {
#         "AmazonOrderId": "902-1845936-5435065",
#         "PurchaseDate": "1970-01-19T03:58:30Z",
# ...

# However, when using the sandbox, instead use the explicit keyword TEST_CASE_200
set orderId "TEST_CASE_200"

set authAws [new_CkAuthAws]

CkAuthAws_put_AccessKey $authAws "AWS_ACCESS_KEY"
CkAuthAws_put_SecretKey $authAws "AWS_SECRET_KEY"
CkAuthAws_put_ServiceName $authAws "execute-api"
# Use the region that is correct for your needs.
CkAuthAws_put_Region $authAws "eu-west-1"

# First get a restricted data token for the given order ID.
# This requires an LWA access token which cannot be more than 1 hour old.
# See Fetch SP-API LWA Access Token
set jsonLwaToken [new_CkJsonObject]

set success [CkJsonObject_LoadFile $jsonLwaToken "qa_data/tokens/sp_api_lwa_token.json"]
if {$success == 0} then {
    puts "Failed to load LWA access token."
    delete_CkAuthAws $authAws
    delete_CkJsonObject $jsonLwaToken
    exit
}

# Must use the non-sandbox domain for getting the RDT.
set rest [new_CkRest]

set success [CkRest_Connect $rest "sellingpartnerapi-eu.amazon.com" 443 1 1]
if {$success == 0} then {
    puts [CkRest_lastErrorText $rest]
    delete_CkAuthAws $authAws
    delete_CkJsonObject $jsonLwaToken
    delete_CkRest $rest
    exit
}

set success [CkRest_SetAuthAws $rest $authAws]

# Add the x-amz-access-token request header.
set lwa_token [CkJsonObject_stringOf $jsonLwaToken "access_token"]
CkRest_ClearAllHeaders $rest
CkRest_AddHeader $rest "x-amz-access-token" $lwa_token

# We're going to send a POST with the following JSON body:

# {
#   "restrictedResources": [
#     {
#       "method": "GET",
#       "path": "/orders/v0/orders/{orderId}/orderItems",
#       "dataElements": ["buyerInfo"]
#     }
#   ]
# }

set sbPath [new_CkStringBuilder]

CkStringBuilder_Append $sbPath "/orders/v0/orders/"
CkStringBuilder_Append $sbPath $orderId
CkStringBuilder_Append $sbPath "/orderItems"

set jsonRc [new_CkJsonObject]

CkJsonObject_UpdateString $jsonRc "restrictedResources[0].method" "GET"
CkJsonObject_UpdateString $jsonRc "restrictedResources[0].path" [CkStringBuilder_getAsString $sbPath]
CkJsonObject_UpdateString $jsonRc "restrictedResources[0].dataElements[0]" "buyerInfo"

set sbRequest [new_CkStringBuilder]

CkJsonObject_EmitSb $jsonRc $sbRequest

set sbResponse [new_CkStringBuilder]

set uri "/tokens/2021-03-01/restrictedDataToken"
set success [CkRest_FullRequestSb $rest "POST" $uri $sbRequest $sbResponse]
if {$success == 0} then {
    puts [CkRest_lastErrorText $rest]
    delete_CkAuthAws $authAws
    delete_CkJsonObject $jsonLwaToken
    delete_CkRest $rest
    delete_CkStringBuilder $sbPath
    delete_CkJsonObject $jsonRc
    delete_CkStringBuilder $sbRequest
    delete_CkStringBuilder $sbResponse
    exit
}

# Examine the response status.
set statusCode [CkRest_get_ResponseStatusCode $rest]
if {$statusCode != 200} then {
    puts "Response status code: $statusCode"
    puts "Response status text: [CkRest_responseStatusText $rest]"
    puts "Response body: "
    puts [CkStringBuilder_getAsString $sbResponse]
    puts "Failed."
    delete_CkAuthAws $authAws
    delete_CkJsonObject $jsonLwaToken
    delete_CkRest $rest
    delete_CkStringBuilder $sbPath
    delete_CkJsonObject $jsonRc
    delete_CkStringBuilder $sbRequest
    delete_CkStringBuilder $sbResponse
    exit
}

# Get the restricted data token.
set jsonResp [new_CkJsonObject]

CkJsonObject_LoadSb $jsonResp $sbResponse
set restrictedDataToken [CkJsonObject_stringOf $jsonResp "restrictedDataToken"]
puts "Restricted Data Token: $restrictedDataToken"

# ------------------------------------------------------------------------------------------------------------
# ------------------------------------------------------------------------------------------------------------
# Now that we have the RDT, we can use it to get information about the order.
# 
# Yes, the SP-API is horribly tedious and painful.  You must use an RDT specifically tailored to each request requiring an RDT,
# the RDT must not be over an hour old, and if you need to get a new RDT you must get it using an LWA token that itself is not
# more than an hour old.  If the LWA is more than an hour old, you must get a new one.  Ughhh!!!!!
# ------------------------------------------------------------------------------------------------------------

# Disconnect from the non-sandbox domain.  This example will use the sandbox.
# (The RDT was obtained using the non-sandbox domain.  For some reason, the sandbox domain does not work for getting the RDT.)
CkRest_Disconnect $rest 100

set success [CkRest_Connect $rest "sandbox.sellingpartnerapi-eu.amazon.com" 443 1 1]
if {$success == 0} then {
    puts [CkRest_lastErrorText $rest]
    delete_CkAuthAws $authAws
    delete_CkJsonObject $jsonLwaToken
    delete_CkRest $rest
    delete_CkStringBuilder $sbPath
    delete_CkJsonObject $jsonRc
    delete_CkStringBuilder $sbRequest
    delete_CkStringBuilder $sbResponse
    delete_CkJsonObject $jsonResp
    exit
}

set success [CkRest_SetAuthAws $rest $authAws]

CkRest_ClearAllHeaders $rest
CkRest_AddHeader $rest "x-amz-access-token" $restrictedDataToken

CkRest_ClearAllQueryParams $rest
CkRest_AddQueryParam $rest "MarketplaceIds" "ATVPDKIKX0DER"

CkRest_ClearAllPathParams $rest
CkRest_AddPathParam $rest "{orderId}" $orderId

set uri "/orders/v0/orders/{orderId}/orderItems"
set success [CkRest_FullRequestNoBodySb $rest "GET" $uri $sbResponse]
if {$success == 0} then {
    puts [CkRest_lastErrorText $rest]
    delete_CkAuthAws $authAws
    delete_CkJsonObject $jsonLwaToken
    delete_CkRest $rest
    delete_CkStringBuilder $sbPath
    delete_CkJsonObject $jsonRc
    delete_CkStringBuilder $sbRequest
    delete_CkStringBuilder $sbResponse
    delete_CkJsonObject $jsonResp
    exit
}

# Examine the response status.
set statusCode [CkRest_get_ResponseStatusCode $rest]
if {$statusCode != 200} then {
    puts "Response status text: [CkRest_responseStatusText $rest]"
    puts "Response body: "
    puts [CkStringBuilder_getAsString $sbResponse]
    puts "Failed."
    delete_CkAuthAws $authAws
    delete_CkJsonObject $jsonLwaToken
    delete_CkRest $rest
    delete_CkStringBuilder $sbPath
    delete_CkJsonObject $jsonRc
    delete_CkStringBuilder $sbRequest
    delete_CkStringBuilder $sbResponse
    delete_CkJsonObject $jsonResp
    exit
}

# If successful, gets a JSON response such as the following:

# {
#   "payload": {
#     "AmazonOrderId": "902-1845936-5435065",
#     "OrderItems": [
#       {
#         "ASIN": "B00551Q3CS",
#         "OrderItemId": "05015851154158",
#         "SellerSKU": "NABetaASINB00551Q3CS",
#         "Title": "B00551Q3CS [Card Book]",
#         "QuantityOrdered": 1,
#         "QuantityShipped": 0,
#         "ProductInfo": {
#           "NumberOfItems": 1
#         },
#         "ItemPrice": {
#           "CurrencyCode": "USD",
#           "Amount": "10.00"
#         },
#         "ItemTax": {
#           "CurrencyCode": "USD",
#           "Amount": "1.01"
#         },
#         "PromotionDiscount": {
#           "CurrencyCode": "USD",
#           "Amount": "0.00"
#         },
#         "IsGift": false,
#         "ConditionId": "New",
#         "ConditionSubtypeId": "New",
#         "IsTransparency": false,
#         "SerialNumberRequired": false,
#         "IossNumber": "",
#         "DeemedResellerCategory": "IOSS",
#         "StoreChainStoreId": "ISPU_StoreId",
#         "BuyerRequestedCancel": {
#           "IsBuyerRequestedCancel": true,
#           "BuyerCancelReason": "Found cheaper somewhere else."
#         }
#       }
#     ]
#   }
# }

# Use this online tool to generate parsing code from sample JSON: 
# Generate Parsing Code from JSON

set json [new_CkJsonObject]

CkJsonObject_LoadSb $json $sbResponse
CkJsonObject_put_EmitCompact $json 0
puts [CkJsonObject_emit $json]

set AmazonOrderId [CkJsonObject_stringOf $json "payload.AmazonOrderId"]
set i 0
set count_i [CkJsonObject_SizeOfArray $json "payload.OrderItems"]
while {$i < $count_i} {
    CkJsonObject_put_I $json $i
    set ASIN [CkJsonObject_stringOf $json "payload.OrderItems[i].ASIN"]
    set OrderItemId [CkJsonObject_stringOf $json "payload.OrderItems[i].OrderItemId"]
    set SellerSKU [CkJsonObject_stringOf $json "payload.OrderItems[i].SellerSKU"]
    set Title [CkJsonObject_stringOf $json "payload.OrderItems[i].Title"]
    set QuantityOrdered [CkJsonObject_IntOf $json "payload.OrderItems[i].QuantityOrdered"]
    set QuantityShipped [CkJsonObject_IntOf $json "payload.OrderItems[i].QuantityShipped"]
    set NumberOfItems [CkJsonObject_IntOf $json "payload.OrderItems[i].ProductInfo.NumberOfItems"]
    set CurrencyCode [CkJsonObject_stringOf $json "payload.OrderItems[i].ItemPrice.CurrencyCode"]
    set Amount [CkJsonObject_stringOf $json "payload.OrderItems[i].ItemPrice.Amount"]
    set ItemTaxCurrencyCode [CkJsonObject_stringOf $json "payload.OrderItems[i].ItemTax.CurrencyCode"]
    set ItemTaxAmount [CkJsonObject_stringOf $json "payload.OrderItems[i].ItemTax.Amount"]
    set PromotionDiscountCurrencyCode [CkJsonObject_stringOf $json "payload.OrderItems[i].PromotionDiscount.CurrencyCode"]
    set PromotionDiscountAmount [CkJsonObject_stringOf $json "payload.OrderItems[i].PromotionDiscount.Amount"]
    set IsGift [CkJsonObject_BoolOf $json "payload.OrderItems[i].IsGift"]
    set ConditionId [CkJsonObject_stringOf $json "payload.OrderItems[i].ConditionId"]
    set ConditionSubtypeId [CkJsonObject_stringOf $json "payload.OrderItems[i].ConditionSubtypeId"]
    set IsTransparency [CkJsonObject_BoolOf $json "payload.OrderItems[i].IsTransparency"]
    set SerialNumberRequired [CkJsonObject_BoolOf $json "payload.OrderItems[i].SerialNumberRequired"]
    set IossNumber [CkJsonObject_stringOf $json "payload.OrderItems[i].IossNumber"]
    set DeemedResellerCategory [CkJsonObject_stringOf $json "payload.OrderItems[i].DeemedResellerCategory"]
    set StoreChainStoreId [CkJsonObject_stringOf $json "payload.OrderItems[i].StoreChainStoreId"]
    set IsBuyerRequestedCancel [CkJsonObject_BoolOf $json "payload.OrderItems[i].BuyerRequestedCancel.IsBuyerRequestedCancel"]
    set BuyerCancelReason [CkJsonObject_stringOf $json "payload.OrderItems[i].BuyerRequestedCancel.BuyerCancelReason"]
    set i [expr $i + 1]
}

puts "Success!"

delete_CkAuthAws $authAws
delete_CkJsonObject $jsonLwaToken
delete_CkRest $rest
delete_CkStringBuilder $sbPath
delete_CkJsonObject $jsonRc
delete_CkStringBuilder $sbRequest
delete_CkStringBuilder $sbResponse
delete_CkJsonObject $jsonResp
delete_CkJsonObject $json