Chilkat HOME Android™ Classic ASP C C++ C# Mono C# .NET Core C# C# UWP/WinRT DataFlex Delphi ActiveX Delphi DLL Visual FoxPro Java Lianja MFC Objective-C Perl PHP ActiveX PHP Extension PowerBuilder PowerShell PureBasic CkPython Chilkat2-Python Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ Visual Basic 6.0 VB.NET VB.NET UWP/WinRT VBScript Xojo Plugin Node.js Excel Go
(MFC) 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 <CkHttp.h> #include <CkJsonObject.h> void ChilkatSample(void) { CkString strOut; // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkHttp http; bool success; http.put_BasicAuth(true); http.put_Login("API_USERNAME"); http.put_Password("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 CkJsonObject json; json.UpdateString("retref","112989260941"); json.UpdateString("shiptozip","11111-1111"); json.UpdateString("shipfromzip","99999-9999"); json.UpdateString("amount","596.00"); json.UpdateString("items[0].discamnt","0"); json.UpdateString("items[0].unitcost","900"); json.UpdateString("items[0].uom","CS"); json.UpdateString("items[0].lineno","1"); json.UpdateString("items[0].description","DESCRIPTION-1"); json.UpdateString("items[0].taxamnt","117"); json.UpdateString("items[0].quantity","1000"); json.UpdateString("items[0].upc","UPC-1"); json.UpdateString("items[0].netamnt","150"); json.UpdateString("items[0].material","MATERIAL-1"); json.UpdateString("items[1].discamnt","0"); json.UpdateString("items[1].unitcost","450"); json.UpdateString("items[1].uom","CS"); json.UpdateString("items[1].lineno","2"); json.UpdateString("items[1].description","DESCRIPTION-2"); json.UpdateString("items[1].taxamnt","117"); json.UpdateString("items[1].quantity","2000"); json.UpdateString("items[1].upc","UPC-1"); json.UpdateString("items[1].netamnt","300"); json.UpdateString("items[1].material","MATERIAL-2"); json.UpdateString("taxamount","40.00"); json.UpdateString("merchid","MERCHANT_ID"); json.UpdateString("account","4111111111111111"); json.UpdateString("ponumber","PO-0736332"); const char *url = "https://<site>.cardconnect.com:<port>/cardconnect/rest/capture"; const char *responseStr = http.putText(url,json.emit(),"utf-8","application/json",false,false); if (http.get_LastMethodSuccess() == false) { strOut.append(http.lastErrorText()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); 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. strOut.append("response status code = "); strOut.appendInt(http.get_LastStatus()); strOut.append("\r\n"); CkJsonObject jsonResp; jsonResp.Load(responseStr); jsonResp.put_EmitCompact(false); strOut.append("response JSON:"); strOut.append("\r\n"); strOut.append(jsonResp.emit()); strOut.append("\r\n"); // 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 char *amount = jsonResp.stringOf("amount"); const char *resptext = jsonResp.stringOf("resptext"); const char *setlstat = jsonResp.stringOf("setlstat"); const char *commcard = jsonResp.stringOf("commcard"); const char *respcode = jsonResp.stringOf("respcode"); const char *batchid = jsonResp.stringOf("batchid"); const char *merchid = jsonResp.stringOf("merchid"); const char *token = jsonResp.stringOf("token"); const char *authcode = jsonResp.stringOf("authcode"); const char *respproc = jsonResp.stringOf("respproc"); const char *retref = jsonResp.stringOf("retref"); const char *respstat = jsonResp.stringOf("respstat"); const char *account = jsonResp.stringOf("account"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); } |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.