/bank-account-to-sheets

Google Apps Scripts to automatically import bank account transactions into Google Sheets via Plaid.

Primary LanguageJavaScriptGNU General Public License v3.0GPL-3.0

Bank Account to Google Sheets

This is a Google Apps script that imports transactions from one or more bank accounts into Google Sheets via Plaid. It displays them in reverse chronological order (newest first) along with a current total. Transactions are dated, named and categorised, and distinction is given to those that are pending (and therefore might change). A summary sheet is also available that groups transactions by week, and divides this into categories of interest. Updates can be made by the user manually or scheduled to occur automatically.

Setup

You'll need to sign-up for a developer account on Plaid (here). You'll be prompted to create a 'team' and then granted immediate access to the 'Sandbox' environment, which uses test data. However, in order to use this app you'll need to request access to the 'Development' environment (here), which will allow you to create up to 100 access tokens (each authorisation with an institution requires an access token). This will take a day or so to be approved.

Getting an Access Token

You'll find the client ID and the secret for the development environment on the keys page for your team (here). Once you've got access to the 'Development' environment, you'll need to create an access token that grants your 'team' (or app) access to your own bank account(s).

The simplest way to do this is by following their Quickstart guide here: https://plaid.com/docs/quickstart/. You'll need to use the 'Development' environment instead of the 'Sandbox', and set PLAID_PRODUCTS to auth,transactions. I did it without Docker, and whilst it is a bit fiddly, it does work eventually. Once you've granted it access to your own bank account(s), you'll be presented with an access token that you can use in these scripts.

Creating the Google Sheet

These scripts are designed to work with a specific Google Sheets template, which you can make your own copy of here: https://docs.google.com/spreadsheets/d/1NzR1d8vzlPR0yxO-hRV37KB_dBkDRt1fnbDbeGXWT-w/copy. Once you've done that, you can easily add the scripts and start importing your transactions.

  1. Make a copy of the Google Sheet above and open it. Don't worry about the example transactions, they'll be removed when you import your own.
  2. Go to Tools -> Script Editor, which should open a new Apps Script project.
  3. Remove anything that's in the editor already, and copy in the contents of code.gs.
  4. At the top-left, click the + next to Files to create a new script file, and name it secrets.
  5. Copy the contents of secrets.gs into this new file.
  6. Add your own client ID, secret, and access token.
  7. Save it.
  8. Refresh the Google Sheet. This might close the editor (which is fine).
  9. A new menu named Scripts should appear in the menu bar.
  10. Clicking the Update Transactions option within this menu should download all of your transactions into the 'Transactions' sheet, with a summary automatically generated in the 'Weekly Summary' sheet.

Optionally, you can create a time-driven trigger to run the updateTransactions() function automatically on a regular basis (e.g., hourly).

Assumptions & Limitations

  • Currently, this only supports one access token, so you can only grant access to one institution. The spreadsheet does, however, support multiple accounts within that institution (e.g. a current account and a credit card).
  • Plaid only updates its list of transactions (from the bank) every six hours or so, which means that new transactions might not appear instantly. I've been unable to get access to /transactions/refresh to try to remove this delay.
  • The access token doesn't expire, however it might need updating if the user (you) changes their password, or when working with European institutions that comply with PSD2's 90-day consent window. This can be done by re-authorising with the quickstart.

Important Points to Note About the Template

  • This template has been designed to work specifically with this script, so you should avoid modifying it (unless you're willing to modify the script too).
  • You can edit a transaction's category, subcategory, channel, internal status, and notes, and these changes will all be preserved when the transactions are updated. Changes to anything else (like the date, or the name) won't be.
  • Transactions marked as internal won't be included on the Weekly Summary sheet (except as part of the ending balance). This is designed for transactions that are transfers to or from your own accounts, and therefore don't represent money gained or spent by you. It's entirely at your discretion what you choose to mark as this.
  • The option to format the Weekly Summary sheet neatly will adjust the hidden rows so that the current week is displayed at the top, and weeks in the future are hidden.
  • You can change the categories on the Weekly Summary sheet to any category or subcategory that you want.
    • Note that Other Shops isn't a category, but instead is the sum of everything categorised as Shops, minus those with the subcategories of Supermarkets and Groceries or Clothing and Accessories.
    • The final categories column, Other, is simply the sum of all transactions, minus those in the displayed categories.
  • The Values sheet simply has a static list of all the available categories and subcategories, as well as list of which category each subcategory maps to.
    • On the Transactions sheet, you don't have to enforce that a transaction's subcategory must come from its category, but it's probably sensible to.

License

GNU GPLv3