Sample code for 30+ languages & platforms
Delphi ActiveX

Isabel Connect List Transactions

See more Ibanity Examples

Get a list of transactions for an account.

Chilkat Delphi ActiveX Downloads

Delphi ActiveX
uses
    Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
    Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Chilkat_TLB;

...

procedure TForm1.Button1Click(Sender: TObject);
var
success: Integer;
http: TChilkatHttp;
jsonToken: TChilkatJsonObject;
jsonStr: WideString;
jResp: TChilkatJsonObject;
respStatusCode: Integer;
attributesAmount: Integer;
attributesCounterpartAccountReference: WideString;
attributesCounterpartFinancialInstitutionBic: WideString;
attributesCounterpartName: WideString;
attributesEndToEndId: WideString;
attributesExecutionDate: WideString;
attributesInternalId: WideString;
attributesRemittanceInformation: WideString;
attributesRemittanceInformationType: WideString;
attributesStatus: WideString;
attributesValueDate: WideString;
id: WideString;
v_type: WideString;
metaPagingOffset: Integer;
metaPagingTotal: Integer;
i: Integer;
count_i: Integer;

begin
success := 0;

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

http := TChilkatHttp.Create(Self);

// 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
  begin
    Memo1.Lines.Add(http.LastErrorText);
    Exit;
  end;

// Load the previously obtained access token.
jsonToken := TChilkatJsonObject.Create(Self);
success := jsonToken.LoadFile('qa_data/tokens/isabel_access_token.json');
if (success = 0) then
  begin
    Memo1.Lines.Add('No existing access token.');
    Exit;
  end;

// 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';

http.SetUrlVar('id','93ecb1fdbfb7848e7b7896c0f2d207aed3d8b4c1');
jsonStr := http.QuickGetStr('https://api.ibanity.com/isabel-connect/accounts/{$id}/transactions');
if (http.LastMethodSuccess = 0) then
  begin
    Memo1.Lines.Add(http.LastErrorText);
    Exit;
  end;

jResp := TChilkatJsonObject.Create(Self);
jResp.Load(jsonStr);
jResp.EmitCompact := 0;

Memo1.Lines.Add('Response Body:');
Memo1.Lines.Add(jResp.Emit());

respStatusCode := http.LastStatus;
Memo1.Lines.Add('Response Status Code = ' + IntToStr(respStatusCode));
if (respStatusCode >= 400) then
  begin
    Memo1.Lines.Add('Response Header:');
    Memo1.Lines.Add(http.LastResponseHeader);
    Memo1.Lines.Add('Failed.');
    Exit;
  end;

// 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

metaPagingOffset := jResp.IntOf('meta.paging.offset');
metaPagingTotal := jResp.IntOf('meta.paging.total');
i := 0;
count_i := jResp.SizeOfArray('data');
while i < count_i do
  begin
    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;
  end;
end;