Sample code for 30+ languages & platforms
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

Unicode C++
#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");
    }