Unicode C++
Unicode C++
CardConnect Capture Level 3 Data
See more CardConnect Examples
Demonstrates 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
Chilkat Unicode C++ Downloads
#include <CkHttpW.h>
#include <CkJsonObjectW.h>
#include <CkHttpResponseW.h>
void ChilkatSample(void)
{
bool success = false;
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
CkHttpW http;
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";
CkHttpResponseW resp;
success = http.HttpStr(L"PUT",url,json.emit(),L"utf-8",L"application/json",resp);
if (success == 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",resp.get_StatusCode());
CkJsonObjectW jsonResp;
jsonResp.Load(resp.bodyStr());
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");
}