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
(Unicode C++) CardConnect Capture Level 3 DataDemonstrates how to send a CardConnect Capture request with Lavel 3 line item data. If available, Level 3 line item data can be sent with the capture request, particularly for any commercial or corporate payment cards. To qualify for Level 3 Interchange rates, Level 2 data must also be provided. ... See https://developer.cardconnect.com/cardconnect-api#capture-level-3-data
#include <CkHttpW.h> #include <CkJsonObjectW.h> void ChilkatSample(void) { // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkHttpW http; bool success; http.put_BasicAuth(true); http.put_Login(L"API_USERNAME"); http.put_Password(L"API_PASSWORD"); // Build and send the following JSON: // The "retref" is the value returned in the JSON response for the Authorization request. // { // "retref": "2880000333", // "shiptozip": "11111-1111", // "shipfromzip": "99999-9999", // "amount": "596.00", // "items": [ // { // "discamnt": "0", // "unitcost": "900", // "uom": "CS", // "lineno": "1", // "description": "DESCRIPTION-1", // "taxamnt": "117", // "quantity": "1000", // "upc": "UPC-1", // "netamnt": "150", // "material": "MATERIAL-1" // }, // { // "discamnt": "0", // "unitcost": "450", // "uom": "CS", // "lineno": "2", // "description": "DESCRIPTION-2", // "taxamnt": "117", // "quantity": "2000", // "upc": "UPC-1", // "netamnt": "300", // "material": "MATERIAL-2" // } // ], // "taxamount": "40.00", // "merchid": "123456789012", // "account": "4111111111111111", // "ponumber": "PO-0736332" // } // // Use this online tool to generate the code from sample JSON: // Generate Code to Create JSON CkJsonObjectW json; json.UpdateString(L"retref",L"112989260941"); json.UpdateString(L"shiptozip",L"11111-1111"); json.UpdateString(L"shipfromzip",L"99999-9999"); json.UpdateString(L"amount",L"596.00"); json.UpdateString(L"items[0].discamnt",L"0"); json.UpdateString(L"items[0].unitcost",L"900"); json.UpdateString(L"items[0].uom",L"CS"); json.UpdateString(L"items[0].lineno",L"1"); json.UpdateString(L"items[0].description",L"DESCRIPTION-1"); json.UpdateString(L"items[0].taxamnt",L"117"); json.UpdateString(L"items[0].quantity",L"1000"); json.UpdateString(L"items[0].upc",L"UPC-1"); json.UpdateString(L"items[0].netamnt",L"150"); json.UpdateString(L"items[0].material",L"MATERIAL-1"); json.UpdateString(L"items[1].discamnt",L"0"); json.UpdateString(L"items[1].unitcost",L"450"); json.UpdateString(L"items[1].uom",L"CS"); json.UpdateString(L"items[1].lineno",L"2"); json.UpdateString(L"items[1].description",L"DESCRIPTION-2"); json.UpdateString(L"items[1].taxamnt",L"117"); json.UpdateString(L"items[1].quantity",L"2000"); json.UpdateString(L"items[1].upc",L"UPC-1"); json.UpdateString(L"items[1].netamnt",L"300"); json.UpdateString(L"items[1].material",L"MATERIAL-2"); json.UpdateString(L"taxamount",L"40.00"); json.UpdateString(L"merchid",L"MERCHANT_ID"); json.UpdateString(L"account",L"4111111111111111"); json.UpdateString(L"ponumber",L"PO-0736332"); const wchar_t *url = L"https://<site>.cardconnect.com:<port>/cardconnect/rest/capture"; const wchar_t *responseStr = http.putText(url,json.emit(),L"utf-8",L"application/json",false,false); if (http.get_LastMethodSuccess() == false) { wprintf(L"%s\n",http.lastErrorText()); return; } // A response status of 200 indicates potential success. The JSON response body // must be examined to determine if it was truly successful or an error. wprintf(L"response status code = %d\n",http.get_LastStatus()); CkJsonObjectW jsonResp; jsonResp.Load(responseStr); jsonResp.put_EmitCompact(false); wprintf(L"response JSON:\n"); wprintf(L"%s\n",jsonResp.emit()); // A successful response looks like this: // { // "amount": "596.00", // "resptext": "Approval", // "setlstat": "Queued for Capture", // "commcard": " C ", // "respcode": "00", // "batchid": "1900942291", // "merchid": "MERCHANT_ID", // "token": "9418594164541111", // "authcode": "PPS158", // "respproc": "FNOR", // "retref": "112989260941", // "respstat": "A", // "account": "9418594164541111" // } // Use this online tool to generate parsing code from sample JSON: // Generate Parsing Code from JSON const wchar_t *amount = jsonResp.stringOf(L"amount"); const wchar_t *resptext = jsonResp.stringOf(L"resptext"); const wchar_t *setlstat = jsonResp.stringOf(L"setlstat"); const wchar_t *commcard = jsonResp.stringOf(L"commcard"); const wchar_t *respcode = jsonResp.stringOf(L"respcode"); const wchar_t *batchid = jsonResp.stringOf(L"batchid"); const wchar_t *merchid = jsonResp.stringOf(L"merchid"); const wchar_t *token = jsonResp.stringOf(L"token"); const wchar_t *authcode = jsonResp.stringOf(L"authcode"); const wchar_t *respproc = jsonResp.stringOf(L"respproc"); const wchar_t *retref = jsonResp.stringOf(L"retref"); const wchar_t *respstat = jsonResp.stringOf(L"respstat"); const wchar_t *account = jsonResp.stringOf(L"account"); } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.