Visual FoxPro
Visual FoxPro
Isabel Connect List Accounts
See more Ibanity Examples
Get a list of accounts.Chilkat Visual FoxPro Downloads
LOCAL lnSuccess
LOCAL loHttp
LOCAL loJsonToken
LOCAL lcJsonStr
LOCAL loJResp
LOCAL lnRespStatusCode
LOCAL lcId
LOCAL lcV_type
LOCAL lnMetaPagingOffset
LOCAL lnMetaPagingTotal
LOCAL i
LOCAL lnCount_i
lnSuccess = 0
* This example assumes the Chilkat API to have been previously unlocked.
* See Global Unlock Sample for sample code.
loHttp = CreateObject('Chilkat.Http')
* 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.)
lnSuccess = loHttp.SetSslClientCertPfx("qa_data/pfx/my_ibanity_certificate.pfx","my_pfx_password")
IF (lnSuccess = 0) THEN
? loHttp.LastErrorText
RELEASE loHttp
CANCEL
ENDIF
* Load the previously obtained access token.
loJsonToken = CreateObject('Chilkat.JsonObject')
lnSuccess = loJsonToken.LoadFile("qa_data/tokens/isabel_access_token.json")
IF (lnSuccess = 0) THEN
? "No existing access token."
RELEASE loHttp
RELEASE loJsonToken
CANCEL
ENDIF
* This causes the "Authorization: Bearer ***" header to be added to the HTTP request.
loHttp.AuthToken = loJsonToken.StringOf("access_token")
loHttp.Accept = "application/vnd.api+json"
lcJsonStr = loHttp.QuickGetStr("https://api.ibanity.com/isabel-connect/accounts")
IF (loHttp.LastMethodSuccess = 0) THEN
? loHttp.LastErrorText
RELEASE loHttp
RELEASE loJsonToken
CANCEL
ENDIF
loJResp = CreateObject('Chilkat.JsonObject')
loJResp.Load(lcJsonStr)
loJResp.EmitCompact = 0
? "Response Body:"
? loJResp.Emit()
lnRespStatusCode = loHttp.LastStatus
? "Response Status Code = " + STR(lnRespStatusCode)
IF (lnRespStatusCode >= 400) THEN
? "Response Header:"
? loHttp.LastResponseHeader
? "Failed."
RELEASE loHttp
RELEASE loJsonToken
RELEASE loJResp
CANCEL
ENDIF
* 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
lnMetaPagingOffset = loJResp.IntOf("meta.paging.offset")
lnMetaPagingTotal = loJResp.IntOf("meta.paging.total")
i = 0
lnCount_i = loJResp.SizeOfArray("data")
DO WHILE i < lnCount_i
loJResp.I = i
lcId = loJResp.StringOf("data[i].id")
lcV_type = loJResp.StringOf("data[i].type")
i = i + 1
ENDDO
RELEASE loHttp
RELEASE loJsonToken
RELEASE loJResp