Perl
Perl
Isabel Connect List Transactions
See more Ibanity Examples
Get a list of transactions for an account.Chilkat Perl Downloads
use chilkat();
$success = 0;
# This example assumes the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.
$http = chilkat::CkHttp->new();
# 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) {
print $http->lastErrorText() . "\r\n";
exit;
}
# Load the previously obtained access token.
$jsonToken = chilkat::CkJsonObject->new();
$success = $jsonToken->LoadFile("qa_data/tokens/isabel_access_token.json");
if ($success == 0) {
print "No existing access token." . "\r\n";
exit;
}
# This causes the "Authorization: Bearer ***" header to be added to the HTTP request.
$http->put_AuthToken($jsonToken->stringOf("access_token"));
$http->put_Accept("application/vnd.api+json");
$http->SetUrlVar("id","93ecb1fdbfb7848e7b7896c0f2d207aed3d8b4c1");
$jsonStr = $http->quickGetStr("https://api.ibanity.com/isabel-connect/accounts/{$id}/transactions");
if ($http->get_LastMethodSuccess() == 0) {
print $http->lastErrorText() . "\r\n";
exit;
}
$jResp = chilkat::CkJsonObject->new();
$jResp->Load($jsonStr);
$jResp->put_EmitCompact(0);
print "Response Body:" . "\r\n";
print $jResp->emit() . "\r\n";
$respStatusCode = $http->get_LastStatus();
print "Response Status Code = " . $respStatusCode . "\r\n";
if ($respStatusCode >= 400) {
print "Response Header:" . "\r\n";
print $http->lastResponseHeader() . "\r\n";
print "Failed." . "\r\n";
exit;
}
# 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) {
$jResp->put_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;
}