Sample code for 30+ languages & platforms
Android™

Amazon SP-API Get Specific Order

See more Amazon SP-API Examples

Get a specific Amazon Seller order.

Chilkat Android™ Downloads

Android™
// Important: Don't forget to include the call to System.loadLibrary
// as shown at the bottom of this code sample.
package com.test;

import android.app.Activity;
import com.chilkatsoft.*;

import android.widget.TextView;
import android.os.Bundle;

public class SimpleActivity extends Activity {

  private static final String TAG = "Chilkat";

  // Called when the activity is first created.
  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    boolean success = false;

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

    // Gets information for this 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
    String orderId = "TEST_CASE_200";

    CkAuthAws authAws = new CkAuthAws();
    authAws.put_AccessKey("AWS_ACCESS_KEY");
    authAws.put_SecretKey("AWS_SECRET_KEY");
    authAws.put_ServiceName("execute-api");
    // Use the region that is correct for your needs.
    authAws.put_Region("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
    CkJsonObject jsonLwaToken = new CkJsonObject();
    success = jsonLwaToken.LoadFile("qa_data/tokens/sp_api_lwa_token.json");
    if (success == false) {
        Log.i(TAG, "Failed to load LWA access token.");
        return;
        }

    // Must use the non-sandbox domain for getting the RDT.
    CkRest rest = new CkRest();
    success = rest.Connect("sellingpartnerapi-eu.amazon.com",443,true,true);
    if (success == false) {
        Log.i(TAG, rest.lastErrorText());
        return;
        }

    success = rest.SetAuthAws(authAws);

    // Add the x-amz-access-token request header.
    String lwa_token = jsonLwaToken.stringOf("access_token");
    rest.ClearAllHeaders();
    rest.AddHeader("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}",
    //       "dataElements": ["buyerInfo", "shippingAddress"]
    //     }
    //   ]
    // }

    CkStringBuilder sbPath = new CkStringBuilder();
    sbPath.Append("/orders/v0/orders/");
    sbPath.Append(orderId);

    CkJsonObject jsonRc = new CkJsonObject();
    jsonRc.UpdateString("restrictedResources[0].method","GET");
    jsonRc.UpdateString("restrictedResources[0].path",sbPath.getAsString());
    jsonRc.UpdateString("restrictedResources[0].dataElements[0]","buyerInfo");
    jsonRc.UpdateString("restrictedResources[0].dataElements[1]","shippingAddress");

    CkStringBuilder sbRequest = new CkStringBuilder();
    jsonRc.EmitSb(sbRequest);

    CkStringBuilder sbResponse = new CkStringBuilder();
    String uri = "/tokens/2021-03-01/restrictedDataToken";
    success = rest.FullRequestSb("POST",uri,sbRequest,sbResponse);
    if (success == false) {
        Log.i(TAG, rest.lastErrorText());
        return;
        }

    // Examine the response status.
    int statusCode = rest.get_ResponseStatusCode();
    if (statusCode != 200) {
        Log.i(TAG, "Response status code: " + String.valueOf(statusCode));
        Log.i(TAG, "Response status text: " + rest.responseStatusText());
        Log.i(TAG, "Response body: ");
        Log.i(TAG, sbResponse.getAsString());
        Log.i(TAG, "Failed.");
        return;
        }

    // Get the restricted data token.
    CkJsonObject jsonResp = new CkJsonObject();
    jsonResp.LoadSb(sbResponse);
    String restrictedDataToken = jsonResp.stringOf("restrictedDataToken");
    Log.i(TAG, "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.)
    rest.Disconnect(100);

    success = rest.Connect("sandbox.sellingpartnerapi-eu.amazon.com",443,true,true);
    if (success == false) {
        Log.i(TAG, rest.lastErrorText());
        return;
        }

    success = rest.SetAuthAws(authAws);

    rest.ClearAllHeaders();
    rest.AddHeader("x-amz-access-token",restrictedDataToken);

    rest.ClearAllQueryParams();
    rest.AddQueryParam("MarketplaceIds","ATVPDKIKX0DER");

    rest.ClearAllPathParams();
    rest.AddPathParam("{orderId}",orderId);

    uri = "/orders/v0/orders/{orderId}";
    success = rest.FullRequestNoBodySb("GET",uri,sbResponse);
    if (success == false) {
        Log.i(TAG, rest.lastErrorText());
        return;
        }

    // Examine the response status.
    statusCode = rest.get_ResponseStatusCode();
    if (statusCode != 200) {
        Log.i(TAG, "Response status text: " + rest.responseStatusText());
        Log.i(TAG, "Response body: ");
        Log.i(TAG, sbResponse.getAsString());
        Log.i(TAG, "Failed.");
        return;
        }

    Log.i(TAG, sbResponse.getAsString());

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

    // {
    //   "payload": {
    //     "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"
    //   }
    // }

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

    CkJsonObject json = new CkJsonObject();

    json.LoadSb(sbResponse);

    String strVal;

    String AmazonOrderId = json.stringOf("payload.AmazonOrderId");
    String PurchaseDate = json.stringOf("payload.PurchaseDate");
    String LastUpdateDate = json.stringOf("payload.LastUpdateDate");
    String OrderStatus = json.stringOf("payload.OrderStatus");
    String FulfillmentChannel = json.stringOf("payload.FulfillmentChannel");
    String SalesChannel = json.stringOf("payload.SalesChannel");
    String ShipServiceLevel = json.stringOf("payload.ShipServiceLevel");
    String CurrencyCode = json.stringOf("payload.OrderTotal.CurrencyCode");
    String Amount = json.stringOf("payload.OrderTotal.Amount");
    int NumberOfItemsShipped = json.IntOf("payload.NumberOfItemsShipped");
    int NumberOfItemsUnshipped = json.IntOf("payload.NumberOfItemsUnshipped");
    String PaymentMethod = json.stringOf("payload.PaymentMethod");
    boolean IsReplacementOrder = json.BoolOf("payload.IsReplacementOrder");
    String MarketplaceId = json.stringOf("payload.MarketplaceId");
    String ShipmentServiceLevelCategory = json.stringOf("payload.ShipmentServiceLevelCategory");
    String OrderType = json.stringOf("payload.OrderType");
    String EarliestShipDate = json.stringOf("payload.EarliestShipDate");
    String LatestShipDate = json.stringOf("payload.LatestShipDate");
    String EarliestDeliveryDate = json.stringOf("payload.EarliestDeliveryDate");
    String LatestDeliveryDate = json.stringOf("payload.LatestDeliveryDate");
    boolean IsBusinessOrder = json.BoolOf("payload.IsBusinessOrder");
    boolean IsPrime = json.BoolOf("payload.IsPrime");
    boolean IsGlobalExpressEnabled = json.BoolOf("payload.IsGlobalExpressEnabled");
    boolean IsPremiumOrder = json.BoolOf("payload.IsPremiumOrder");
    boolean IsSoldByAB = json.BoolOf("payload.IsSoldByAB");
    boolean IsIBA = json.BoolOf("payload.IsIBA");
    String Name = json.stringOf("payload.DefaultShipFromLocationAddress.Name");
    String AddressLine1 = json.stringOf("payload.DefaultShipFromLocationAddress.AddressLine1");
    String City = json.stringOf("payload.DefaultShipFromLocationAddress.City");
    String StateOrRegion = json.stringOf("payload.DefaultShipFromLocationAddress.StateOrRegion");
    String PostalCode = json.stringOf("payload.DefaultShipFromLocationAddress.PostalCode");
    String CountryCode = json.stringOf("payload.DefaultShipFromLocationAddress.CountryCode");
    String Phone = json.stringOf("payload.DefaultShipFromLocationAddress.Phone");
    String AddressType = json.stringOf("payload.DefaultShipFromLocationAddress.AddressType");
    String FulfillmentSupplySourceId = json.stringOf("payload.FulfillmentInstruction.FulfillmentSupplySourceId");
    boolean IsISPU = json.BoolOf("payload.IsISPU");
    boolean IsAccessPointOrder = json.BoolOf("payload.IsAccessPointOrder");
    boolean HasAutomatedShippingSettings = json.BoolOf("payload.AutomatedShippingSettings.HasAutomatedShippingSettings");
    String EasyShipShipmentStatus = json.stringOf("payload.EasyShipShipmentStatus");
    String ElectronicInvoiceStatus = json.stringOf("payload.ElectronicInvoiceStatus");
    int i = 0;
    int count_i = json.SizeOfArray("payload.PaymentMethodDetails");
    while (i < count_i) {
        json.put_I(i);
        strVal = json.stringOf("payload.PaymentMethodDetails[i]");
        i = i + 1;
        }

    Log.i(TAG, "Success!");

  }

  static {
      System.loadLibrary("chilkat");

      // Note: If the incorrect library name is passed to System.loadLibrary,
      // then you will see the following error message at application startup:
      //"The application <your-application-name> has stopped unexpectedly. Please try again."
  }
}