Delphi DLL
Delphi DLL
Isabel Connect List Transactions
See more Ibanity Examples
Get a list of transactions for an account.Chilkat Delphi DLL Downloads
uses
Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, JsonObject, Http;
...
procedure TForm1.Button1Click(Sender: TObject);
var
success: Boolean;
http: HCkHttp;
jsonToken: HCkJsonObject;
jsonStr: PWideChar;
jResp: HCkJsonObject;
respStatusCode: Integer;
attributesAmount: Integer;
attributesCounterpartAccountReference: PWideChar;
attributesCounterpartFinancialInstitutionBic: PWideChar;
attributesCounterpartName: PWideChar;
attributesEndToEndId: PWideChar;
attributesExecutionDate: PWideChar;
attributesInternalId: PWideChar;
attributesRemittanceInformation: PWideChar;
attributesRemittanceInformationType: PWideChar;
attributesStatus: PWideChar;
attributesValueDate: PWideChar;
id: PWideChar;
v_type: PWideChar;
metaPagingOffset: Integer;
metaPagingTotal: Integer;
i: Integer;
count_i: Integer;
begin
success := False;
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
http := CkHttp_Create();
// 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 := CkHttp_SetSslClientCertPfx(http,'qa_data/pfx/my_ibanity_certificate.pfx','my_pfx_password');
if (success = False) then
begin
Memo1.Lines.Add(CkHttp__lastErrorText(http));
Exit;
end;
// Load the previously obtained access token.
jsonToken := CkJsonObject_Create();
success := CkJsonObject_LoadFile(jsonToken,'qa_data/tokens/isabel_access_token.json');
if (success = False) then
begin
Memo1.Lines.Add('No existing access token.');
Exit;
end;
// This causes the "Authorization: Bearer ***" header to be added to the HTTP request.
CkHttp_putAuthToken(http,CkJsonObject__stringOf(jsonToken,'access_token'));
CkHttp_putAccept(http,'application/vnd.api+json');
CkHttp_SetUrlVar(http,'id','93ecb1fdbfb7848e7b7896c0f2d207aed3d8b4c1');
jsonStr := CkHttp__quickGetStr(http,'https://api.ibanity.com/isabel-connect/accounts/{$id}/transactions');
if (CkHttp_getLastMethodSuccess(http) = False) then
begin
Memo1.Lines.Add(CkHttp__lastErrorText(http));
Exit;
end;
jResp := CkJsonObject_Create();
CkJsonObject_Load(jResp,jsonStr);
CkJsonObject_putEmitCompact(jResp,False);
Memo1.Lines.Add('Response Body:');
Memo1.Lines.Add(CkJsonObject__emit(jResp));
respStatusCode := CkHttp_getLastStatus(http);
Memo1.Lines.Add('Response Status Code = ' + IntToStr(respStatusCode));
if (respStatusCode >= 400) then
begin
Memo1.Lines.Add('Response Header:');
Memo1.Lines.Add(CkHttp__lastResponseHeader(http));
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 := CkJsonObject_IntOf(jResp,'meta.paging.offset');
metaPagingTotal := CkJsonObject_IntOf(jResp,'meta.paging.total');
i := 0;
count_i := CkJsonObject_SizeOfArray(jResp,'data');
while i < count_i do
begin
CkJsonObject_putI(jResp,i);
attributesAmount := CkJsonObject_IntOf(jResp,'data[i].attributes.amount');
attributesCounterpartAccountReference := CkJsonObject__stringOf(jResp,'data[i].attributes.counterpartAccountReference');
attributesCounterpartFinancialInstitutionBic := CkJsonObject__stringOf(jResp,'data[i].attributes.counterpartFinancialInstitutionBic');
attributesCounterpartName := CkJsonObject__stringOf(jResp,'data[i].attributes.counterpartName');
attributesEndToEndId := CkJsonObject__stringOf(jResp,'data[i].attributes.endToEndId');
attributesExecutionDate := CkJsonObject__stringOf(jResp,'data[i].attributes.executionDate');
attributesInternalId := CkJsonObject__stringOf(jResp,'data[i].attributes.internalId');
attributesRemittanceInformation := CkJsonObject__stringOf(jResp,'data[i].attributes.remittanceInformation');
attributesRemittanceInformationType := CkJsonObject__stringOf(jResp,'data[i].attributes.remittanceInformationType');
attributesStatus := CkJsonObject__stringOf(jResp,'data[i].attributes.status');
attributesValueDate := CkJsonObject__stringOf(jResp,'data[i].attributes.valueDate');
id := CkJsonObject__stringOf(jResp,'data[i].id');
v_type := CkJsonObject__stringOf(jResp,'data[i].type');
i := i + 1;
end;
CkHttp_Dispose(http);
CkJsonObject_Dispose(jsonToken);
CkJsonObject_Dispose(jResp);
end;