Have you ever been on a group trip and lost track of who paid for what and who owes money to whom? If so, money balancer is the perfect tool for you! It helps you to keep track of who paid for what and calculates your balance with all of your friends. A demo is available here but it may be reset at any time.
Using docker-compose
:
version: "3"
services:
money-balancer:
image: ghcr.io/dorianim/money-balancer
restart: unless-stopped
ports:
- 8000:8000
volumes:
- ./data:/data
environment:
- MONEYBALANCER_JWT_SECRET=some_super_secret_secret
Using docker
:
docker run -p8000:8000 -e MONEYBALANCER_JWT_SECRET=some_super_secret_secret -v $(pwd)/data:/data ghcr.io/dorianim/money-balancer
You can then access money-balancer on http://localhost:8000
. The API documentation can be found at http://localhost:8000/api/v1
.
MONEYBALANCER_JWT_SECRET
: a random value for the JWT signature
MONEYBALANCER_AUTH_LOCAL_ENABLED
: enable local username/password authentication
Proxy authentication can be used with services like Authelia and Authentik
MONEYBALANCER_AUTH_PROXY_ENABLED
: enable proxy authenticationMONEYBALANCER_AUTH_PROXY_HEADERS_USERNAME
: header containing the username (e.g.X-authentik-username
)MONEYBALANCER_AUTH_PROXY_HEADERS_NICKNAME
: header containing the nickname (e.g.X-authentik-name
)
If you want to use another sign on method, you may only protect the route /api/v1/auth/proxy
.
For example in Authentik, you may use this as the unauthenticated paths:
^([^p]|p(p|r(p|o(p|xp)))*([^pr]|r([^op]|o([^px]|x[^py]))))*(p(p|r(p|o(p|xp)))*(r(o?|ox))?)?$
(excludes everything that contains proxy
, generated with this tool)
- amount / debtors
- the potential rest is assigned to people who have to overpay
- who has to overpay is determined by how often they have overpaid in the past in this specific group
You need cargo
and yarn
installed on your system. You can build everything using
cargo build
This will create a static binary in target/debug/money-balancer
which you can run.