Sample code for 30+ languages & platforms
PHP Extension

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 PHP Extension Downloads

PHP Extension
<?php

include("chilkat.php");

$success = false;

// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.

$json = new CkJsonObject();

// 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('keyId','api-key');
$json->UpdateString('hmacKey','api-secret');
$json->UpdateString('algorithm','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('headers[0]','(request-target)');
$json->UpdateString('headers[1]','host');
$json->UpdateString('headers[2]','date');

$http = new CkHttp();

// 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('Cache-Control','no-cache');

// Chilkat will auto-add the Date header because it's needed by the HTTP Signature.

$responseJson = $http->quickGetStr('https://api-worldcheck.refinitiv.com/v2/groups');
if ($http->get_LastMethodSuccess() == false) {
    print $http->lastErrorText() . "\n";
    exit;
}

print $responseJson . "\n";
print '----' . "\n";
// A 200 status code indicates success.
print 'Status code = ' . $http->get_LastStatus() . "\n";

// 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

$jarr = new CkJsonArray();

$success = $jarr->Load($responseJson);

$i = 0;
$count_i = $jarr->get_Size();
while ($i < $count_i) {
    // jsonObj is a CkJsonObject
    $jsonObj = $jarr->ObjectAt($i);
    $id = $jsonObj->stringOf('id');
    $name = $jsonObj->stringOf('name');
    $parentId = $jsonObj->stringOf('parentId');
    $hasChildren = $jsonObj->BoolOf('hasChildren');
    $status = $jsonObj->stringOf('status');
    $j = 0;
    $count_j = $jsonObj->SizeOfArray('children');
    while ($j < $count_j) {
        $jsonObj->put_J($j);
        $j = $j + 1;
    }

    $i = $i + 1;
}


?>