Chilkat Online Tools

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

Back to Collection Items

func chilkatTest() {
    // This example assumes the Chilkat API to have been previously unlocked.
    // See Global Unlock Sample for sample code.

    let http = CkoHttp()
    var success: Bool

    let queryParams = CkoJsonObject()
    queryParams.UpdateString("amazonOrderId", value: "nisi non tempor minim")
    queryParams.UpdateString("marketplaceId", value: "nisi non tempor minim")

    http.SetRequestHeader("Accept", value: "application/json")

    var resp: CkoHttpResponse? = http.QuickRequestParams("GET", url: "https://sellingpartnerapi-na.amazon.com/easyShip/2022-03-23/package", json: queryParams)
    if http.LastMethodSuccess == false {
        print("\(http.LastErrorText)")
        return
    }

    let sbResponseBody = CkoStringBuilder()
    resp!.GetBodySb(sbResponseBody)

    let jResp = CkoJsonObject()
    jResp.LoadSb(sbResponseBody)
    jResp.EmitCompact = false

    print("Response Body:")
    print("\(jResp.Emit())")

    var respStatusCode: Int = resp!.StatusCode.intValue
    print("Response Status Code = \(respStatusCode)")
    if respStatusCode >= 400 {
        print("Response Header:")
        print("\(resp!.Header)")
        print("Failed.")
        resp = nil
        return
    }

    resp = nil

    // 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

    var orderItemId: String?
    var j: Int
    var count_j: Int
    var strVal: String?

    var Length: String? = jResp.StringOf("packageDimensions.length")
    var Width: String? = jResp.StringOf("packageDimensions.width")
    var Height: String? = jResp.StringOf("packageDimensions.height")
    var Unit: String? = jResp.StringOf("packageDimensions.unit")
    var Identifier: String? = jResp.StringOf("packageDimensions.identifier")
    var SlotId: String? = jResp.StringOf("packageTimeSlot.slotId")
    var StartTime: String? = jResp.StringOf("packageTimeSlot.startTime")
    var EndTime: String? = jResp.StringOf("packageTimeSlot.endTime")
    var HandoverMethod: String? = jResp.StringOf("packageTimeSlot.handoverMethod")
    var Value: String? = jResp.StringOf("packageWeight.value")
    var packageWeightUnit: String? = jResp.StringOf("packageWeight.unit")
    var AmazonOrderId: String? = jResp.StringOf("scheduledPackageId.amazonOrderId")
    var PackageId: String? = jResp.StringOf("scheduledPackageId.packageId")
    var packageIdentifier: String? = jResp.StringOf("packageIdentifier")
    var InvoiceNumber: String? = jResp.StringOf("invoice.invoiceNumber")
    var InvoiceDate: String? = jResp.StringOf("invoice.invoiceDate")
    var packageStatus: String? = jResp.StringOf("packageStatus")
    var TrackingId: String? = jResp.StringOf("trackingDetails.trackingId")
    var i: Int = 0
    var count_i: Int = jResp.SizeOfArray("packageItems").intValue
    while i < count_i {
        jResp.I = i
        orderItemId = jResp.StringOf("packageItems[i].orderItemId")
        j = 0
        count_j = jResp.SizeOfArray("packageItems[i].orderItemSerialNumbers").intValue
        while j < count_j {
            jResp.J = j
            strVal = jResp.StringOf("packageItems[i].orderItemSerialNumbers[j]")
            j = j + 1
        }

        i = i + 1
    }


}

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}"
    }
  ]
}