Sample code for 30+ languages & platforms
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

Unicode C++
#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;
    }
    }