Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(C) Amazon Pay - Create Delivery TrackerSee more Amazon Pay ExamplesCreate a Delivery Tracker once an order has been shipped and a tracking code has been generated. Note: This example requires Chilkat v9.5.0.89 or later. Contact support@chilkatsoft.com to get a v9.5.0.89 pre-release for testing. For more information, see https://developer.amazon.com/docs/amazon-pay-api-v2/delivery-tracker.html#button_widget_other
#include <C_CkHttp.h> #include <C_CkJsonObject.h> #include <C_CkPrivateKey.h> #include <C_CkHttpResponse.h> #include <C_CkStringBuilder.h> void ChilkatSample(void) { HCkHttp http; BOOL success; HCkJsonObject json; HCkPrivateKey privKey; const char *publicKeyId; HCkHttpResponse resp; HCkStringBuilder sbResponseBody; HCkJsonObject jResp; int respStatusCode; const char *trackingNumber; const char *carrierCode; const char *amazonOrderReferenceId; int i; int count_i; // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. http = CkHttp_Create(); // Implements the following POST: // POST /:version/deliveryTrackers HTTP/1.1 // Host: pay-api.amazon.com // Accept: application/json // Authorization: AMZN-PAY-RSASSA-PSS PublicKeyId=f4fc06fc-c5a7-11e7-abc4-cec278b6b50a, SignedHeaders=content-type;x-amz-pay-date, Signature=4164128ec5d1b9da1700167ab2ccda8125f472c8bb9de447cebf5d741ee317c8 // X-Amz-Pay-Date: 20190305T024410Z // Content-type: application/json // // { // "amazonOrderReferenceId" : "P00-0000000-0000000", // "deliveryDetails" : [{ // "trackingNumber" : "1Z999AA10123456784", // "carrierCode" : "UPS" // }] // } // Use the following online tool to generate HTTP code from a CURL command // Convert a Raw HTTP Request to Source Code // Use this online tool to generate code from sample JSON: // Generate Code to Create JSON // The following JSON is sent in the request body. // { // "amazonOrderReferenceId" : "P00-0000000-0000000", // "deliveryDetails" : [{ // "trackingNumber" : "1Z999AA10123456784", // "carrierCode" : "UPS" // }] // } json = CkJsonObject_Create(); CkJsonObject_UpdateString(json,"amazonOrderReferenceId","P00-0000000-0000000"); CkJsonObject_UpdateString(json,"deliveryDetails[0].trackingNumber","1Z999AA10123456784"); CkJsonObject_UpdateString(json,"deliveryDetails[0].carrierCode","UPS"); // Load your Amazon Pay private key. // There are many other ways to load private keys into the Chilkat private key object, such as from different formats, // or from in-memory strings or bytes. privKey = CkPrivateKey_Create(); success = CkPrivateKey_LoadPemFile(privKey,"C:/someDir/myAmazonPayPrivateKey.pem"); if (success == FALSE) { printf("%s\n",CkPrivateKey_lastErrorText(privKey)); CkHttp_Dispose(http); CkJsonObject_Dispose(json); CkPrivateKey_Dispose(privKey); return; } // Provide your Amazon Pay private key and Public Key ID // Use your public key ID here. It must be the one associated with the private key. // Note: The SetAuthPrivateKey method was added in Chilkat v9.5.0.89 publicKeyId = "SANDBOX-AHEGSJCM3L2S637RBGABLAFW"; success = CkHttp_SetAuthPrivateKey(http,publicKeyId,privKey); if (success == FALSE) { printf("%s\n",CkHttp_lastErrorText(http)); CkHttp_Dispose(http); CkJsonObject_Dispose(json); CkPrivateKey_Dispose(privKey); return; } // Note: When the private key is provided as shown above, Chilkat will automatically add the required x-amz-pay-* headers to the HTTP request, // and will also sign the request. Nothing more is needed. // Chilkat automatically generates and adds the following headers: // // x-amz-pay-date // x-amz-pay-host // x-amz-pay-region // x-amz-pay-idempotency-key // Authorization CkHttp_putAccept(http,"application/json"); // To use the live system, replace "sandbox" with "live" in the URL passed to PostJson3. // Also, make sure to use the correct region: pay-api.amazon.com, pay-api.amazon.eu, or pay-api.amazon.jp resp = CkHttp_PostJson3(http,"https://pay-api.amazon.eu/sandbox/v2/deliveryTrackers","application/json",json); if (CkHttp_getLastMethodSuccess(http) == FALSE) { printf("%s\n",CkHttp_lastErrorText(http)); CkHttp_Dispose(http); CkJsonObject_Dispose(json); CkPrivateKey_Dispose(privKey); return; } sbResponseBody = CkStringBuilder_Create(); CkHttpResponse_GetBodySb(resp,sbResponseBody); jResp = CkJsonObject_Create(); CkJsonObject_LoadSb(jResp,sbResponseBody); CkJsonObject_putEmitCompact(jResp,FALSE); // If the status code is not equal to 200, this will display error information. printf("Response Body:\n"); printf("%s\n",CkJsonObject_emit(jResp)); respStatusCode = CkHttpResponse_getStatusCode(resp); printf("Response Status Code = %d\n",respStatusCode); if (respStatusCode != 200) { printf("Failed.\n"); CkHttpResponse_Dispose(resp); CkHttp_Dispose(http); CkJsonObject_Dispose(json); CkPrivateKey_Dispose(privKey); CkStringBuilder_Dispose(sbResponseBody); CkJsonObject_Dispose(jResp); return; } CkHttpResponse_Dispose(resp); // Sample JSON response: // (Sample code for parsing the JSON response is shown below) // { // "amazonOrderReferenceId": "P00-0000000-0000000", // "deliveryDetails": [{ // "trackingNumber": "1Z999AA10123456784", // "carrierCode": "UPS" // }] // } // Sample code for parsing the JSON response... // Use the following online tool to generate parsing code from sample JSON: // Generate Parsing Code from JSON amazonOrderReferenceId = CkJsonObject_stringOf(jResp,"amazonOrderReferenceId"); i = 0; count_i = CkJsonObject_SizeOfArray(jResp,"deliveryDetails"); while (i < count_i) { CkJsonObject_putI(jResp,i); trackingNumber = CkJsonObject_stringOf(jResp,"deliveryDetails[i].trackingNumber"); carrierCode = CkJsonObject_stringOf(jResp,"deliveryDetails[i].carrierCode"); i = i + 1; } CkHttp_Dispose(http); CkJsonObject_Dispose(json); CkPrivateKey_Dispose(privKey); CkStringBuilder_Dispose(sbResponseBody); CkJsonObject_Dispose(jResp); } |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.