Skip to main content

Transactions

To access transactions, use the Transactions API endpoint. The transactions are sent as a collection of transactions within a data array and a nextPageToken. The last page returns a null value for nextPageToken.

Transaction history

After a user provides consent to a bank, transactions are fetched from the bank to EnableNow with a maximum of 18 months of transaction history.

Structure

{
"data": [
{
"id": "aeeffb5c-4800-5f6f-8797-7f488351553d",
"accountNumber": "NL12ABNA9999876523",
"accountId": "faa409f9-ff20-4462-4729-08dbfaecde2e",
"description": "Description",
"bookDate": "2021-12-23",
"transactionDateTime": "2021-12-23T21:40:38.26Z",
"amount": 229.6,
"balanceAfterTransaction": 1229.82,
"currency": "EUR",
"counterpartDescription": "ACME Inc.",
"counterpartAccountNumber": "NL28ABNA9998422205",
"providerProperties": {
"providerKey": "ABNANL2A",
"transactionId": "GT020008680598410AO",
"transactionType": "658",
"transactionTypeName": null,
"reasonCode": null,
"purposeCode": null,
"balanceAfterTransaction": 1229.82
},
"category": {
"l0Name": "Retail",
"l1Name": "Inflows",
"l2Name": "Income",
"l3Name": "Fixed income",
"code": "R010101"
}
},
{
"id": "d8906f3a-5128-54cf-840f-1a82c5562b73",
"accountNumber": "NL12ABNA9999876523",
"accountId": "faa409f9-ff20-4462-4729-08dbfaecde2e",
"description": "Description",
"bookDate": "2021-12-23",
"transactionDateTime": "2021-12-23T21:40:38.31Z",
"amount": -181.5,
"balanceAfterTransaction": 1000.22,
"currency": "EUR",
"counterpartDescription": "ACME Inc.",
"counterpartAccountNumber": "NL04INGB9999552978",
"providerProperties": {
"providerKey": "ABNANL2A",
"transactionId": "9855P5427870677S0AQ",
"transactionType": "654",
"transactionTypeName": null,
"reasonCode": null,
"purposeCode": null,
"balanceAfterTransaction": 1000.22
},
"category": {
"l0Name": "Retail",
"l1Name": "Inflows",
"l2Name": "Income",
"l3Name": "Variable income",
"code": "R010102"
}
}
],
"nextPageToken": "wjUIWnL2qgXbmjdq"
}

Inside the data collection, the transaction object consists of the following properties:

PropertyTypeAvailabilityDescription
idUUIDRequiredUnique ID for this transaction.
accountIdUUIDRequiredUnique EnableNow account ID for this account.
accountNumberstringOptionalAccount IBAN number for this transaction in uppercase. Can be null for accounts which have no IBAN number (i.e. savings accounts).
descriptionstringRequiredThe description of the transaction.
bookDatestringRequiredThe booking date of the transaction, in the structure YYYY-MM-DD.
transactionDateTimestringRequiredDateTime of the transaction in UTC time, ISO 8601 notation like: 2024-12-24T09:17:40.524Z.
Note: the fractional seconds are optional and are not available on all banks.
Some banks only provide the date, not the time of a transaction, in that case we provide a string where time is 00:00:00Z, like: 2024-12-24T00:00:00Z
Refer to the Fields per provider table to check the structure in which banks provide this field.
amountdecimalRequiredThe amount of this transaction, this value is negative for debit transactions.
balanceAfterTransactiondecimalOptionalWhen balance data is provided by the provider, this is the calculated balance after this transaction. This value is negative for negative balances.
currencystringRequiredISO 3 letter currency value in uppercase (e.g. EUR, USD, etc.).
counterpartDescriptionstringOptionalDescription of the counterpart party.
counterpartAccountNumberstringOptionalAccount IBAN number of the counterpart party in uppercase.

The category object is only returned when you are using the Categorization features and a Categorization Job has run for the selected transactions. For more information about the structure of the category object, refer to the Categorization documentation.

Provider Properties

Provider properties is an object with properties that contain specific (meta)data related to the transaction. Not all banks provide all details.

info

The structure and content of the provider properties object are subject to change. Banks may alter the way they provide additional metadata about transactions, which can affect the properties available within this object. It's important to note that these properties can be modified or new ones can be added without any changes to our API. This means integrations using provider properties should be designed with flexibility and resilience in mind to handle potential modifications seamlessly.

PropertyTypeAvailabilityDescription
providerKeystringRequiredThe bank identifier.
transactionIdstringOptionalUnique ID from the bank for this transaction.
transactionTypestringOptionalThe bank specific mutation of type code of this transaction.
transactionTypeNamestringOptionalThe bank specific mutation of type name of this transaction.
reasonCodestringOptionalThe bank specific reason code of this transaction. Reason codes are used to provide details about errors regarding direct debits.
purposeCodestringOptionalThe bank specific purpose code of this transaction. Purpose codes allow a user to classify payments by informing the bank about the purpose for the credit transfer, e.g. Salary, Savings, Rent, etc.
balanceAfterTransactiondecimalOptionalThe account balance after the transaction.
remittanceInfostringOptionalStructured remittance information refers to a set of predefined and standardized data fields included in a payment message, used to provide specific details about the transaction, such as invoice numbers, payment references, or other identifiers.
remittanceInfoTypestringOptionalThe type of the structured remittance information (example: SCOR).
remittanceInfoIssuerstringOptionalThe identification of the issuer of the reference document type (example: ISO).

Fields per provider

The currently available fields and mappings from the raw PSD2 output is specified below per provider:

Bank / ProviderTransaction TypeTransaction Type NameReason CodePurpose CodeRemittance InfoRemittance Info TypeRemittance Info IssuerTransaction Date/Time
EnableNow Sandbox BankNot availableNot availableNot availableNot availableNot availableNot availableNot availableDate & time without fractional seconds
ABN AMROMutationCodeNot availableNot availableNot availableNot availableNot availableNot availableDate & time with fractional seconds
RabobankRaboDetailedTransactionTypeRaboTransactionTypeNameReasonCodePurposeCoderemittanceInformationStructuredNot availableNot availableDate & time with fractional seconds
INGNot availableTransactionTypeNot availableNot availableremittanceInformationStructured.referenceremittanceInformationStructured.referenceTyperemittanceInformationStructured.referenceIssuerDate & time without fractional seconds
KnabNot availableProprietaryBankTransactionCodeNot availableNot availableremittanceInformationStructuredNot availableNot availableDate only
SNS BankBankTransactionCodeProprietaryBankTransactionCodeReturnInformationCodePurposeCoderemittanceInformationStructured.referenceNot availableremittanceInformationStructured.referenceIssuerDate only
ASN BankBankTransactionCodeProprietaryBankTransactionCodeReturnInformationCodePurposeCoderemittanceInformationStructured.referenceNot availableremittanceInformationStructured.referenceIssuerDate only
RegioBankBankTransactionCodeProprietaryBankTransactionCodeReturnInformationCodePurposeCoderemittanceInformationStructured.referenceNot availableremittanceInformationStructured.referenceIssuerDate only
BunqSubTypeTypeNot availableNot availableNot availableNot availableNot availableDate & time with fractional seconds
Van LanschotNot availableProprietaryBankTransactionCodeNot availableNot availableNot availableNot availableNot availableDate & time with fractional seconds
TriodosNot availableProprietaryBankTransactionCodeNot availableNot availableNot availableNot availableNot availableDate only
RevolutProprietaryBankTransactionCode.CodeNot availableNot availableNot availableNot availableNot availableNot availableDate & time with fractional seconds