Tcl
Tcl
Isabel Connect List Accounts
See more Ibanity Examples
Get a list of accounts.Chilkat Tcl Downloads
load ./chilkat.dll
set success 0
# This example assumes the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.
set http [new_CkHttp]
# Implements the following CURL command:
# curl -X GET https://api.ibanity.com/isabel-connect/accounts \
# --cert certificate.pem:qwertyuiop1 \
# --key private_key.pem \
# -H "Authorization: Bearer access_token_1603365407" \
# -H "Accept: application/vnd.api+json"
# Ibanity provides the certificate + private key in PFX format. This example will use the .pfx instead of the pair of PEM files.
# (It is also possible to implement using Chilkat with the PEM files, but PFX is easier.)
set success [CkHttp_SetSslClientCertPfx $http "qa_data/pfx/my_ibanity_certificate.pfx" "my_pfx_password"]
if {$success == 0} then {
puts [CkHttp_lastErrorText $http]
delete_CkHttp $http
exit
}
# Load the previously obtained access token.
set jsonToken [new_CkJsonObject]
set success [CkJsonObject_LoadFile $jsonToken "qa_data/tokens/isabel_access_token.json"]
if {$success == 0} then {
puts "No existing access token."
delete_CkHttp $http
delete_CkJsonObject $jsonToken
exit
}
# This causes the "Authorization: Bearer ***" header to be added to the HTTP request.
CkHttp_put_AuthToken $http [CkJsonObject_stringOf $jsonToken "access_token"]
CkHttp_put_Accept $http "application/vnd.api+json"
set jsonStr [CkHttp_quickGetStr $http "https://api.ibanity.com/isabel-connect/accounts"]
if {[CkHttp_get_LastMethodSuccess $http] == 0} then {
puts [CkHttp_lastErrorText $http]
delete_CkHttp $http
delete_CkJsonObject $jsonToken
exit
}
set jResp [new_CkJsonObject]
CkJsonObject_Load $jResp $jsonStr
CkJsonObject_put_EmitCompact $jResp 0
puts "Response Body:"
puts [CkJsonObject_emit $jResp]
set respStatusCode [CkHttp_get_LastStatus $http]
puts "Response Status Code = $respStatusCode"
if {$respStatusCode >= 400} then {
puts "Response Header:"
puts [CkHttp_lastResponseHeader $http]
puts "Failed."
delete_CkHttp $http
delete_CkJsonObject $jsonToken
delete_CkJsonObject $jResp
exit
}
# Sample JSON response:
# (Sample code for parsing the JSON response is shown below)
# {
# "data": [
# {
# "id": "93ecb1fdbfb7848e7b7896c0f2d207aed3d8b4c1",
# "type": "account"
# }
# ],
# "meta": {
# "paging": {
# "offset": 0,
# "total": 1
# }
# }
# }
# Sample code for parsing the JSON response...
# Use the following online tool to generate parsing code from sample JSON:
# Generate Parsing Code from JSON
set metaPagingOffset [CkJsonObject_IntOf $jResp "meta.paging.offset"]
set metaPagingTotal [CkJsonObject_IntOf $jResp "meta.paging.total"]
set i 0
set count_i [CkJsonObject_SizeOfArray $jResp "data"]
while {$i < $count_i} {
CkJsonObject_put_I $jResp $i
set id [CkJsonObject_stringOf $jResp "data[i].id"]
set v_type [CkJsonObject_stringOf $jResp "data[i].type"]
set i [expr $i + 1]
}
delete_CkHttp $http
delete_CkJsonObject $jsonToken
delete_CkJsonObject $jResp