tvl-depot/tools/monzo_ynab
William Carroll 5add8ddc13 Move monzo_ynab into //tools
Optimizing is difficult: I like flat hierarchies because I don't like
directory-hopping, but I also would like a cleaner root for my mono-repo. Bombs
away!

Well it's that time again, folks: spring cleaning!

Here I am musing about a few things that bother me:
- Should I use kebab-case or snake_case?
- It feels ~confusing to have //tools and //utils. What a //projects? Isn't
  everything a project? *sigh*
2020-07-20 10:15:47 +01:00
..
monzo Move monzo_ynab into //tools 2020-07-20 10:15:47 +01:00
ynab Move monzo_ynab into //tools 2020-07-20 10:15:47 +01:00
.envrc Move monzo_ynab into //tools 2020-07-20 10:15:47 +01:00
.gitignore Move monzo_ynab into //tools 2020-07-20 10:15:47 +01:00
auth.go Move monzo_ynab into //tools 2020-07-20 10:15:47 +01:00
dir-locals.nix Move monzo_ynab into //tools 2020-07-20 10:15:47 +01:00
job.nix Move monzo_ynab into //tools 2020-07-20 10:15:47 +01:00
main.go Move monzo_ynab into //tools 2020-07-20 10:15:47 +01:00
README.md Move monzo_ynab into //tools 2020-07-20 10:15:47 +01:00
requests.txt Move monzo_ynab into //tools 2020-07-20 10:15:47 +01:00
shell.nix Move monzo_ynab into //tools 2020-07-20 10:15:47 +01:00
tokens.go Move monzo_ynab into //tools 2020-07-20 10:15:47 +01:00
tokens.nix Move monzo_ynab into //tools 2020-07-20 10:15:47 +01:00

monzo_ynab

Exporting Monzo transactions to my YouNeedABudget.com (i.e. YNAB) account. YNAB unfortunately doesn't currently offer an Monzo integration. As a workaround and a practical excuse to learn Go, I decided to write one myself.

This job is going to run N times per 24 hours. Monzo offers webhooks for reacting to certain types of events. I don't expect I'll need realtime data for my YNAB integration. That may change, however, so it's worth noting.

Installation

Like many other packages in this repository, monzo_ynab is packaged using Nix. To install and use, you have two options:

You can install using nix-build and then run the resulting ./result/bin/monzo_ynab.

> nix-build . && ./result/bin/monzo_ynab

Or you can install using nix-env if you'd like to create the monzo_ynab symlink.

> nix-env -f ~/briefcase/monzo_ynab -i

Deployment

While this project is currently not deployed, my plan is to host it on Google Cloud and run it as a Cloud Run application. What I don't yet know is whether or not this is feasible or a good idea. One complication that I foresee is that the OAuth 2.0 login flow requires a web browser until the access token and refresh tokens are acquired. I'm unsure how to workaround this at the moment.

For more information about the general packaging and deployment strategies I'm currently using, refer to the deployments writeup.