Chilkat Online Tools

Foxpro / Selling Partner API for Easy Ship / get Scheduled Package

Back to Collection Items

LOCAL loHttp
LOCAL lnSuccess
LOCAL loQueryParams
LOCAL loResp
LOCAL loSbResponseBody
LOCAL loJResp
LOCAL lnRespStatusCode
LOCAL lcOrderItemId
LOCAL j
LOCAL lnCount_j
LOCAL lcStrVal
LOCAL lcLength
LOCAL lcWidth
LOCAL lcHeight
LOCAL lcUnit
LOCAL lcIdentifier
LOCAL lcSlotId
LOCAL lcStartTime
LOCAL lcEndTime
LOCAL lcHandoverMethod
LOCAL lcValue
LOCAL lcPackageWeightUnit
LOCAL lcAmazonOrderId
LOCAL lcPackageId
LOCAL lcPackageIdentifier
LOCAL lcInvoiceNumber
LOCAL lcInvoiceDate
LOCAL lcPackageStatus
LOCAL lcTrackingId
LOCAL i
LOCAL lnCount_i

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

* For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Http')
loHttp = CreateObject('Chilkat.Http')

* For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.JsonObject')
loQueryParams = CreateObject('Chilkat.JsonObject')
loQueryParams.UpdateString("amazonOrderId","nisi non tempor minim")
loQueryParams.UpdateString("marketplaceId","nisi non tempor minim")

loHttp.SetRequestHeader("Accept","application/json")

loResp = loHttp.QuickRequestParams("GET","https://sellingpartnerapi-na.amazon.com/easyShip/2022-03-23/package",loQueryParams)
IF (loHttp.LastMethodSuccess = 0) THEN
    ? loHttp.LastErrorText
    RELEASE loHttp
    RELEASE loQueryParams
    CANCEL
ENDIF

* For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.StringBuilder')
loSbResponseBody = CreateObject('Chilkat.StringBuilder')
loResp.GetBodySb(loSbResponseBody)

* For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.JsonObject')
loJResp = CreateObject('Chilkat.JsonObject')
loJResp.LoadSb(loSbResponseBody)
loJResp.EmitCompact = 0

? "Response Body:"
? loJResp.Emit()

lnRespStatusCode = loResp.StatusCode
? "Response Status Code = " + STR(lnRespStatusCode)
IF (lnRespStatusCode >= 400) THEN
    ? "Response Header:"
    ? loResp.Header
    ? "Failed."
    RELEASE loResp
    RELEASE loHttp
    RELEASE loQueryParams
    RELEASE loSbResponseBody
    RELEASE loJResp
    CANCEL
ENDIF

RELEASE loResp

* Sample JSON response:
* (Sample code for parsing the JSON response is shown below)

* {
*   "packageDimensions": {
*     "length": 92908506.38751999,
*     "width": 69740717.24177761,
*     "height": 55703784.11292852,
*     "unit": "Cm",
*     "identifier": "velit elit incididunt"
*   },
*   "packageTimeSlot": {
*     "slotId": "id sit ut elit",
*     "startTime": "2015-08-10T18:15:47.176Z",
*     "endTime": "1974-01-15T04:04:16.651Z",
*     "handoverMethod": "Dropoff"
*   },
*   "packageWeight": {
*     "value": 22615253.265217148,
*     "unit": "Grams"
*   },
*   "scheduledPackageId": {
*     "amazonOrderId": "eu ex pariatur mollit",
*     "packageId": "la"
*   },
*   "packageItems": [
*     {
*       "orderItemId": "irure in",
*       "orderItemSerialNumbers": [
*         "est qui magna dolor in",
*         "do sint consequat"
*       ]
*     },
*     {
*       "orderItemId": "incididunt proident",
*       "orderItemSerialNumbers": [
*         "amet",
*         "ex"
*       ]
*     }
*   ],
*   "packageIdentifier": "Lorem",
*   "invoice": {
*     "invoiceNumber": "esse non",
*     "invoiceDate": "2020-10-09T01:25:28.191Z"
*   },
*   "packageStatus": "AtDestinationFC",
*   "trackingDetails": {
*     "trackingId": "dolor est aute"
*   }
* }

* Sample code for parsing the JSON response...
* Use this online tool to generate parsing code from sample JSON: Generate JSON Parsing Code

lcLength = loJResp.StringOf("packageDimensions.length")
lcWidth = loJResp.StringOf("packageDimensions.width")
lcHeight = loJResp.StringOf("packageDimensions.height")
lcUnit = loJResp.StringOf("packageDimensions.unit")
lcIdentifier = loJResp.StringOf("packageDimensions.identifier")
lcSlotId = loJResp.StringOf("packageTimeSlot.slotId")
lcStartTime = loJResp.StringOf("packageTimeSlot.startTime")
lcEndTime = loJResp.StringOf("packageTimeSlot.endTime")
lcHandoverMethod = loJResp.StringOf("packageTimeSlot.handoverMethod")
lcValue = loJResp.StringOf("packageWeight.value")
lcPackageWeightUnit = loJResp.StringOf("packageWeight.unit")
lcAmazonOrderId = loJResp.StringOf("scheduledPackageId.amazonOrderId")
lcPackageId = loJResp.StringOf("scheduledPackageId.packageId")
lcPackageIdentifier = loJResp.StringOf("packageIdentifier")
lcInvoiceNumber = loJResp.StringOf("invoice.invoiceNumber")
lcInvoiceDate = loJResp.StringOf("invoice.invoiceDate")
lcPackageStatus = loJResp.StringOf("packageStatus")
lcTrackingId = loJResp.StringOf("trackingDetails.trackingId")
i = 0
lnCount_i = loJResp.SizeOfArray("packageItems")
DO WHILE i < lnCount_i
    loJResp.I = i
    lcOrderItemId = loJResp.StringOf("packageItems[i].orderItemId")
    j = 0
    lnCount_j = loJResp.SizeOfArray("packageItems[i].orderItemSerialNumbers")
    DO WHILE j < lnCount_j
        loJResp.J = j
        lcStrVal = loJResp.StringOf("packageItems[i].orderItemSerialNumbers[j]")
        j = j + 1
    ENDDO
    i = i + 1
ENDDO

RELEASE loHttp
RELEASE loQueryParams
RELEASE loSbResponseBody
RELEASE loJResp

Curl Command

curl -G -d "amazonOrderId=nisi%20non%20tempor%20minim"
	-d "marketplaceId=nisi%20non%20tempor%20minim"
	-H "Accept: application/json"
https://sellingpartnerapi-na.amazon.com/easyShip/2022-03-23/package

Postman Collection Item JSON

{
  "name": "get Scheduled Package",
  "request": {
    "method": "GET",
    "header": [
      {
        "key": "Accept",
        "value": "application/json"
      }
    ],
    "url": {
      "raw": "{{baseUrl}}/easyShip/2022-03-23/package?amazonOrderId=nisi non tempor minim&marketplaceId=nisi non tempor minim",
      "host": [
        "{{baseUrl}}"
      ],
      "path": [
        "easyShip",
        "2022-03-23",
        "package"
      ],
      "query": [
        {
          "key": "amazonOrderId",
          "value": "nisi non tempor minim",
          "description": "(Required) An Amazon-defined order identifier. Identifies the order that the seller wants to deliver using Amazon Easy Ship."
        },
        {
          "key": "marketplaceId",
          "value": "nisi non tempor minim",
          "description": "(Required) An identifier for the marketplace in which the seller is selling."
        }
      ]
    },
    "description": "Returns information about a package, including dimensions, weight, time slot information for handover, invoice and item information, and status.\n\n**Usage Plan:**\n\n| Rate (requests per second) | Burst |\n| ---- | ---- |\n| 1 | 5 |\n\nThe `x-amzn-RateLimit-Limit` response header returns the usage plan rate limits that were applied to the requested operation, when available. The table above indicates the default rate and burst values for this operation. Selling partners whose business demands require higher throughput may see higher rate and burst values than those shown here. For more information, see [Usage Plans and Rate Limits in the Selling Partner API](doc:usage-plans-and-rate-limits-in-the-sp-api)."
  },
  "response": [
    {
      "name": "Success.",
      "originalRequest": {
        "method": "GET",
        "header": [
        ],
        "url": {
          "raw": "{{baseUrl}}/easyShip/2022-03-23/package?amazonOrderId=nisi non tempor minim&marketplaceId=nisi non tempor minim",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "easyShip",
            "2022-03-23",
            "package"
          ],
          "query": [
            {
              "key": "amazonOrderId",
              "value": "nisi non tempor minim"
            },
            {
              "key": "marketplaceId",
              "value": "nisi non tempor minim"
            }
          ]
        }
      },
      "status": "OK",
      "code": 200,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "x-amzn-RateLimit-Limit",
          "value": "do anim",
          "description": "Your rate limit (requests per second) for this operation."
        },
        {
          "key": "x-amzn-RequestId",
          "value": "do anim",
          "description": "Unique request reference identifier."
        },
        {
          "key": "Content-Type",
          "value": "application/json"
        }
      ],
      "cookie": [
      ],
      "body": "{\n  \"packageDimensions\": {\n    \"length\": 92908506.38751999,\n    \"width\": 69740717.24177761,\n    \"height\": 55703784.11292852,\n    \"unit\": \"Cm\",\n    \"identifier\": \"velit elit incididunt\"\n  },\n  \"packageTimeSlot\": {\n    \"slotId\": \"id sit ut elit\",\n    \"startTime\": \"2015-08-10T18:15:47.176Z\",\n    \"endTime\": \"1974-01-15T04:04:16.651Z\",\n    \"handoverMethod\": \"Dropoff\"\n  },\n  \"packageWeight\": {\n    \"value\": 22615253.265217148,\n    \"unit\": \"Grams\"\n  },\n  \"scheduledPackageId\": {\n    \"amazonOrderId\": \"eu ex pariatur mollit\",\n    \"packageId\": \"la\"\n  },\n  \"packageItems\": [\n    {\n      \"orderItemId\": \"irure in\",\n      \"orderItemSerialNumbers\": [\n        \"est qui magna dolor in\",\n        \"do sint consequat\"\n      ]\n    },\n    {\n      \"orderItemId\": \"incididunt proident\",\n      \"orderItemSerialNumbers\": [\n        \"amet\",\n        \"ex\"\n      ]\n    }\n  ],\n  \"packageIdentifier\": \"Lorem\",\n  \"invoice\": {\n    \"invoiceNumber\": \"esse non\",\n    \"invoiceDate\": \"2020-10-09T01:25:28.191Z\"\n  },\n  \"packageStatus\": \"AtDestinationFC\",\n  \"trackingDetails\": {\n    \"trackingId\": \"dolor est aute\"\n  }\n}"
    },
    {
      "name": "Request has missing or invalid parameters and cannot be parsed.",
      "originalRequest": {
        "method": "GET",
        "header": [
        ],
        "url": {
          "raw": "{{baseUrl}}/easyShip/2022-03-23/package?amazonOrderId=nisi non tempor minim&marketplaceId=nisi non tempor minim",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "easyShip",
            "2022-03-23",
            "package"
          ],
          "query": [
            {
              "key": "amazonOrderId",
              "value": "nisi non tempor minim"
            },
            {
              "key": "marketplaceId",
              "value": "nisi non tempor minim"
            }
          ]
        }
      },
      "status": "Bad Request",
      "code": 400,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "x-amzn-RateLimit-Limit",
          "value": "do anim",
          "description": "Your rate limit (requests per second) for this operation."
        },
        {
          "key": "x-amzn-RequestId",
          "value": "do anim",
          "description": "Unique request reference identifier."
        },
        {
          "key": "Content-Type",
          "value": "application/json"
        }
      ],
      "cookie": [
      ],
      "body": "{\n  \"errors\": [\n    {\n      \"code\": \"minim nisi sint\",\n      \"message\": \"irure sed dolor\",\n      \"details\": \"officia consectetur Excepteur\"\n    },\n    {\n      \"code\": \"Ut do\",\n      \"message\": \"non nisi ipsum\",\n      \"details\": \"Ut\"\n    }\n  ]\n}"
    },
    {
      "name": "The request's Authorization header is not formatted correctly or does not contain a valid token.",
      "originalRequest": {
        "method": "GET",
        "header": [
        ],
        "url": {
          "raw": "{{baseUrl}}/easyShip/2022-03-23/package?amazonOrderId=nisi non tempor minim&marketplaceId=nisi non tempor minim",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "easyShip",
            "2022-03-23",
            "package"
          ],
          "query": [
            {
              "key": "amazonOrderId",
              "value": "nisi non tempor minim"
            },
            {
              "key": "marketplaceId",
              "value": "nisi non tempor minim"
            }
          ]
        }
      },
      "status": "Unauthorized",
      "code": 401,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "x-amzn-RateLimit-Limit",
          "value": "do anim",
          "description": "Your rate limit (requests per second) for this operation."
        },
        {
          "key": "x-amzn-RequestId",
          "value": "do anim",
          "description": "Unique request reference identifier."
        },
        {
          "key": "Content-Type",
          "value": "application/json"
        }
      ],
      "cookie": [
      ],
      "body": "{\n  \"errors\": [\n    {\n      \"code\": \"minim nisi sint\",\n      \"message\": \"irure sed dolor\",\n      \"details\": \"officia consectetur Excepteur\"\n    },\n    {\n      \"code\": \"Ut do\",\n      \"message\": \"non nisi ipsum\",\n      \"details\": \"Ut\"\n    }\n  ]\n}"
    },
    {
      "name": "Indicates access to the resource is forbidden. Possible reasons include Access Denied, Unauthorized, Expired Token, or Invalid Signature.",
      "originalRequest": {
        "method": "GET",
        "header": [
        ],
        "url": {
          "raw": "{{baseUrl}}/easyShip/2022-03-23/package?amazonOrderId=nisi non tempor minim&marketplaceId=nisi non tempor minim",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "easyShip",
            "2022-03-23",
            "package"
          ],
          "query": [
            {
              "key": "amazonOrderId",
              "value": "nisi non tempor minim"
            },
            {
              "key": "marketplaceId",
              "value": "nisi non tempor minim"
            }
          ]
        }
      },
      "status": "Forbidden",
      "code": 403,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "x-amzn-RequestId",
          "value": "do anim",
          "description": "Unique request reference identifier."
        },
        {
          "key": "Content-Type",
          "value": "application/json"
        }
      ],
      "cookie": [
      ],
      "body": "{\n  \"errors\": [\n    {\n      \"code\": \"minim nisi sint\",\n      \"message\": \"irure sed dolor\",\n      \"details\": \"officia consectetur Excepteur\"\n    },\n    {\n      \"code\": \"Ut do\",\n      \"message\": \"non nisi ipsum\",\n      \"details\": \"Ut\"\n    }\n  ]\n}"
    },
    {
      "name": "The specified resource does not exist.",
      "originalRequest": {
        "method": "GET",
        "header": [
        ],
        "url": {
          "raw": "{{baseUrl}}/easyShip/2022-03-23/package?amazonOrderId=nisi non tempor minim&marketplaceId=nisi non tempor minim",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "easyShip",
            "2022-03-23",
            "package"
          ],
          "query": [
            {
              "key": "amazonOrderId",
              "value": "nisi non tempor minim"
            },
            {
              "key": "marketplaceId",
              "value": "nisi non tempor minim"
            }
          ]
        }
      },
      "status": "Not Found",
      "code": 404,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "x-amzn-RateLimit-Limit",
          "value": "do anim",
          "description": "Your rate limit (requests per second) for this operation."
        },
        {
          "key": "x-amzn-RequestId",
          "value": "do anim",
          "description": "Unique request reference identifier."
        },
        {
          "key": "Content-Type",
          "value": "application/json"
        }
      ],
      "cookie": [
      ],
      "body": "{\n  \"errors\": [\n    {\n      \"code\": \"minim nisi sint\",\n      \"message\": \"irure sed dolor\",\n      \"details\": \"officia consectetur Excepteur\"\n    },\n    {\n      \"code\": \"Ut do\",\n      \"message\": \"non nisi ipsum\",\n      \"details\": \"Ut\"\n    }\n  ]\n}"
    },
    {
      "name": "The request payload is in an unsupported format.",
      "originalRequest": {
        "method": "GET",
        "header": [
        ],
        "url": {
          "raw": "{{baseUrl}}/easyShip/2022-03-23/package?amazonOrderId=nisi non tempor minim&marketplaceId=nisi non tempor minim",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "easyShip",
            "2022-03-23",
            "package"
          ],
          "query": [
            {
              "key": "amazonOrderId",
              "value": "nisi non tempor minim"
            },
            {
              "key": "marketplaceId",
              "value": "nisi non tempor minim"
            }
          ]
        }
      },
      "status": "Unsupported Media Type",
      "code": 415,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "x-amzn-RequestId",
          "value": "do anim",
          "description": "Unique request reference identifier."
        },
        {
          "key": "Content-Type",
          "value": "application/json"
        }
      ],
      "cookie": [
      ],
      "body": "{\n  \"errors\": [\n    {\n      \"code\": \"minim nisi sint\",\n      \"message\": \"irure sed dolor\",\n      \"details\": \"officia consectetur Excepteur\"\n    },\n    {\n      \"code\": \"Ut do\",\n      \"message\": \"non nisi ipsum\",\n      \"details\": \"Ut\"\n    }\n  ]\n}"
    },
    {
      "name": "The frequency of requests was greater than allowed.",
      "originalRequest": {
        "method": "GET",
        "header": [
        ],
        "url": {
          "raw": "{{baseUrl}}/easyShip/2022-03-23/package?amazonOrderId=nisi non tempor minim&marketplaceId=nisi non tempor minim",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "easyShip",
            "2022-03-23",
            "package"
          ],
          "query": [
            {
              "key": "amazonOrderId",
              "value": "nisi non tempor minim"
            },
            {
              "key": "marketplaceId",
              "value": "nisi non tempor minim"
            }
          ]
        }
      },
      "status": "Too Many Requests",
      "code": 429,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "x-amzn-RequestId",
          "value": "do anim",
          "description": "Unique request reference identifier."
        },
        {
          "key": "Content-Type",
          "value": "application/json"
        }
      ],
      "cookie": [
      ],
      "body": "{\n  \"errors\": [\n    {\n      \"code\": \"minim nisi sint\",\n      \"message\": \"irure sed dolor\",\n      \"details\": \"officia consectetur Excepteur\"\n    },\n    {\n      \"code\": \"Ut do\",\n      \"message\": \"non nisi ipsum\",\n      \"details\": \"Ut\"\n    }\n  ]\n}"
    },
    {
      "name": "An unexpected condition occurred that prevented the server from fulfilling the request.",
      "originalRequest": {
        "method": "GET",
        "header": [
        ],
        "url": {
          "raw": "{{baseUrl}}/easyShip/2022-03-23/package?amazonOrderId=nisi non tempor minim&marketplaceId=nisi non tempor minim",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "easyShip",
            "2022-03-23",
            "package"
          ],
          "query": [
            {
              "key": "amazonOrderId",
              "value": "nisi non tempor minim"
            },
            {
              "key": "marketplaceId",
              "value": "nisi non tempor minim"
            }
          ]
        }
      },
      "status": "Internal Server Error",
      "code": 500,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "x-amzn-RequestId",
          "value": "do anim",
          "description": "Unique request reference identifier."
        },
        {
          "key": "Content-Type",
          "value": "application/json"
        }
      ],
      "cookie": [
      ],
      "body": "{\n  \"errors\": [\n    {\n      \"code\": \"minim nisi sint\",\n      \"message\": \"irure sed dolor\",\n      \"details\": \"officia consectetur Excepteur\"\n    },\n    {\n      \"code\": \"Ut do\",\n      \"message\": \"non nisi ipsum\",\n      \"details\": \"Ut\"\n    }\n  ]\n}"
    },
    {
      "name": "Temporary overloading or maintenance of the server.",
      "originalRequest": {
        "method": "GET",
        "header": [
        ],
        "url": {
          "raw": "{{baseUrl}}/easyShip/2022-03-23/package?amazonOrderId=nisi non tempor minim&marketplaceId=nisi non tempor minim",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "easyShip",
            "2022-03-23",
            "package"
          ],
          "query": [
            {
              "key": "amazonOrderId",
              "value": "nisi non tempor minim"
            },
            {
              "key": "marketplaceId",
              "value": "nisi non tempor minim"
            }
          ]
        }
      },
      "status": "Service Unavailable",
      "code": 503,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "x-amzn-RequestId",
          "value": "do anim",
          "description": "Unique request reference identifier."
        },
        {
          "key": "Content-Type",
          "value": "application/json"
        }
      ],
      "cookie": [
      ],
      "body": "{\n  \"errors\": [\n    {\n      \"code\": \"minim nisi sint\",\n      \"message\": \"irure sed dolor\",\n      \"details\": \"officia consectetur Excepteur\"\n    },\n    {\n      \"code\": \"Ut do\",\n      \"message\": \"non nisi ipsum\",\n      \"details\": \"Ut\"\n    }\n  ]\n}"
    }
  ]
}