unicodeC / CardPointe API Integration / Refund without Reference (Negative Auth)
Back to Collection Items
#include <C_CkHttpW.h>
#include <C_CkJsonObjectW.h>
#include <C_CkStringBuilderW.h>
#include <C_CkHttpResponseW.h>
void ChilkatSample(void)
{
HCkHttpW http;
BOOL success;
HCkJsonObjectW json;
HCkStringBuilderW sbRequestBody;
HCkHttpResponseW resp;
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
http = CkHttpW_Create();
// Use this online tool to generate code from sample JSON: Generate Code to Create JSON
// The following JSON is sent in the request body.
// {
// "merchid": "{{merchid}}",
// "account": "{{account}}",
// "expiry": "{{expiry}}",
// "amount": "-1",
// "currency": "{{currency}}",
// "name": "CC TEST"
// }
json = CkJsonObjectW_Create();
CkJsonObjectW_UpdateString(json,L"merchid",L"{{merchid}}");
CkJsonObjectW_UpdateString(json,L"account",L"{{account}}");
CkJsonObjectW_UpdateString(json,L"expiry",L"{{expiry}}");
CkJsonObjectW_UpdateString(json,L"amount",L"-1");
CkJsonObjectW_UpdateString(json,L"currency",L"{{currency}}");
CkJsonObjectW_UpdateString(json,L"name",L"CC TEST");
CkHttpW_SetRequestHeader(http,L"Authorization",L"Basic dGVzdGluZzp0ZXN0aW5nMTIz");
CkHttpW_SetRequestHeader(http,L"Content-Type",L"application/json");
sbRequestBody = CkStringBuilderW_Create();
CkJsonObjectW_EmitSb(json,sbRequestBody);
resp = CkHttpW_PTextSb(http,L"PUT",L"https://domain.com/auth",sbRequestBody,L"utf-8",L"application/json",FALSE,FALSE);
if (CkHttpW_getLastMethodSuccess(http) == FALSE) {
wprintf(L"%s\n",CkHttpW_lastErrorText(http));
CkHttpW_Dispose(http);
CkJsonObjectW_Dispose(json);
CkStringBuilderW_Dispose(sbRequestBody);
return;
}
wprintf(L"%d\n",CkHttpResponseW_getStatusCode(resp));
wprintf(L"%s\n",CkHttpResponseW_bodyStr(resp));
CkHttpResponseW_Dispose(resp);
CkHttpW_Dispose(http);
CkJsonObjectW_Dispose(json);
CkStringBuilderW_Dispose(sbRequestBody);
}
Curl Command
curl -X PUT
-H "Authorization: Basic dGVzdGluZzp0ZXN0aW5nMTIz"
-H "Content-Type: application/json"
-d '{
"merchid": "{{merchid}}",
"account": "{{account}}",
"expiry": "{{expiry}}",
"amount": "-1",
"currency": "{{currency}}",
"name": "CC TEST"
}'
https://domain.com/auth
Postman Collection Item JSON
{
"name": "Refund without Reference (Negative Auth)",
"event": [
{
"listen": "test",
"script": {
"exec": [
"var jsonData = JSON.parse(responseBody);",
"postman.setEnvironmentVariable(\"profileid\", jsonData.profileid);",
"var jsonData = JSON.parse(responseBody);",
"postman.setEnvironmentVariable(\"acctid\", jsonData.acctid);",
"var jsonData = JSON.parse(responseBody);",
"postman.setEnvironmentVariable(\"retref\", jsonData.retref);",
"var jsonData = JSON.parse(responseBody);",
"postman.setEnvironmentVariable(\"token\", jsonData.token);",
"var jsonData = JSON.parse(responseBody);",
"postman.setEnvironmentVariable(\"batchid\", jsonData.batchid);"
],
"type": "text/javascript"
}
}
],
"request": {
"method": "PUT",
"header": [
{
"key": "Authorization",
"value": "Basic dGVzdGluZzp0ZXN0aW5nMTIz"
},
{
"key": "Content-Type",
"value": "application/json"
}
],
"body": {
"mode": "raw",
"raw": "{\n \"merchid\": \"{{merchid}}\",\n \"account\": \"{{account}}\",\n \"expiry\": \"{{expiry}}\",\n \"amount\": \"-1\",\n \"currency\": \"{{currency}}\",\n \"name\": \"CC TEST\"\n}"
},
"url": {
"raw": "{{url}}/auth",
"host": [
"{{url}}"
],
"path": [
"auth"
]
},
"description": "[Authorization Documentation](https://developer.cardconnect.com/cardconnect-api#authorization)\n\n**Note:** Authorization for a negative amount"
},
"response": [
]
}