Unicode C++
Unicode C++
Refinitiv World-Check One - Get Top Level Groups
See more Refinitiv Examples
Sends a signed GET request to get the top level groups.Note: This example requires Chilkat v9.5.0.89 or later.
Chilkat Unicode C++ Downloads
#include <CkJsonObjectW.h>
#include <CkHttpW.h>
#include <CkJsonArrayW.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.
CkJsonObjectW json;
// Create the following JSON:
//
// {
// "keyId": "aaaaaaa-bbbb-cccc-dddd-eeeeeeeeeeee",
// "hmacKey": "xxxxzI3vi58xxxCBxxx1+P/d8tGxx7KuLqN/KMPNxxxxekhj8/bx83+1YQSUxxxxYyv939ceY06GvhYRKmxxxx==",
// "algorithm": "hmac-sha256",
// "headers": [
// "(request-target)",
// "host",
// "date"
// ]
// }
// Substitute your actual API key and API secret in place of "api-key" and "api-secret"
json.UpdateString(L"keyId",L"api-key");
json.UpdateString(L"hmacKey",L"api-secret");
json.UpdateString(L"algorithm",L"hmac-sha256");
// Indicate the names of the headers to be included in the signature.
// "(request-target)" is not actually a header name, but is a special name for HTTP signatures.
// Copy the following three lines of code exactly as-is.
// Do not replace "host", "date", or "(request-target)" with values.
json.UpdateString(L"headers[0]",L"(request-target)");
json.UpdateString(L"headers[1]",L"host");
json.UpdateString(L"headers[2]",L"date");
CkHttpW http;
// Setting the AuthSignature property causes the following header to be computed and added:
// Authorization: Signature keyId="...", algorithm="hmac-sha256", headers="(request-target) host date", signature="..."
http.put_AuthSignature(json.emit());
http.SetRequestHeader(L"Cache-Control",L"no-cache");
// Chilkat will auto-add the Date header because it's needed by the HTTP Signature.
const wchar_t *responseJson = http.quickGetStr(L"https://api-worldcheck.refinitiv.com/v2/groups");
if (http.get_LastMethodSuccess() == false) {
wprintf(L"%s\n",http.lastErrorText());
return;
}
wprintf(L"%s\n",responseJson);
wprintf(L"----\n");
// A 200 status code indicates success.
wprintf(L"Status code = %d\n",http.get_LastStatus());
// Successful JSON looks like this:
// [
// {
// "id": "...",
// "name": "Company Name",
// "parentId": null,
// "hasChildren": false,
// "status": "ACTIVE",
// "children": []
// }
// ]
// Use this online tool to generate parsing code from sample JSON:
// Generate Parsing Code from JSON
CkJsonArrayW jarr;
success = jarr.Load(responseJson);
CkJsonObjectW *jsonObj = 0;
const wchar_t *id = 0;
const wchar_t *name = 0;
const wchar_t *parentId = 0;
bool hasChildren;
const wchar_t *status = 0;
int j;
int count_j;
int i = 0;
int count_i = jarr.get_Size();
while (i < count_i) {
jsonObj = jarr.ObjectAt(i);
id = jsonObj->stringOf(L"id");
name = jsonObj->stringOf(L"name");
parentId = jsonObj->stringOf(L"parentId");
hasChildren = jsonObj->BoolOf(L"hasChildren");
status = jsonObj->stringOf(L"status");
j = 0;
count_j = jsonObj->SizeOfArray(L"children");
while (j < count_j) {
jsonObj->put_J(j);
j = j + 1;
}
delete jsonObj;
i = i + 1;
}
}