Sample code for 30+ languages & platforms
Unicode C

CardConnect Void

See more CardConnect Examples

Demonstrates how to send a CardConnect void request.
The void service cancels a transaction that is in either "Authorized" or "Queued for Capture" status.. ...

See https://developer.cardconnect.com/cardconnect-api#void

Chilkat Unicode C Downloads

Unicode C
#include <C_CkHttpW.h>
#include <C_CkJsonObjectW.h>
#include <C_CkHttpResponseW.h>

void ChilkatSample(void)
    {
    BOOL success;
    HCkHttpW http;
    HCkJsonObjectW json;
    const wchar_t *url;
    HCkHttpResponseW resp;
    HCkJsonObjectW jsonResp;
    const wchar_t *authcode;
    const wchar_t *respproc;
    const wchar_t *amount;
    const wchar_t *resptext;
    const wchar_t *currency;
    const wchar_t *retref;
    const wchar_t *respstat;
    const wchar_t *respcode;
    const wchar_t *merchid;

    success = FALSE;

    // This example assumes the Chilkat API to have been previously unlocked.
    // See Global Unlock Sample for sample code.

    http = CkHttpW_Create();

    CkHttpW_putBasicAuth(http,TRUE);
    CkHttpW_putLogin(http,L"API_USERNAME");
    CkHttpW_putPassword(http,L"API_PASSWORD");

    // Build and send the following JSON:

    // The "retref" is the value returned in the JSON response for the Authorization request.

    // {
    //     "retref":"112989260941",
    //     "merchid":"MERCHANT_ID"
    // }

    json = CkJsonObjectW_Create();
    CkJsonObjectW_UpdateString(json,L"retref",L"112989260941");
    CkJsonObjectW_UpdateString(json,L"merchid",L"MERCHANT_ID");

    url = L"https://<site>.cardconnect.com:<port>/cardconnect/rest/void";

    resp = CkHttpResponseW_Create();
    success = CkHttpW_HttpStr(http,L"PUT",url,CkJsonObjectW_emit(json),L"utf-8",L"application/json",resp);
    if (success == FALSE) {
        wprintf(L"%s\n",CkHttpW_lastErrorText(http));
        CkHttpW_Dispose(http);
        CkJsonObjectW_Dispose(json);
        CkHttpResponseW_Dispose(resp);
        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",CkHttpResponseW_getStatusCode(resp));

    jsonResp = CkJsonObjectW_Create();
    CkJsonObjectW_Load(jsonResp,CkHttpResponseW_bodyStr(resp));
    CkJsonObjectW_putEmitCompact(jsonResp,FALSE);

    wprintf(L"response JSON:\n");
    wprintf(L"%s\n",CkJsonObjectW_emit(jsonResp));

    // A successful response looks like this:

    // {
    //   "authcode": "REVERS",
    //   "respproc": "FNOR",
    //   "amount": "0.00",
    //   "resptext": "Approval",
    //   "currency": "USD",
    //   "retref": "112989260941",
    //   "respstat": "A",
    //   "respcode": "00",
    //   "merchid": "496160873888"
    // }

    // Use this online tool to generate parsing code from sample JSON: 
    // Generate Parsing Code from JSON

    authcode = CkJsonObjectW_stringOf(jsonResp,L"authcode");
    respproc = CkJsonObjectW_stringOf(jsonResp,L"respproc");
    amount = CkJsonObjectW_stringOf(jsonResp,L"amount");
    resptext = CkJsonObjectW_stringOf(jsonResp,L"resptext");
    currency = CkJsonObjectW_stringOf(jsonResp,L"currency");
    retref = CkJsonObjectW_stringOf(jsonResp,L"retref");
    respstat = CkJsonObjectW_stringOf(jsonResp,L"respstat");
    respcode = CkJsonObjectW_stringOf(jsonResp,L"respcode");
    merchid = CkJsonObjectW_stringOf(jsonResp,L"merchid");


    CkHttpW_Dispose(http);
    CkJsonObjectW_Dispose(json);
    CkHttpResponseW_Dispose(resp);
    CkJsonObjectW_Dispose(jsonResp);

    }