PowerBuilder
PowerBuilder
RSAP Union API - Get Members Status
See more _Miscellaneous_ Examples
Demonstrates how to use an OAuth2 access token for the RSAP Union API. Calls the endpoint to get the statuses of all union members.Chilkat PowerBuilder Downloads
integer li_rc
integer li_Success
oleobject loo_Http
oleobject loo_JToken
oleobject loo_Cert
oleobject loo_PrivKey
oleobject loo_SbResponseBody
oleobject loo_JResp
integer li_RespStatusCode
li_Success = 0
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
loo_Http = create oleobject
li_rc = loo_Http.ConnectToNewObject("Chilkat.Http")
if li_rc < 0 then
destroy loo_Http
MessageBox("Error","Connecting to COM object failed")
return
end if
// Load the access token previously obtained by this example: RSAP Union OAuth2
loo_JToken = create oleobject
li_rc = loo_JToken.ConnectToNewObject("Chilkat.JsonObject")
li_Success = loo_JToken.LoadFile("qa_data/tokens/rsapToken.json")
if li_Success = 0 then
Write-Debug "Failed to load access token JSON."
destroy loo_Http
destroy loo_JToken
return
end if
// Adds the "Authorization: Bearer ACCESS_TOKEN" header.
loo_Http.AuthToken = loo_JToken.StringOf("access_token")
// For authentication, assuming both the client cert and access token are needed???
loo_Cert = create oleobject
li_rc = loo_Cert.ConnectToNewObject("Chilkat.Cert")
li_Success = loo_Cert.LoadFromFile("qa_data/certs_and_keys/union_client_certificate.crt")
if li_Success = 0 then
Write-Debug loo_Cert.LastErrorText
destroy loo_Http
destroy loo_JToken
destroy loo_Cert
return
end if
loo_PrivKey = create oleobject
li_rc = loo_PrivKey.ConnectToNewObject("Chilkat.PrivateKey")
li_Success = loo_PrivKey.LoadAnyFormatFile("qa_data/certs_and_keys/union_client_certificate.nopass.key","")
if li_Success = 0 then
Write-Debug loo_PrivKey.LastErrorText
destroy loo_Http
destroy loo_JToken
destroy loo_Cert
destroy loo_PrivKey
return
end if
// Associate the private key with the cert.
// This will fail if the private key is not actually the correct one that corresponds to the public key stored within the cert.
li_Success = loo_Cert.SetPrivateKey(loo_PrivKey)
if li_Success = 0 then
Write-Debug loo_Cert.LastErrorText
destroy loo_Http
destroy loo_JToken
destroy loo_Cert
destroy loo_PrivKey
return
end if
// Tell HTTP to use the cert for client TLS certificate authentication.
li_Success = loo_Http.SetSslClientCert(loo_Cert)
if li_Success = 0 then
Write-Debug loo_Http.LastErrorText
destroy loo_Http
destroy loo_JToken
destroy loo_Cert
destroy loo_PrivKey
return
end if
loo_SbResponseBody = create oleobject
li_rc = loo_SbResponseBody.ConnectToNewObject("Chilkat.StringBuilder")
li_Success = loo_Http.QuickGetSb("https://api-test.rsap.ca/members/status",loo_SbResponseBody)
if li_Success = 0 then
Write-Debug loo_Http.LastErrorText
destroy loo_Http
destroy loo_JToken
destroy loo_Cert
destroy loo_PrivKey
destroy loo_SbResponseBody
return
end if
loo_JResp = create oleobject
li_rc = loo_JResp.ConnectToNewObject("Chilkat.JsonObject")
loo_JResp.LoadSb(loo_SbResponseBody)
loo_JResp.EmitCompact = 0
Write-Debug "Response Body:"
Write-Debug loo_JResp.Emit()
li_RespStatusCode = loo_Http.LastStatus
Write-Debug "Response Status Code = " + string(li_RespStatusCode)
if li_RespStatusCode >= 400 then
Write-Debug "Response Header:"
Write-Debug loo_Http.LastHeader
Write-Debug "Failed."
destroy loo_Http
destroy loo_JToken
destroy loo_Cert
destroy loo_PrivKey
destroy loo_SbResponseBody
destroy loo_JResp
return
end if
destroy loo_Http
destroy loo_JToken
destroy loo_Cert
destroy loo_PrivKey
destroy loo_SbResponseBody
destroy loo_JResp