Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(PureBasic) RSAP Union API - Get Members StatusDemonstrates how to use an OAuth2 access token for the RSAP Union API. Calls the endpoint to get the statuses of all union members. For more information, see https://app.swaggerhub.com/apis-docs/pderas/RSAP/2.0.1#/Members/getAllUnionMemberStatuses
IncludeFile "CkCert.pb" IncludeFile "CkHttp.pb" IncludeFile "CkStringBuilder.pb" IncludeFile "CkJsonObject.pb" IncludeFile "CkPrivateKey.pb" Procedure ChilkatExample() ; This example assumes the Chilkat API to have been previously unlocked. ; See Global Unlock Sample for sample code. http.i = CkHttp::ckCreate() If http.i = 0 Debug "Failed to create object." ProcedureReturn EndIf success.i ; Load the access token previously obtained by this example: RSAP Union OAuth2 jToken.i = CkJsonObject::ckCreate() If jToken.i = 0 Debug "Failed to create object." ProcedureReturn EndIf success = CkJsonObject::ckLoadFile(jToken,"qa_data/tokens/rsapToken.json") If success = 0 Debug "Failed to load access token JSON." CkHttp::ckDispose(http) CkJsonObject::ckDispose(jToken) ProcedureReturn EndIf ; Adds the "Authorization: Bearer ACCESS_TOKEN" header. CkHttp::setCkAuthToken(http, CkJsonObject::ckStringOf(jToken,"access_token")) ; For authentication, assuming both the client cert and access token are needed??? cert.i = CkCert::ckCreate() If cert.i = 0 Debug "Failed to create object." ProcedureReturn EndIf success = CkCert::ckLoadFromFile(cert,"qa_data/certs_and_keys/union_client_certificate.crt") If success = 0 Debug CkCert::ckLastErrorText(cert) CkHttp::ckDispose(http) CkJsonObject::ckDispose(jToken) CkCert::ckDispose(cert) ProcedureReturn EndIf privKey.i = CkPrivateKey::ckCreate() If privKey.i = 0 Debug "Failed to create object." ProcedureReturn EndIf success = CkPrivateKey::ckLoadAnyFormatFile(privKey,"qa_data/certs_and_keys/union_client_certificate.nopass.key","") If success = 0 Debug CkPrivateKey::ckLastErrorText(privKey) CkHttp::ckDispose(http) CkJsonObject::ckDispose(jToken) CkCert::ckDispose(cert) CkPrivateKey::ckDispose(privKey) ProcedureReturn EndIf ; 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. success = CkCert::ckSetPrivateKey(cert,privKey) If success = 0 Debug CkCert::ckLastErrorText(cert) CkHttp::ckDispose(http) CkJsonObject::ckDispose(jToken) CkCert::ckDispose(cert) CkPrivateKey::ckDispose(privKey) ProcedureReturn EndIf ; Tell HTTP to use the cert for client TLS certificate authentication. success = CkHttp::ckSetSslClientCert(http,cert) If success = 0 Debug CkHttp::ckLastErrorText(http) CkHttp::ckDispose(http) CkJsonObject::ckDispose(jToken) CkCert::ckDispose(cert) CkPrivateKey::ckDispose(privKey) ProcedureReturn EndIf sbResponseBody.i = CkStringBuilder::ckCreate() If sbResponseBody.i = 0 Debug "Failed to create object." ProcedureReturn EndIf success = CkHttp::ckQuickGetSb(http,"https://api-test.rsap.ca/members/status",sbResponseBody) If success = 0 Debug CkHttp::ckLastErrorText(http) CkHttp::ckDispose(http) CkJsonObject::ckDispose(jToken) CkCert::ckDispose(cert) CkPrivateKey::ckDispose(privKey) CkStringBuilder::ckDispose(sbResponseBody) ProcedureReturn EndIf jResp.i = CkJsonObject::ckCreate() If jResp.i = 0 Debug "Failed to create object." ProcedureReturn EndIf CkJsonObject::ckLoadSb(jResp,sbResponseBody) CkJsonObject::setCkEmitCompact(jResp, 0) Debug "Response Body:" Debug CkJsonObject::ckEmit(jResp) respStatusCode.i = CkHttp::ckLastStatus(http) Debug "Response Status Code = " + Str(respStatusCode) If respStatusCode >= 400 Debug "Response Header:" Debug CkHttp::ckLastHeader(http) Debug "Failed." CkHttp::ckDispose(http) CkJsonObject::ckDispose(jToken) CkCert::ckDispose(cert) CkPrivateKey::ckDispose(privKey) CkStringBuilder::ckDispose(sbResponseBody) CkJsonObject::ckDispose(jResp) ProcedureReturn EndIf CkHttp::ckDispose(http) CkJsonObject::ckDispose(jToken) CkCert::ckDispose(cert) CkPrivateKey::ckDispose(privKey) CkStringBuilder::ckDispose(sbResponseBody) CkJsonObject::ckDispose(jResp) ProcedureReturn EndProcedure |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.