Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(C) Amazon Pay - Get Checkout SessionSee more Amazon Pay ExamplesGet Checkout Session details includes buyer info, payment instrument details, and shipping address. For more information, see https://developer.amazon.com/docs/amazon-pay-api-v2/checkout-session.html#get-checkout-session
#include <C_CkHttp.h> #include <C_CkPrivateKey.h> #include <C_CkStringBuilder.h> #include <C_CkJsonObject.h> void ChilkatSample(void) { HCkHttp http; BOOL success; HCkPrivateKey privKey; const char *publicKeyId; int respStatusCode; HCkStringBuilder sbResponseBody; HCkJsonObject jResp; const char *paymentDescriptor; const char *constraintId; const char *description; const char *strVal; const char *checkoutSessionId; const char *webCheckoutDetailsCheckoutReviewReturnUrl; const char *webCheckoutDetailsCheckoutResultReturnUrl; const char *webCheckoutDetailsCheckoutCancelUrl; const char *webCheckoutDetailsAmazonPayRedirectUrl; const char *chargePermissionType; const char *recurringMetadataFrequencyUnit; const char *recurringMetadataFrequencyValue; const char *recurringMetadataAmountAmount; const char *recurringMetadataAmountCurrencyCode; const char *productType; const char *paymentDetailsPaymentIntent; BOOL paymentDetailsCanHandlePendingAuthorization; const char *paymentDetailsChargeAmount; const char *paymentDetailsTotalOrderAmount; const char *paymentDetailsSoftDescriptor; const char *paymentDetailsPresentmentCurrency; const char *paymentDetailsAllowOvercharge; const char *paymentDetailsExtendExpiration; const char *merchantMetadataMerchantReferenceId; const char *merchantMetadataMerchantStoreName; const char *merchantMetadataNoteToBuyer; const char *merchantMetadataCustomInformation; const char *supplementaryData; const char *buyerBuyerId; const char *buyerName; const char *buyerEmail; const char *buyerPhoneNumber; const char *buyerPrimeMembershipTypes; const char *billingAddressName; const char *billingAddressAddressLine1; const char *billingAddressAddressLine2; const char *billingAddressAddressLine3; const char *billingAddressCity; const char *billingAddressCounty; const char *billingAddressDistrict; const char *billingAddressStateOrRegion; const char *billingAddressPostalCode; const char *billingAddressCountryCode; const char *statusDetailsState; const char *statusDetailsReasonCode; const char *statusDetailsReasonDescription; const char *statusDetailsLastUpdatedTimestamp; const char *shippingAddressName; const char *shippingAddressAddressLine1; const char *shippingAddressAddressLine2; const char *shippingAddressAddressLine3; const char *shippingAddressCity; const char *shippingAddressCounty; const char *shippingAddressDistrict; const char *shippingAddressStateOrRegion; const char *shippingAddressPostalCode; const char *shippingAddressCountryCode; const char *shippingAddressPhoneNumber; const char *platformId; const char *chargePermissionId; const char *chargeId; const char *creationTimestamp; const char *expirationTimestamp; const char *storeId; const char *deliverySpecificationsAddressRestrictionsType; const char *providerMetadataProviderReferenceId; const char *releaseEnvironment; 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 CURL command: // curl "https://pay-api.amazon.com/:version/checkoutSessions/:checkoutSessionId" // -X GET // -H "authorization:Px2e5oHhQZ88vVhc0DO%2FsShHj8MDDg%3DEXAMPLESIGNATURE" // -H "x-amz-pay-date:20201012T235046Z" // Use the following online tool to generate HTTP code from a CURL command // Convert a cURL Command to HTTP Source Code // 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); 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); 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 // Authorization CkHttp_putAccept(http,"application/json"); respStatusCode = 0; sbResponseBody = CkStringBuilder_Create(); success = CkHttp_SetUrlVar(http,"sessionId","62b7d028-6c7c-4a43-b077-3897dff27c5b"); // To use the live system, replace "sandbox" with "live" in the URL passed to QuickGetSb. // Also, make sure to use the correct region: pay-api.amazon.com, pay-api.amazon.eu, or pay-api.amazon.jp success = CkHttp_QuickGetSb(http,"https://pay-api.amazon.eu/sandbox/v2/checkoutSessions/{$sessionId}",sbResponseBody); if (success == FALSE) { // If the LastStatus is not equal to 0, then we received a response, but it was an error response. respStatusCode = CkHttp_getLastStatus(http); if (respStatusCode != 0) { printf("Response Status Code = %d\n",respStatusCode); // A sample response body for the case where the session ID does not exist: // {"reasonCode":"ResourceNotFound","message":"Resource you are trying to access is not available. Requested path '/sandbox/v2/checkoutSessions/bd504926-f659-4ad7-a1a9-9a747aaf5275'"} printf("Response body:\n"); printf("%s\n",CkHttp_lastResponseBody(http)); } else { printf("%s\n",CkHttp_lastErrorText(http)); } CkHttp_Dispose(http); CkPrivateKey_Dispose(privKey); CkStringBuilder_Dispose(sbResponseBody); return; } jResp = CkJsonObject_Create(); CkJsonObject_LoadSb(jResp,sbResponseBody); CkJsonObject_putEmitCompact(jResp,FALSE); printf("Response Body:\n"); printf("%s\n",CkJsonObject_emit(jResp)); respStatusCode = CkHttp_getLastStatus(http); printf("Response Status Code = %d\n",respStatusCode); // We expect a 200 status code for success. // Note: Some Amazon Pay API calls return 200 for success, others return 201. if (respStatusCode != 200) { printf("Failed.\n"); CkHttp_Dispose(http); CkPrivateKey_Dispose(privKey); CkStringBuilder_Dispose(sbResponseBody); CkJsonObject_Dispose(jResp); return; } // Sample JSON response: // (Sample code for parsing the JSON response is shown below) // { // "checkoutSessionId": "bd504926-f659-4ad7-a1a9-9a747aaf5275", // "webCheckoutDetails": { // "checkoutReviewReturnUrl": "https://a.com/merchant-review-page", // "checkoutResultReturnUrl": null, // "checkoutCancelUrl": null, // "amazonPayRedirectUrl": null // }, // "chargePermissionType": "Recurring", // "recurringMetadata": { // "frequency": { // "unit": "Month", // "value": "1" // }, // "amount": { // "amount": "30", // "currencyCode": "USD" // } // }, // "productType": "PayAndShip", // "paymentDetails": { // "paymentIntent": null, // "canHandlePendingAuthorization": false, // "chargeAmount": null, // "totalOrderAmount": null, // "softDescriptor": null, // "presentmentCurrency": null, // "allowOvercharge": null, // "extendExpiration": null // }, // "merchantMetadata": { // "merchantReferenceId": null, // "merchantStoreName": null, // "noteToBuyer": null, // "customInformation": null // }, // "supplementaryData": null, // "buyer": { // "buyerId": "buyerId", // "name": "name-1", // "email": "name@amazon.com", // "phoneNumber": "800-000-0000", // "primeMembershipTypes": null // }, // "billingAddress": { // "name": "Work", // "addressLine1": "440 Terry Ave", // "addressLine2": "", // "addressLine3": "", // "city": "Seattle", // "county": "King", // "district": "Seattle", // "stateOrRegion": "WA", // "postalCode": "98121", // "countryCode": "US" // }, // "paymentPreferences": [ // { // "paymentDescriptor": "Your selected Amazon payment method" // } // ], // "statusDetails": { // "state": "Open", // "reasonCode": null, // "reasonDescription": null, // "lastUpdatedTimestamp": "20191015T204327Z" // }, // "shippingAddress": { // "name": "Susie Smith", // "addressLine1": "10 Ditka Ave", // "addressLine2": "Suite 2500", // "addressLine3": null, // "city": "Chicago", // "county": null, // "district": null, // "stateOrRegion": "IL", // "postalCode": "60602", // "countryCode": "US", // "phoneNumber": "800-000-0000" // }, // "platformId": null, // "chargePermissionId": null, // "chargeId": null, // "constraints": [ // { // "constraintId": "ChargeAmountNotSet", // "description": "chargeAmount is not set." // }, // { // "constraintId": "CheckoutResultReturnUrlNotSet", // "description": "checkoutResultReturnUrl is not set." // }, // { // "constraintId": "PaymentIntentNotSet", // "description": "paymentIntent is not set." // } // ], // "creationTimestamp": "20191015T204313Z", // "expirationTimestamp": "20191016T204313Z", // "storeId": "amzn1.application-oa2-client.8b5e45312b5248b69eeaStoreId", // "deliverySpecifications": { // "specialRestrictions": [ // "RestrictPOBoxes" // ], // "addressRestrictions": { // "type": "Allowed", // "restrictions": { // "US": { // "statesOrRegions": [ // "WA" // ], // "zipCodes": [ // "95050", // "93405" // ] // }, // "GB": { // "zipCodes": [ // "72046", // "72047" // ] // }, // "IN": { // "statesOrRegions": [ // "AP" // ] // }, // "JP": {} // } // } // }, // "providerMetadata": { // "providerReferenceId": null // }, // "releaseEnvironment": "Sandbox" // } // Sample code for parsing the JSON response... // Use the following online tool to generate parsing code from sample JSON: // Generate Parsing Code from JSON // Chilkat functions returning "const char *" return a pointer to temporary internal memory owned and managed by Chilkat. // See this example explaining how this memory should be used: const char * functions. checkoutSessionId = CkJsonObject_stringOf(jResp,"checkoutSessionId"); webCheckoutDetailsCheckoutReviewReturnUrl = CkJsonObject_stringOf(jResp,"webCheckoutDetails.checkoutReviewReturnUrl"); webCheckoutDetailsCheckoutResultReturnUrl = CkJsonObject_stringOf(jResp,"webCheckoutDetails.checkoutResultReturnUrl"); webCheckoutDetailsCheckoutCancelUrl = CkJsonObject_stringOf(jResp,"webCheckoutDetails.checkoutCancelUrl"); webCheckoutDetailsAmazonPayRedirectUrl = CkJsonObject_stringOf(jResp,"webCheckoutDetails.amazonPayRedirectUrl"); chargePermissionType = CkJsonObject_stringOf(jResp,"chargePermissionType"); recurringMetadataFrequencyUnit = CkJsonObject_stringOf(jResp,"recurringMetadata.frequency.unit"); recurringMetadataFrequencyValue = CkJsonObject_stringOf(jResp,"recurringMetadata.frequency.value"); recurringMetadataAmountAmount = CkJsonObject_stringOf(jResp,"recurringMetadata.amount.amount"); recurringMetadataAmountCurrencyCode = CkJsonObject_stringOf(jResp,"recurringMetadata.amount.currencyCode"); productType = CkJsonObject_stringOf(jResp,"productType"); paymentDetailsPaymentIntent = CkJsonObject_stringOf(jResp,"paymentDetails.paymentIntent"); paymentDetailsCanHandlePendingAuthorization = CkJsonObject_BoolOf(jResp,"paymentDetails.canHandlePendingAuthorization"); paymentDetailsChargeAmount = CkJsonObject_stringOf(jResp,"paymentDetails.chargeAmount"); paymentDetailsTotalOrderAmount = CkJsonObject_stringOf(jResp,"paymentDetails.totalOrderAmount"); paymentDetailsSoftDescriptor = CkJsonObject_stringOf(jResp,"paymentDetails.softDescriptor"); paymentDetailsPresentmentCurrency = CkJsonObject_stringOf(jResp,"paymentDetails.presentmentCurrency"); paymentDetailsAllowOvercharge = CkJsonObject_stringOf(jResp,"paymentDetails.allowOvercharge"); paymentDetailsExtendExpiration = CkJsonObject_stringOf(jResp,"paymentDetails.extendExpiration"); merchantMetadataMerchantReferenceId = CkJsonObject_stringOf(jResp,"merchantMetadata.merchantReferenceId"); merchantMetadataMerchantStoreName = CkJsonObject_stringOf(jResp,"merchantMetadata.merchantStoreName"); merchantMetadataNoteToBuyer = CkJsonObject_stringOf(jResp,"merchantMetadata.noteToBuyer"); merchantMetadataCustomInformation = CkJsonObject_stringOf(jResp,"merchantMetadata.customInformation"); supplementaryData = CkJsonObject_stringOf(jResp,"supplementaryData"); buyerBuyerId = CkJsonObject_stringOf(jResp,"buyer.buyerId"); buyerName = CkJsonObject_stringOf(jResp,"buyer.name"); buyerEmail = CkJsonObject_stringOf(jResp,"buyer.email"); buyerPhoneNumber = CkJsonObject_stringOf(jResp,"buyer.phoneNumber"); buyerPrimeMembershipTypes = CkJsonObject_stringOf(jResp,"buyer.primeMembershipTypes"); billingAddressName = CkJsonObject_stringOf(jResp,"billingAddress.name"); billingAddressAddressLine1 = CkJsonObject_stringOf(jResp,"billingAddress.addressLine1"); billingAddressAddressLine2 = CkJsonObject_stringOf(jResp,"billingAddress.addressLine2"); billingAddressAddressLine3 = CkJsonObject_stringOf(jResp,"billingAddress.addressLine3"); billingAddressCity = CkJsonObject_stringOf(jResp,"billingAddress.city"); billingAddressCounty = CkJsonObject_stringOf(jResp,"billingAddress.county"); billingAddressDistrict = CkJsonObject_stringOf(jResp,"billingAddress.district"); billingAddressStateOrRegion = CkJsonObject_stringOf(jResp,"billingAddress.stateOrRegion"); billingAddressPostalCode = CkJsonObject_stringOf(jResp,"billingAddress.postalCode"); billingAddressCountryCode = CkJsonObject_stringOf(jResp,"billingAddress.countryCode"); statusDetailsState = CkJsonObject_stringOf(jResp,"statusDetails.state"); statusDetailsReasonCode = CkJsonObject_stringOf(jResp,"statusDetails.reasonCode"); statusDetailsReasonDescription = CkJsonObject_stringOf(jResp,"statusDetails.reasonDescription"); statusDetailsLastUpdatedTimestamp = CkJsonObject_stringOf(jResp,"statusDetails.lastUpdatedTimestamp"); shippingAddressName = CkJsonObject_stringOf(jResp,"shippingAddress.name"); shippingAddressAddressLine1 = CkJsonObject_stringOf(jResp,"shippingAddress.addressLine1"); shippingAddressAddressLine2 = CkJsonObject_stringOf(jResp,"shippingAddress.addressLine2"); shippingAddressAddressLine3 = CkJsonObject_stringOf(jResp,"shippingAddress.addressLine3"); shippingAddressCity = CkJsonObject_stringOf(jResp,"shippingAddress.city"); shippingAddressCounty = CkJsonObject_stringOf(jResp,"shippingAddress.county"); shippingAddressDistrict = CkJsonObject_stringOf(jResp,"shippingAddress.district"); shippingAddressStateOrRegion = CkJsonObject_stringOf(jResp,"shippingAddress.stateOrRegion"); shippingAddressPostalCode = CkJsonObject_stringOf(jResp,"shippingAddress.postalCode"); shippingAddressCountryCode = CkJsonObject_stringOf(jResp,"shippingAddress.countryCode"); shippingAddressPhoneNumber = CkJsonObject_stringOf(jResp,"shippingAddress.phoneNumber"); platformId = CkJsonObject_stringOf(jResp,"platformId"); chargePermissionId = CkJsonObject_stringOf(jResp,"chargePermissionId"); chargeId = CkJsonObject_stringOf(jResp,"chargeId"); creationTimestamp = CkJsonObject_stringOf(jResp,"creationTimestamp"); expirationTimestamp = CkJsonObject_stringOf(jResp,"expirationTimestamp"); storeId = CkJsonObject_stringOf(jResp,"storeId"); deliverySpecificationsAddressRestrictionsType = CkJsonObject_stringOf(jResp,"deliverySpecifications.addressRestrictions.type"); providerMetadataProviderReferenceId = CkJsonObject_stringOf(jResp,"providerMetadata.providerReferenceId"); releaseEnvironment = CkJsonObject_stringOf(jResp,"releaseEnvironment"); i = 0; count_i = CkJsonObject_SizeOfArray(jResp,"paymentPreferences"); while (i < count_i) { CkJsonObject_putI(jResp,i); paymentDescriptor = CkJsonObject_stringOf(jResp,"paymentPreferences[i].paymentDescriptor"); i = i + 1; } i = 0; count_i = CkJsonObject_SizeOfArray(jResp,"constraints"); while (i < count_i) { CkJsonObject_putI(jResp,i); constraintId = CkJsonObject_stringOf(jResp,"constraints[i].constraintId"); description = CkJsonObject_stringOf(jResp,"constraints[i].description"); i = i + 1; } i = 0; count_i = CkJsonObject_SizeOfArray(jResp,"deliverySpecifications.specialRestrictions"); while (i < count_i) { CkJsonObject_putI(jResp,i); strVal = CkJsonObject_stringOf(jResp,"deliverySpecifications.specialRestrictions[i]"); i = i + 1; } i = 0; count_i = CkJsonObject_SizeOfArray(jResp,"deliverySpecifications.addressRestrictions.restrictions.US.statesOrRegions"); while (i < count_i) { CkJsonObject_putI(jResp,i); strVal = CkJsonObject_stringOf(jResp,"deliverySpecifications.addressRestrictions.restrictions.US.statesOrRegions[i]"); i = i + 1; } i = 0; count_i = CkJsonObject_SizeOfArray(jResp,"deliverySpecifications.addressRestrictions.restrictions.US.zipCodes"); while (i < count_i) { CkJsonObject_putI(jResp,i); strVal = CkJsonObject_stringOf(jResp,"deliverySpecifications.addressRestrictions.restrictions.US.zipCodes[i]"); i = i + 1; } i = 0; count_i = CkJsonObject_SizeOfArray(jResp,"deliverySpecifications.addressRestrictions.restrictions.GB.zipCodes"); while (i < count_i) { CkJsonObject_putI(jResp,i); strVal = CkJsonObject_stringOf(jResp,"deliverySpecifications.addressRestrictions.restrictions.GB.zipCodes[i]"); i = i + 1; } i = 0; count_i = CkJsonObject_SizeOfArray(jResp,"deliverySpecifications.addressRestrictions.restrictions.IN.statesOrRegions"); while (i < count_i) { CkJsonObject_putI(jResp,i); strVal = CkJsonObject_stringOf(jResp,"deliverySpecifications.addressRestrictions.restrictions.IN.statesOrRegions[i]"); i = i + 1; } CkHttp_Dispose(http); CkPrivateKey_Dispose(privKey); CkStringBuilder_Dispose(sbResponseBody); CkJsonObject_Dispose(jResp); } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.