Moolah is a tool for converting money in your non-default currency in your Splitwise account into your default currency, using the rates for that day from fixer.io.
- Copy
config.yaml.example
toconfig.yaml
and fill in the values there as we go through the later steps - Register app at https://secure.splitwise.com/oauth_clients and get the OAuth Client/Secret for
config.yaml
- Callback URL should be "<host>/oauth/response" (http://localhost:5000/oauth/response for local setup)
- If you've already got Bower installed, just run
bower install
. Otherwise, install Node.js and runnpm install
, which will install and run Bower. pip install -r requirements.txt
(preferably within a Virtualenv because that's just sensible)./debug-run.sh
You've now got a running version of the app at http://localhost:5000. Running python fixer.py
will synchronise all registered users.
There's a running instance of this at https://moolah-heroku.herokuapp.com/ but here's how I did that.
- Get a Heroku account. Free ones work fine.
- Install the Heroku toolbelt
- Goto your dashboard and make a new app. Mine was called "moolah-heroku" but you'll need to use another name for yours, and replace anywhere I use that.
heroku git:remote --app moolah-heroku
to make it possible to push to deploy to your new app.- We're using multiple buildpacks, both the Python (backend) and Node.js (assets). You'll need to do the following:
heroku buildpacks:add --index 1 heroku/nodejs
heroku buildpacks:add --index 2 heroku/python
heroku buildpacks
should now say (and if it doesn't, read the docs)- heroku/nodejs 2. heroku/python
- Add the PostgreSQL addon
- Go into the settings for your app and set the following config variables:
- CLIENT_ID/CLIENT_SECRET - Splitwise app configured as per above, but with your Heroku URL, not localhost
- FLASK_ENCRYPTION_KEY - Something secret for Flask to use for cookie encryption
git push heroku master
- At this point, goto your Heroku URL and check everything works. You might have an error page the first time you load it due to clashes between multiple workers all trying to configure the DB. Just refresh and it should fix itself.
- Add the Scheduler addon and configure the update command (
python fixer.py
) to run every so often.