Sample code for 30+ languages & platforms
Visual Basic 6.0

Isabel Connect List Transactions

See more Ibanity Examples

Get a list of transactions for an account.

Chilkat Visual Basic 6.0 Downloads

Visual Basic 6.0
Dim success As Long
success = 0

' This example assumes the Chilkat API to have been previously unlocked.
' See Global Unlock Sample for sample code.

Dim http As New ChilkatHttp

' Implements the following CURL command:

' curl -X GET https://api.ibanity.com/isabel-connect/accounts/93ecb1fdbfb7848e7b7896c0f2d207aed3d8b4c1/transactions \
' --cert certificate.pem:qwertyuiop1 \
' --key private_key.pem  \
' -H "Authorization: Bearer access_token_1603365408" \
' -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.)
success = http.SetSslClientCertPfx("qa_data/pfx/my_ibanity_certificate.pfx","my_pfx_password")
If (success = 0) Then
    Debug.Print http.LastErrorText
    Exit Sub
End If

' Load the previously obtained access token.
Dim jsonToken As New ChilkatJsonObject
success = jsonToken.LoadFile("qa_data/tokens/isabel_access_token.json")
If (success = 0) Then
    Debug.Print "No existing access token."
    Exit Sub
End If

' This causes the "Authorization: Bearer ***" header to be added to the HTTP request.
http.AuthToken = jsonToken.StringOf("access_token")

http.Accept = "application/vnd.api+json"

success = http.SetUrlVar("id","93ecb1fdbfb7848e7b7896c0f2d207aed3d8b4c1")
Dim jsonStr As String
jsonStr = http.QuickGetStr("https://api.ibanity.com/isabel-connect/accounts/{$id}/transactions")
If (http.LastMethodSuccess = 0) Then
    Debug.Print http.LastErrorText
    Exit Sub
End If

Dim jResp As New ChilkatJsonObject
success = jResp.Load(jsonStr)
jResp.EmitCompact = 0

Debug.Print "Response Body:"
Debug.Print jResp.Emit()

Dim respStatusCode As Long
respStatusCode = http.LastStatus
Debug.Print "Response Status Code = " & respStatusCode
If (respStatusCode >= 400) Then
    Debug.Print "Response Header:"
    Debug.Print http.LastResponseHeader
    Debug.Print "Failed."
    Exit Sub
End If

' Sample JSON response:
' (Sample code for parsing the JSON response is shown below)

' {
'   "data": [
'     {
'       "attributes": {
'         "amount": 80000,
'         "counterpartAccountReference": "BE21210123456703",
'         "counterpartFinancialInstitutionBic": "GEBABEBB",
'         "counterpartName": "MYBESTCLIENT",
'         "endToEndId": "UNIQUE CODE CUSTOMER",
'         "executionDate": "2018-10-15T08:34:17.417Z",
'         "internalId": "UNIQUE CODE BANK",
'         "remittanceInformation": "123456789002",
'         "remittanceInformationType": "structured-be",
'         "status": "Booked",
'         "valueDate": "2018-10-15T08:52:43.962Z"
'       },
'       "id": "14e2bff5-e365-4bc7-bf48-76b7bcd464e9",
'       "type": "transaction"
'     },
'     {
'       "attributes": {
'         "amount": 40000,
'         "counterpartAccountReference": "BE58400101010179",
'         "counterpartFinancialInstitutionBic": "KREDBEBB",
'         "counterpartName": "MYGOODCLIENT",
'         "endToEndId": null,
'         "executionDate": "2018-10-15T08:34:17.417Z",
'         "internalId": null,
'         "remittanceInformation": "FREE COMMUNICATION",
'         "remittanceInformationType": "unstructured",
'         "status": "Booked",
'         "valueDate": "2018-10-15T08:52:43.962Z"
'       },
'       "id": "29b0f52e-a389-4ff8-88e1-cc30c12b789f",
'       "type": "transaction"
'     },
'     {
'       "attributes": {
'         "amount": -20000,
'         "counterpartAccountReference": "BE56300694353788",
'         "counterpartFinancialInstitutionBic": null,
'         "counterpartName": "MY SUPPLIER",
'         "endToEndId": null,
'         "executionDate": "2018-10-15T08:34:17.417Z",
'         "internalId": null,
'         "remittanceInformation": "999000000171",
'         "remittanceInformationType": "structured-be",
'         "status": "Booked",
'         "valueDate": "2018-10-15T08:52:43.962Z"
'       },
'       "id": "7d79a28e-b45d-4595-b98e-7c18871ee208",
'       "type": "transaction"
'     }
'   ],
'   "meta": {
'     "paging": {
'       "offset": 0,
'       "total": 3
'     }
'   }
' }

' Sample code for parsing the JSON response...
' Use the following online tool to generate parsing code from sample JSON:
' Generate Parsing Code from JSON

Dim attributesAmount As Long
Dim attributesCounterpartAccountReference As String
Dim attributesCounterpartFinancialInstitutionBic As String
Dim attributesCounterpartName As String
Dim attributesEndToEndId As String
Dim attributesExecutionDate As String
Dim attributesInternalId As String
Dim attributesRemittanceInformation As String
Dim attributesRemittanceInformationType As String
Dim attributesStatus As String
Dim attributesValueDate As String
Dim id As String
Dim v_type As String

Dim metaPagingOffset As Long
metaPagingOffset = jResp.IntOf("meta.paging.offset")
Dim metaPagingTotal As Long
metaPagingTotal = jResp.IntOf("meta.paging.total")
Dim i As Long
i = 0
Dim count_i As Long
count_i = jResp.SizeOfArray("data")
Do While i < count_i
    jResp.I = i
    attributesAmount = jResp.IntOf("data[i].attributes.amount")
    attributesCounterpartAccountReference = jResp.StringOf("data[i].attributes.counterpartAccountReference")
    attributesCounterpartFinancialInstitutionBic = jResp.StringOf("data[i].attributes.counterpartFinancialInstitutionBic")
    attributesCounterpartName = jResp.StringOf("data[i].attributes.counterpartName")
    attributesEndToEndId = jResp.StringOf("data[i].attributes.endToEndId")
    attributesExecutionDate = jResp.StringOf("data[i].attributes.executionDate")
    attributesInternalId = jResp.StringOf("data[i].attributes.internalId")
    attributesRemittanceInformation = jResp.StringOf("data[i].attributes.remittanceInformation")
    attributesRemittanceInformationType = jResp.StringOf("data[i].attributes.remittanceInformationType")
    attributesStatus = jResp.StringOf("data[i].attributes.status")
    attributesValueDate = jResp.StringOf("data[i].attributes.valueDate")
    id = jResp.StringOf("data[i].id")
    v_type = jResp.StringOf("data[i].type")
    i = i + 1
Loop