d36aaeb967
**TL;DR:** - Delete half-baked packaging attempts (`job.nix`, `token.nix`). - Ensure golang code compiles. - Some "packages" were being treated like "programs" presumably for debugging/testing purposes back when I was working on this. Make those behave like libraries. - Remove stale imports. - Fix syntax errors. - Miscellaneous other chores. - Drop `shell.nix` and `use_nix` directive. Change-Id: I63c275680bac55a3cad3b9cb48d51cdc431fbe48 Reviewed-on: https://cl.tvl.fyi/c/depot/+/7318 Autosubmit: wpcarro <wpcarro@gmail.com> Tested-by: BuildkiteCI Reviewed-by: wpcarro <wpcarro@gmail.com> |
||
---|---|---|
.. | ||
monzo | ||
ynab | ||
.envrc | ||
.gitignore | ||
auth.go | ||
main.go | ||
README.md | ||
requests.txt | ||
tokens.go |
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 -iA users.wpcarro.monzo_ynab
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.