To help people manage their finances in the Toshl Finance apps, we connect to banks with the help of our connection partners. Where available, the data is imported over APIs – official automatic connections, provided by the bank. In the European Union, banks need to provide such connectivity by law (PSD2). Where API connections are not available, data is imported through the transactions lists in online banking apps.
While not perfect, such legislation is a big step forward in enabling people to use their data as they please. Unfortunately, a lot of banks still provide very poorly made APIs or not at all. By doing that, they’re not only doing a disservice to their customers and themselves, but in many cases are also breaking national and EU legislation. The final deadline for all EU banks to have a fully functional API to import transactions and accounts was September 14 2019.
With the hopes of this situation improving and better informing our customers about the (in)capabilities of individual institutions, we are starting this list of shitty banks based on the performance of their APIs. These banks have shown major errors and persistence in not fixing them, despite our reports and those via our connection partners.
Shitty Banks 💩
Shitty banks in the EU and UK
These financial institutions are bound by PSD2 or similar legislation and are likely breaking national and EU law by being this shitty.
N26 (EU, banking licence in Germany): The bank stopped reporting correct dates of transactions. They report only the settled date of the transaction, which is usually 3-4 days after the actual purchase. N26 initially refused to make changes and claimed all is well, when pressed further they say they might schedule this for future improvements. In the meantime, they show correct dates in their own apps. Frequent issues previously, like duplication of transactions, not working authorisation flows and similar. While these have since been resolved, the bank is a frequent offender who does not hold up to their legal obligations as per PSD2.
Solaris Bank (EU, banking licence in Germany): The bank introduced a bug which prevents users from connecting their accounts. We’ve reported the issue via our connection partners in December 2021. Solaris Bank still hasn’t resolved the issue by May 5th 2022. Bank’s representatives stopped replying to reports.
NewDay cards, such as; Aqua Card, Pulse Card, Amazon Mastercard and all other NewDay cards (United Kingdom): The card company only allows for the initial connection, no updates of the card data. Some card connections have faulty authentication systems to boot.
Argenta (Belgium) The bank is extremely slow with onboarding new certificates that enable us to connect. This is something that should be done automatically via dynamic registration to begin with, something that most other banks offer. While the bank representatives are unresponsive, our customers are unable to connect. We’ve been reporting the issue since Aug 2022.
Openbank (Spain): The bank has historically been quite shitty by producing many authentication issues on their end, inability to provide transactions consistently. They also refuse to provide pending card transactions (pending, but not yet settled), despite displaying them in their own apps. This means that the transactions are not provided until 3-4 days after purchase.
NKBM (Slovenia) They’re on this list very frequently. After producing month-long downtimes and often faulty log in systems, they’ve now decided to stop even replying to multiple requests to fix proven issues and bugs on their end. They should feel shame, but we doubt they have any capacity for it left. Despicable.
Gorenjska Banka (Slovenia) The bank does not provide transactions immediately, as they do in their own apps. The transactions are provided over the PSD2 API only 3-4 days later in violation of the PSD2 legislation.
Intesa Sanpaolo (Slovenia) An unfortunate frequent flyer on this list. The bank first took years to provide a working API, but continues to support it poorly. With the last update, they caused a several day downtime. Errors continued after the first few batches of fixes and currently remain unresolved. The bank’s own apps are incredibly buggy as well. The latest problem is with Intesa’s Android apps which don’t send the authentication notification and users thus cannot connect.
Aktia (Finland) The bank is not responding to request to resolve issues with their PSD2 API authentication system.
BRD (Romania) Another bank way too frequently on this list. Bank representatives respond very slowly if at all, making their frequent technical issues even more difficult to resolve.
UniCredit (Slovenia) Bank duplicates certain transactions and sends them again via the connection almost 2 months after they were originally reported.
MeDirect (Belgium) Frequent technical issues, bank representatives very slow to respond.
Pekao (Poland) Bank has a manual process for updating certificates. After issues with certificate update the bank representatives failed to respond to resolve issues.
Independently shitty banks
These banks are not bound by legislation to provide automatic connections, but display a generally shitty attitude towards their customers by blocking importing data to 3rd party apps such as ours. Data about own transactions belongs to the user, not the bank.
BBVA Frances (Argentina): The bank is actively trying to prevent its customers from using their data, blocking screen scraping with legal and technical means while not providing a transactions API to import in an officially approved manner.
Raiffeisen Aval (Ukraine): The bank is actively trying to prevent its customers from using their data, blocking screen scraping with legal and technical means while not providing a transactions API to import in an officially approved manner.
DBS (Singapore, Hong Kong): The bank is actively trying to prevent its customers from using their data, blocking screen scraping with legal and technical means while not providing a transactions API to import in an officially approved manner.
BDO (Philippines): The bank is actively trying to prevent its customers from using their data, blocking screen scraping with legal and technical means while not providing a transactions API to import in an officially approved manner.
PrivatBank (Ukraine): After initially offering an official API for customers to be able to import their own data, the bank abruptly cancelled all API access for customers with personal accounts. As they also try quite hard at blocking screen scraping, the bank is now preventing their customers from using their own data with other apps.
Citibank (Singapore): The bank was blocking scraping connections, trying to prevent its customers from using their data. Then, theoretically opened an API for transactions. However, this API isn’t freely available and requires an agreement with the bank. Citi is dragging their feet, responding very slowly, if at all, to requests to integrate. The latest response was that they are not commercially interested in providing the API. The API seems more of a PR tactic rather than something that can be actually used. Prove us wrong, please.
Special shitty distinction
Plaid, one of our connection partners for serving this as their most common reply: “We have prioritized this issue based on our evaluation of the user impact and its severity. We’re currently unable to give an exact fix date for this issue, however, we will update you here once this issue is resolved or we have a more exact ETA — whichever comes first. In the meantime, I am placing this ticket on-hold while this issue is being monitored so that we may follow up. Please keep in mind that these types of issues may take 1-3+ months to be resolved.”
Token.io they’re an integrator of APIs for the banks. Poor one at that. Any hope of a working solution dwindles once they’re mentioned. The cause of many non-working authentication systems of bank connections. They’re slow to respond, don’t offer dynamic registration and keep on pushing their own accounts in addition to the credentials you have at the bank.
General problems with PSD2 legislation
- Banks are not obliged to provide all user’s financial accounts. “Payment accounts” as interpreted by the European Banking Authority only include bank accounts (those with an IBAN), but not credit cards or savings accounts. Due to this many banks chose not to include them in their APIs, making the API solution sometimes worse than the scraping it was supposed to replace.
- Business accounts are not included by law, making them optional for the banks. Only payment accounts of individuals are included.
- Requirements to register as an Account Information Service Provider (AISP) or Payment Initiation Service Provider (PISP) with the banking regulator are too vast and sometimes of questionable usefulness. Disproportional cost and time needed to register. So far these regulations contributed to an extended downtime of services, somewhat ironically, as they were made to prevent such circumstances.
- Vastly different technical implementations between banks / countries, with the Berlin standard being especially problematic. Especially problematic implementations are where IBANs need to be entered upfront, re-authorisation sometimes poorly implemented due to that, difficult to add multiple accounts.
- Lack of unified system of onboarding account information service providers (AISP) to be able to import data and start doing so automatically. Dynamic registration with fully automated recognition of QWAC and QSeals certificates should be the only legal way.
- Updating QWAC certificates is still a somewhat manual process in many cases, with banks demanding re-registrations or producing errors during verification of renewed certificates.
Banks who were previously featured here, but got their shit together and now offer working APIs. We congratulate and send thanks for the fixes. 👏
Privredna Banka Zagreb (Croatia)
Flik as authentication (Slovenia) is no longer required by banks.
Sparkasse (Slovenia) now working well in most cases, minor description discrepancies remain. Otherwise responsive with fixes.
Bunq had authentication issues which were not resolved for months in the first half of 2022. Now fixed.
OTP (Hungary) had authentication bugs that lasted from Sep 2021 until May 2022, now resolved.
SKB (Slovenia) bank responded in the end, long standing re-auth issues were resolved.
Easybank (Austria) issues we resolved, no active reports of problems.
KBC (Ireland) the issues were not resolved insomuch as the bank wimped out. KBC withdrew from the Irish market and are no longer offering their services there. Good riddance.
1822direkt (Germany) the bank representatives did not reply for a month and a half to reports of faulty authentication and required public prodding to reply. Issue now resolved.
Erste (Hungary) had broken authentication for years and was poorly responsive, however was finally fixed early 2023.
Bitstamp (EU) had broken API authentication for almost 2 years, did not respond to calls to fix until regulators got involved. New API provided from April 2023.
Wise Business (EU, registered in Belgium) Pending transactions were missing on API, issues fixed about a year after reporting.
Last updated on May 29, 2023