Chilkat Online Tools

PowerBuilder / ShipEngine Walkthrough / List your labels

Back to Collection Items

integer li_rc
oleobject loo_Http
integer li_Success
oleobject loo_QueryParams
oleobject loo_Resp
oleobject loo_SbResponseBody
oleobject loo_JResp
integer li_RespStatusCode
string ls_Label_id
string ls_Status
string ls_Shipment_id
string ls_Ship_date
string ls_Created_at
string ls_V_Currency
string ls_Amount
string ls_Insurance_costCurrency
integer li_Insurance_costAmount
string ls_Tracking_number
integer li_Is_return_label
string ls_Rma_number
integer li_Is_international
string ls_Batch_id
string ls_Carrier_id
string ls_Service_code
string ls_Package_code
integer li_Voided
string ls_Voided_at
string ls_Label_format
string ls_Label_layout
integer li_Trackable
string ls_Carrier_code
string ls_Tracking_status
string ls_V_Pdf
string ls_Png
string ls_Zpl
string ls_Label_downloadHref
string ls_Form_download
string ls_Insurance_claim
integer j
integer li_Count_j
integer li_Value
string ls_Unit
string ls_DimensionsUnit
integer li_Length
integer li_Width
integer li_Height
string ls_Insured_valueCurrency
integer li_Insured_valueAmount
string ls_Reference1
string ls_Reference2
string ls_Reference3
string ls_External_package_id
integer li_Total
integer li_Page
integer li_Pages
string ls_Href
string ls_LastHref
integer i
integer li_Count_i

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

loo_Http = create oleobject
// Use "Chilkat_9_5_0.Http" for versions of Chilkat < 10.0.0
li_rc = loo_Http.ConnectToNewObject("Chilkat.Http")
if li_rc < 0 then
    destroy loo_Http
    MessageBox("Error","Connecting to COM object failed")
    return
end if

loo_QueryParams = create oleobject
// Use "Chilkat_9_5_0.JsonObject" for versions of Chilkat < 10.0.0
li_rc = loo_QueryParams.ConnectToNewObject("Chilkat.JsonObject")

loo_QueryParams.UpdateInt("page",1)
loo_QueryParams.UpdateInt("page_size",10)
loo_QueryParams.UpdateString("sort_by","created_at")
loo_QueryParams.UpdateString("sort_dir","desc")

loo_Http.SetRequestHeader("API-Key","{{API_KEY}}")

loo_Resp = loo_Http.QuickRequestParams("GET","https://api.shipengine.com/v1/labels",loo_QueryParams)
if loo_Http.LastMethodSuccess = 0 then
    Write-Debug loo_Http.LastErrorText
    destroy loo_Http
    destroy loo_QueryParams
    return
end if

loo_SbResponseBody = create oleobject
// Use "Chilkat_9_5_0.StringBuilder" for versions of Chilkat < 10.0.0
li_rc = loo_SbResponseBody.ConnectToNewObject("Chilkat.StringBuilder")

loo_Resp.GetBodySb(loo_SbResponseBody)

loo_JResp = create oleobject
// Use "Chilkat_9_5_0.JsonObject" for versions of Chilkat < 10.0.0
li_rc = loo_JResp.ConnectToNewObject("Chilkat.JsonObject")

loo_JResp.LoadSb(loo_SbResponseBody)
loo_JResp.EmitCompact = 0

Write-Debug "Response Body:"
Write-Debug loo_JResp.Emit()

li_RespStatusCode = loo_Resp.StatusCode
Write-Debug "Response Status Code = " + string(li_RespStatusCode)
if li_RespStatusCode >= 400 then
    Write-Debug "Response Header:"
    Write-Debug loo_Resp.Header
    Write-Debug "Failed."
    destroy loo_Resp
    destroy loo_Http
    destroy loo_QueryParams
    destroy loo_SbResponseBody
    destroy loo_JResp
    return
end if

destroy loo_Resp

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

// {
//   "labels": [
//     {
//       "label_id": "se-1376213",
//       "status": "voided",
//       "shipment_id": "se-4140409",
//       "ship_date": "2019-09-17T00:00:00Z",
//       "created_at": "2019-09-17T21:24:38.293Z",
//       "shipment_cost": {
//         "currency": "usd",
//         "amount": 98.14
//       },
//       "insurance_cost": {
//         "currency": "usd",
//         "amount": 0
//       },
//       "tracking_number": "9405511899564298842779",
//       "is_return_label": false,
//       "rma_number": null,
//       "is_international": false,
//       "batch_id": "",
//       "carrier_id": "se-121861",
//       "service_code": "usps_priority_mail",
//       "package_code": "package",
//       "voided": true,
//       "voided_at": "2019-09-17T21:28:48.89Z",
//       "label_format": "pdf",
//       "label_layout": "4x6",
//       "trackable": false,
//       "carrier_code": "stamps_com",
//       "tracking_status": "in_transit",
//       "label_download": {
//         "pdf": "https://api.shipengine.com/v1/downloads/10/y7wnsDz5f02H4IlaqNO0aw/label-1376213.pdf",
//         "png": "https://api.shipengine.com/v1/downloads/10/y7wnsDz5f02H4IlaqNO0aw/label-1376213.png",
//         "zpl": "https://api.shipengine.com/v1/downloads/10/y7wnsDz5f02H4IlaqNO0aw/label-1376213.zpl",
//         "href": "https://api.shipengine.com/v1/downloads/10/y7wnsDz5f02H4IlaqNO0aw/label-1376213.pdf"
//       },
//       "form_download": null,
//       "insurance_claim": null,
//       "packages": [
//         {
//           "package_code": "package",
//           "weight": {
//             "value": 17,
//             "unit": "pound"
//           },
//           "dimensions": {
//             "unit": "inch",
//             "length": 36,
//             "width": 12,
//             "height": 24
//           },
//           "insured_value": {
//             "currency": "usd",
//             "amount": 0
//           },
//           "tracking_number": "9405511899564298842779",
//           "label_messages": {
//             "reference1": null,
//             "reference2": null,
//             "reference3": null
//           },
//           "external_package_id": null
//         }
//       ]
//     }
//   ],
//   "total": 1,
//   "page": 1,
//   "pages": 1,
//   "links": {
//     "first": {
//       "href": "https://api.shipengine.com/v1/labels?label_status=voided&carrier_id=se-121861&service_code=usps_priority_mail&tracking_number=9405511899564298842779&sort_by=created_at&sort_dir=desc&page=1&page_size=10"
//     },
//     "last": {
//       "href": "https://api.shipengine.com/v1/labels?label_status=voided&carrier_id=se-121861&service_code=usps_priority_mail&tracking_number=9405511899564298842779&sort_by=created_at&sort_dir=desc&page=1&page_size=10"
//     },
//     "prev": {},
//     "next": {}
//   }
// }

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

li_Total = loo_JResp.IntOf("total")
li_Page = loo_JResp.IntOf("page")
li_Pages = loo_JResp.IntOf("pages")
ls_Href = loo_JResp.StringOf("links.first.href")
ls_LastHref = loo_JResp.StringOf("links.last.href")
i = 0
li_Count_i = loo_JResp.SizeOfArray("labels")
do while i < li_Count_i
    loo_JResp.I = i
    ls_Label_id = loo_JResp.StringOf("labels[i].label_id")
    ls_Status = loo_JResp.StringOf("labels[i].status")
    ls_Shipment_id = loo_JResp.StringOf("labels[i].shipment_id")
    ls_Ship_date = loo_JResp.StringOf("labels[i].ship_date")
    ls_Created_at = loo_JResp.StringOf("labels[i].created_at")
    ls_V_Currency = loo_JResp.StringOf("labels[i].shipment_cost.currency")
    ls_Amount = loo_JResp.StringOf("labels[i].shipment_cost.amount")
    ls_Insurance_costCurrency = loo_JResp.StringOf("labels[i].insurance_cost.currency")
    li_Insurance_costAmount = loo_JResp.IntOf("labels[i].insurance_cost.amount")
    ls_Tracking_number = loo_JResp.StringOf("labels[i].tracking_number")
    li_Is_return_label = loo_JResp.BoolOf("labels[i].is_return_label")
    ls_Rma_number = loo_JResp.StringOf("labels[i].rma_number")
    li_Is_international = loo_JResp.BoolOf("labels[i].is_international")
    ls_Batch_id = loo_JResp.StringOf("labels[i].batch_id")
    ls_Carrier_id = loo_JResp.StringOf("labels[i].carrier_id")
    ls_Service_code = loo_JResp.StringOf("labels[i].service_code")
    ls_Package_code = loo_JResp.StringOf("labels[i].package_code")
    li_Voided = loo_JResp.BoolOf("labels[i].voided")
    ls_Voided_at = loo_JResp.StringOf("labels[i].voided_at")
    ls_Label_format = loo_JResp.StringOf("labels[i].label_format")
    ls_Label_layout = loo_JResp.StringOf("labels[i].label_layout")
    li_Trackable = loo_JResp.BoolOf("labels[i].trackable")
    ls_Carrier_code = loo_JResp.StringOf("labels[i].carrier_code")
    ls_Tracking_status = loo_JResp.StringOf("labels[i].tracking_status")
    ls_V_Pdf = loo_JResp.StringOf("labels[i].label_download.pdf")
    ls_Png = loo_JResp.StringOf("labels[i].label_download.png")
    ls_Zpl = loo_JResp.StringOf("labels[i].label_download.zpl")
    ls_Label_downloadHref = loo_JResp.StringOf("labels[i].label_download.href")
    ls_Form_download = loo_JResp.StringOf("labels[i].form_download")
    ls_Insurance_claim = loo_JResp.StringOf("labels[i].insurance_claim")
    j = 0
    li_Count_j = loo_JResp.SizeOfArray("labels[i].packages")
    do while j < li_Count_j
        loo_JResp.J = j
        ls_Package_code = loo_JResp.StringOf("labels[i].packages[j].package_code")
        li_Value = loo_JResp.IntOf("labels[i].packages[j].weight.value")
        ls_Unit = loo_JResp.StringOf("labels[i].packages[j].weight.unit")
        ls_DimensionsUnit = loo_JResp.StringOf("labels[i].packages[j].dimensions.unit")
        li_Length = loo_JResp.IntOf("labels[i].packages[j].dimensions.length")
        li_Width = loo_JResp.IntOf("labels[i].packages[j].dimensions.width")
        li_Height = loo_JResp.IntOf("labels[i].packages[j].dimensions.height")
        ls_Insured_valueCurrency = loo_JResp.StringOf("labels[i].packages[j].insured_value.currency")
        li_Insured_valueAmount = loo_JResp.IntOf("labels[i].packages[j].insured_value.amount")
        ls_Tracking_number = loo_JResp.StringOf("labels[i].packages[j].tracking_number")
        ls_Reference1 = loo_JResp.StringOf("labels[i].packages[j].label_messages.reference1")
        ls_Reference2 = loo_JResp.StringOf("labels[i].packages[j].label_messages.reference2")
        ls_Reference3 = loo_JResp.StringOf("labels[i].packages[j].label_messages.reference3")
        ls_External_package_id = loo_JResp.StringOf("labels[i].packages[j].external_package_id")
        j = j + 1
    loop
    i = i + 1
loop


destroy loo_Http
destroy loo_QueryParams
destroy loo_SbResponseBody
destroy loo_JResp

Curl Command

curl -G -d "page=1"
	-d "page_size=10"
	-d "sort_by=created_at"
	-d "sort_dir=desc"
	-H "API-Key: {{API_KEY}}"
https://api.shipengine.com/v1/labels

Postman Collection Item JSON

{
  "name": "List your labels",
  "event": [
    {
      "listen": "test",
      "script": {
        "exec": [
          "let response = pm.response.json();",
          "",
          "if (response.labels.length > 0) {",
          "    const template = `",
          "        <link rel=\"stylesheet\" href=\"https://cdnjs.cloudflare.com/ajax/libs/meyer-reset/2.0/reset.min.css\">",
          "        <link rel=\"stylesheet\" href=\"https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css\">",
          "        ",
          "        <h1>Labels</h1>",
          "        <p class=\"lead\">",
          "            <span class=\"badge badge-success\">{{total}} labels</span> matched your search criteria <small>({{pages}} pages of results)</small>",
          "        </p>",
          "        ",
          "        <table class=\"table table-hover\">",
          "            <thead class=\"thead-dark\">",
          "                <tr>",
          "                    <th>Label ID</th>",
          "                    <th>Carrier</th>",
          "                    <th>Service</th>",
          "                    <th>Cost</th>",
          "                    <th>Status</th>",
          "                    <th>Tracking Number</th>",
          "                </tr>",
          "            </thead>",
          "            <tbody>",
          "                {{#each labels}}",
          "                    <tr>",
          "                        <td>{{label_id}}</td>",
          "                        <td>",
          "                            <img alt=\"{{carrier_id}}\" style=\"height: 30px\"",
          "                            src=\"https://www.shipengine.com/docs/img/logos/carriers/{{carrier_code}}.svg\">",
          "                        </td>",
          "                        <td>",
          "                            <samp>{{service_code}}</samp>",
          "                        </td>",
          "                        <td>{{shipment_cost.amount}} {{shipment_cost.currency}}</td>",
          "                        <td>{{status}}</td>",
          "                        <td>{{tracking_number}}</td>",
          "                    </tr>",
          "                {{/each}}",
          "            </tbody>",
          "        </table>",
          "    `;",
          "    ",
          "    pm.visualizer.set(template, response);",
          "}"
        ],
        "type": "text/javascript"
      }
    }
  ],
  "request": {
    "method": "GET",
    "header": [
    ],
    "url": {
      "raw": "https://api.shipengine.com/v1/labels?page=1&page_size=10&sort_by=created_at&sort_dir=desc",
      "protocol": "https",
      "host": [
        "api",
        "shipengine",
        "com"
      ],
      "path": [
        "v1",
        "labels"
      ],
      "query": [
        {
          "key": "label_status",
          "value": "voided",
          "disabled": true
        },
        {
          "key": "carrier_id",
          "value": "{{stamps_com}}",
          "disabled": true
        },
        {
          "key": "service_code",
          "value": "usps_priority_mail",
          "disabled": true
        },
        {
          "key": "tracking_number",
          "value": "{{tracking_number}}",
          "disabled": true
        },
        {
          "key": "page",
          "value": "1"
        },
        {
          "key": "page_size",
          "value": "10"
        },
        {
          "key": "sort_by",
          "value": "created_at"
        },
        {
          "key": "sort_dir",
          "value": "desc"
        }
      ]
    },
    "description": "This request shows how to list labels that match certain criteria, such as the carrier, service, date, warehouse, status, etc."
  },
  "response": [
    {
      "name": "List your labels",
      "originalRequest": {
        "method": "GET",
        "header": [
        ],
        "url": {
          "raw": "https://api.shipengine.com/v1/labels?label_status=voided&carrier_id={{stamps_com}}&service_code=usps_priority_mail&tracking_number={{tracking_number}}&page=1&page_size=10&sort_by=created_at&sort_dir=desc",
          "protocol": "https",
          "host": [
            "api",
            "shipengine",
            "com"
          ],
          "path": [
            "v1",
            "labels"
          ],
          "query": [
            {
              "key": "label_status",
              "value": "voided"
            },
            {
              "key": "carrier_id",
              "value": "{{stamps_com}}"
            },
            {
              "key": "service_code",
              "value": "usps_priority_mail"
            },
            {
              "key": "tracking_number",
              "value": "{{tracking_number}}"
            },
            {
              "key": "page",
              "value": "1"
            },
            {
              "key": "page_size",
              "value": "10"
            },
            {
              "key": "sort_by",
              "value": "created_at"
            },
            {
              "key": "sort_dir",
              "value": "desc"
            }
          ]
        }
      },
      "status": "OK",
      "code": 200,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "Date",
          "value": "Tue, 17 Sep 2019 21:33:29 GMT"
        },
        {
          "key": "Content-Type",
          "value": "application/json; charset=utf-8"
        },
        {
          "key": "Content-Length",
          "value": "2699"
        },
        {
          "key": "Connection",
          "value": "keep-alive"
        },
        {
          "key": "Access-Control-Allow-Origin",
          "value": "https://www.shipengine.com"
        },
        {
          "key": "Vary",
          "value": "Origin"
        },
        {
          "key": "x-shipengine-requestid",
          "value": "b3354fc0-d6c2-4711-861f-03730ee4ad2e"
        }
      ],
      "cookie": [
      ],
      "body": "{\n    \"labels\": [\n        {\n            \"label_id\": \"se-1376213\",\n            \"status\": \"voided\",\n            \"shipment_id\": \"se-4140409\",\n            \"ship_date\": \"2019-09-17T00:00:00Z\",\n            \"created_at\": \"2019-09-17T21:24:38.293Z\",\n            \"shipment_cost\": {\n                \"currency\": \"usd\",\n                \"amount\": 98.14\n            },\n            \"insurance_cost\": {\n                \"currency\": \"usd\",\n                \"amount\": 0\n            },\n            \"tracking_number\": \"9405511899564298842779\",\n            \"is_return_label\": false,\n            \"rma_number\": null,\n            \"is_international\": false,\n            \"batch_id\": \"\",\n            \"carrier_id\": \"se-121861\",\n            \"service_code\": \"usps_priority_mail\",\n            \"package_code\": \"package\",\n            \"voided\": true,\n            \"voided_at\": \"2019-09-17T21:28:48.89Z\",\n            \"label_format\": \"pdf\",\n            \"label_layout\": \"4x6\",\n            \"trackable\": false,\n            \"carrier_code\": \"stamps_com\",\n            \"tracking_status\": \"in_transit\",\n            \"label_download\": {\n                \"pdf\": \"https://api.shipengine.com/v1/downloads/10/y7wnsDz5f02H4IlaqNO0aw/label-1376213.pdf\",\n                \"png\": \"https://api.shipengine.com/v1/downloads/10/y7wnsDz5f02H4IlaqNO0aw/label-1376213.png\",\n                \"zpl\": \"https://api.shipengine.com/v1/downloads/10/y7wnsDz5f02H4IlaqNO0aw/label-1376213.zpl\",\n                \"href\": \"https://api.shipengine.com/v1/downloads/10/y7wnsDz5f02H4IlaqNO0aw/label-1376213.pdf\"\n            },\n            \"form_download\": null,\n            \"insurance_claim\": null,\n            \"packages\": [\n                {\n                    \"package_code\": \"package\",\n                    \"weight\": {\n                        \"value\": 17,\n                        \"unit\": \"pound\"\n                    },\n                    \"dimensions\": {\n                        \"unit\": \"inch\",\n                        \"length\": 36,\n                        \"width\": 12,\n                        \"height\": 24\n                    },\n                    \"insured_value\": {\n                        \"currency\": \"usd\",\n                        \"amount\": 0\n                    },\n                    \"tracking_number\": \"9405511899564298842779\",\n                    \"label_messages\": {\n                        \"reference1\": null,\n                        \"reference2\": null,\n                        \"reference3\": null\n                    },\n                    \"external_package_id\": null\n                }\n            ]\n        }\n    ],\n    \"total\": 1,\n    \"page\": 1,\n    \"pages\": 1,\n    \"links\": {\n        \"first\": {\n            \"href\": \"https://api.shipengine.com/v1/labels?label_status=voided&carrier_id=se-121861&service_code=usps_priority_mail&tracking_number=9405511899564298842779&sort_by=created_at&sort_dir=desc&page=1&page_size=10\"\n        },\n        \"last\": {\n            \"href\": \"https://api.shipengine.com/v1/labels?label_status=voided&carrier_id=se-121861&service_code=usps_priority_mail&tracking_number=9405511899564298842779&sort_by=created_at&sort_dir=desc&page=1&page_size=10\"\n        },\n        \"prev\": {},\n        \"next\": {}\n    }\n}"
    }
  ]
}