Back to Collection Items
#include <CkHttp.h>
#include <CkJsonObject.h>
#include <CkStringBuilder.h>
#include <CkHttpResponse.h>
void ChilkatSample(void)
{
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
CkHttp http;
bool success;
// 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"
// }
CkJsonObject json;
json.UpdateString("merchid","{{merchid}}");
json.UpdateString("account","{{account}}");
json.UpdateString("expiry","{{expiry}}");
json.UpdateString("amount","-1");
json.UpdateString("currency","{{currency}}");
json.UpdateString("name","CC TEST");
http.SetRequestHeader("Authorization","Basic dGVzdGluZzp0ZXN0aW5nMTIz");
http.SetRequestHeader("Content-Type","application/json");
CkStringBuilder sbRequestBody;
json.EmitSb(sbRequestBody);
CkHttpResponse *resp = http.PTextSb("PUT","https://domain.com/auth",sbRequestBody,"utf-8","application/json",false,false);
if (http.get_LastMethodSuccess() == false) {
std::cout << http.lastErrorText() << "\r\n";
return;
}
std::cout << resp->get_StatusCode() << "\r\n";
std::cout << resp->bodyStr() << "\r\n";
delete resp;
}
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": [
]
}