PowerShell
PowerShell
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 PowerShell Downloads
Add-Type -Path "C:\chilkat\ChilkatDotNet47-x64\ChilkatDotNet47.dll"
$success = $false
# This example assumes the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.
$json = New-Object Chilkat.JsonObject
# 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-Object Chilkat.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.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.LastMethodSuccess -eq $false) {
$($http.LastErrorText)
exit
}
$($responseJson)
$("----")
# A 200 status code indicates success.
$("Status code = " + $http.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
$jarr = New-Object Chilkat.JsonArray
$success = $jarr.Load($responseJson)
$i = 0
$count_i = $jarr.Size
while ($i -lt $count_i) {
$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 -lt $count_j) {
$jsonObj.J = $j
$j = $j + 1
}
$i = $i + 1
}