Unicode C++
Unicode C++
Shippo Create a Refund
See more Shippo Examples
Demonstrates how to refund a shipping label.Chilkat Unicode C++ Downloads
#include <CkHttpW.h>
#include <CkHttpRequestW.h>
#include <CkHttpResponseW.h>
#include <CkStringBuilderW.h>
#include <CkJsonObjectW.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;
// Implements the following CURL command:
// curl https://api.goshippo.com/refunds/ \
// -H "Authorization: ShippoToken <API_Token>" \
// -d transaction="4503427478ea45a899e9b54abc4c5803"
CkHttpRequestW req;
req.put_HttpVerb(L"POST");
req.put_Path(L"/refunds/");
req.put_ContentType(L"application/x-www-form-urlencoded");
req.AddParam(L"transaction",L"4503427478ea45a899e9b54abc4c5803");
req.AddHeader(L"Authorization",L"ShippoToken <API_Token>");
CkHttpResponseW resp;
success = http.HttpReq(L"https://api.goshippo.com/refunds/",req,resp);
if (success == false) {
wprintf(L"%s\n",http.lastErrorText());
return;
}
CkStringBuilderW sbResponseBody;
resp.GetBodySb(sbResponseBody);
CkJsonObjectW jResp;
jResp.LoadSb(sbResponseBody);
jResp.put_EmitCompact(false);
wprintf(L"Response Body:\n");
wprintf(L"%s\n",jResp.emit());
int respStatusCode = resp.get_StatusCode();
wprintf(L"Response Status Code = %d\n",respStatusCode);
if (respStatusCode >= 400) {
wprintf(L"Response Header:\n");
wprintf(L"%s\n",resp.header());
wprintf(L"Failed.\n");
return;
}
// Sample JSON response:
// (Sample code for parsing the JSON response is shown below)
// {
// "object_created": "2014-04-21T07:12:41.044Z",
// "object_id": "bd7b8379a2e847bcb0818125943dde5d",
// "object_owner": "shippotle@goshippo.com",
// "object_updated": "2014-04-21T07:12:41.045Z",
// "status": "QUEUED",
// "transaction": "35ed59f23a514ecfa2faeaed93a00086"
// }
// Sample code for parsing the JSON response...
// Use the following online tool to generate parsing code from sample JSON:
// Generate Parsing Code from JSON
// Chilkat functions returning "const char *" return a pointer to temporary internal memory owned and managed by Chilkat.
// See this example explaining how this memory should be used: const char * functions.
const wchar_t *object_created = jResp.stringOf(L"object_created");
const wchar_t *object_id = jResp.stringOf(L"object_id");
const wchar_t *object_owner = jResp.stringOf(L"object_owner");
const wchar_t *object_updated = jResp.stringOf(L"object_updated");
const wchar_t *status = jResp.stringOf(L"status");
const wchar_t *transaction = jResp.stringOf(L"transaction");
}