Sample code for 30+ languages & platforms
Visual FoxPro

Isabel Connect List Accounts

See more Ibanity Examples

Get a list of accounts.

Chilkat Visual FoxPro Downloads

Visual FoxPro
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