Go to file
2024-06-10 14:33:01 +01:00
.github push to GHCR 2024-05-27 19:01:11 +02:00
.tmp feat: add new notification methods (telegram, webhooks, gotify) (#295) 2024-05-06 00:15:44 +02:00
db Better baremetal install/update method and guide 2023-11-17 01:17:36 +01:00
endpoints fix: cronjob exchange update would not work with apilayer (#381) 2024-06-09 22:41:33 +02:00
images feat: add slovenian translation 2024-05-27 19:17:05 +02:00
includes Refactor checksession.php, wouldn't it be good to have a test-env atm :D 2024-06-10 14:33:01 +01:00
libs/PHPMailer V1.0 add email notifications 2023-11-10 11:45:01 +01:00
migrations feat: add hability to disable login (#378) 2024-06-08 00:04:50 +02:00
screenshots fix: confusing wording for billing cycle 2024-03-12 21:50:47 +01:00
scripts feat: add hability to disable login (#378) 2024-06-08 00:04:50 +02:00
styles feat: add hability to disable login (#378) 2024-06-08 00:04:50 +02:00
webfonts feat: add discord and pushover as notification agents (#300) 2024-05-06 18:55:10 +02:00
.dockerignore Wallos v0.9 2023-10-05 22:39:37 +02:00
.gitignore Automatically run migration script when loading the registration page. 2024-02-14 16:54:16 +01:00
about.php Fingerprint scripts and styles with version tag 2024-02-05 12:51:10 +01:00
admin.php feat: add hability to disable login (#378) 2024-06-08 00:04:50 +02:00
auth.php Wallos v0.9 2023-10-05 22:39:37 +02:00
CHANGELOG.md chore(main): release 2.4.1 (#382) 2024-06-09 22:53:35 +02:00
cronjobs feat!: allow registration of multiple users (#340) 2024-05-26 23:30:51 +02:00
Dockerfile feat: frequency is now up to 366 2024-06-05 00:15:31 +02:00
index.php feat: frequency is now up to 366 2024-06-05 00:15:31 +02:00
LICENSE.md Wallos v0.9 2023-10-05 22:39:37 +02:00
login.php feat: add hability to disable login (#378) 2024-06-08 00:04:50 +02:00
logos.php Wallos v0.9 2023-10-05 22:39:37 +02:00
logout.php feat!: allow registration of multiple users (#340) 2024-05-26 23:30:51 +02:00
manifest.json feat: enable progressive web app 2024-02-27 19:04:04 +01:00
nginx.conf fix: file upload bypass vulnerability (#181) 2024-03-02 15:58:22 +01:00
nginx.default.conf Wallos v0.9 2023-10-05 22:39:37 +02:00
passwordreset.php feat!: allow registration of multiple users (#340) 2024-05-26 23:30:51 +02:00
README.md feat!: allow registration of multiple users (#340) 2024-05-26 23:30:51 +02:00
registration.php feat!: allow registration of multiple users (#340) 2024-05-26 23:30:51 +02:00
SECURITY.md feat: enable progressive web app 2024-02-27 19:04:04 +01:00
service-worker.js feat: add slovenian translation 2024-05-27 19:17:05 +02:00
settings.php feat: add ntfy as notification method (#377) 2024-06-05 22:08:36 +02:00
startup.sh feat: add custom avatar functionality (#248) 2024-03-24 16:12:44 +01:00
stats.php feat: frequency is now up to 366 2024-06-05 00:15:31 +02:00
verifyemail.php feat!: allow registration of multiple users (#340) 2024-05-26 23:30:51 +02:00

Wallos

Wallos: Open-Source Personal Subscription Tracker

Table of Contents

Introduction

Wallos is a powerful, open-source, and self-hostable web application designed to empower you in managing your finances with ease. Say goodbye to complicated spreadsheets and expensive financial software Wallos simplifies the process of tracking expenses and helps you gain better control over your financial life.

Features

  • Subscription Management: Keep track of your recurring subscriptions and payments, ensuring you never miss a due date.
  • Category Management: Organize your expenses into customizable categories, enabling you to gain insights into your spending habits.
  • Multi-Currency support: Wallos supports multiple currencies, allowing you to manage your finances in the currency of your choice.
  • Currency Conversion: Integrates with the Fixer API so you can get exchange rates and see all your subscriptions on your main currency.
  • Data Privacy: As a self-hosted application, Wallos ensures that your financial data remains private and secure on your own server.
  • Customization: Tailor Wallos to your needs with customizable categories, currencies, themes and other display options.
  • Sorting Options: Allowing you to view your subscriptions from different perspectives.
  • Logo Search: Wallos can search the web for the logo of your subscriptions if you don't have them available for upload.
  • Mobile view: Wallos on the go.
  • Statistics: Another perspective into your spendings.
  • Notifications: Wallos supports multiple notification methods (email, discord, pushover, telegram, gotify and webhooks). Get notified about your upcoming payments.
  • Multi Language support.

Getting Started

See instructions to run Wallos below.

Prerequisites

Baremetal

  • NGINX or APACHE websever running
  • PHP 8.2 with the following modules enabled:
    • curl
    • gd
    • imagick
    • intl
    • openssl
    • sqlite3
    • zip

Docker

  • Docker

Installation

Baremetal

  1. Download or clone this repo and move the files into your web root - usually /var/www/html
  2. Rename /db/wallos.empty.db to /db/wallos.db
  3. Run http://domain.example/endpoints/db/migrate.php on your browser
  4. Add the following scripts to your cronjobs with crontab -e
0 1 * * * php /var/www/html/endpoints/cronjobs/updatenextpayment.php >> /var/log/cron/updatenextpayment.log 2>&1
0 2 * * * php /var/www/html/endpoints/cronjobs/updateexchange.php >> /var/log/cron/updateexchange.log 2>&1
0 9 * * * php /var/www/html/endpoints/cronjobs/sendnotifications.php >> /var/log/cron/sendnotifications.log 2>&1
*/2 * * * * php /var/www/html/endpoints/cronjobs/sendverificationemails.php >> /var/log/cron/sendverificationemail.log 2>&1
*/2 * * * * php /var/www/html/endpoints/cronjobs/sendresetpasswordemails.php >> /var/log/cron/sendresetpasswordemails.log 2>&1
  1. If your web root is not /var/www/html/ adjust the cronjobs above accordingly.

Updating

  1. Re-download the repo and move the files into the correct folder or do git pull (if you used git clone before)
  2. Check the Prerequisites and install / enable the missing ones, if any.
  3. Run http://domain.example/endpoints/db/migrate.php

Docker

docker run -d --name wallos -v /path/to/config/wallos/db:/var/www/html/db \
-v /path/to/config/wallos/logos:/var/www/html/images/uploads/logos \
-e TZ=Europe/Berlin -p 8282:80 --restart unless-stopped \
bellamy/wallos:latest

Docker Compose

version: '3.0'

services:
  wallos:
    container_name: wallos
    image: bellamy/wallos:latest
    ports:
      - "8282:80/tcp"
    environment:
      TZ: 'America/Toronto'
    # Volumes store your data between container upgrades
    volumes:
      - './db:/var/www/html/db'
      - './logos:/var/www/html/images/uploads/logos'
    restart: unless-stopped

Usage

Just open the browser and open ip:port of the machine running wallos.
On the first time you run wallos a user account must be created.
Go to settings and personalise your Avatar and add members of your household. While there add / remove any categories and currencies.
Get a free API Key from Fixer and add it in the settings.
If you want to trigger an Update of the exchange rates, change your main currency after adding the API Key, and then change it back to your prefered one.

Screenshots

Screenshot

Screenshot

Screenshot

Screenshot

Screenshot Screenshot

Contributing

Feel free to open Pull requests with bug fixes and features. I'll do my best to keep an eye on those.
Feel free to open issues with bug reports or feature requests. Bug fixes will take priority.
I welcome contributions from the community and look forward to working with you to improve this project.

Contributors

Translations

If you want to contribute with a translation of wallos:

  • Add your language code to includes/i18n/languages.php in the format "en" => "English". Please use the original language name and not the english translation.
  • Create a copy of the file includes/i18n/en.php and rename it to the language code you used above. Example: pt.php for "pt" => "Português".
  • Translate all the values on the language file to the new language. (Incomplete translations will not be accepted).
  • Create a copy of the file scripts/i18n/en.js and rename it to the language code you used above. Example: pt.js for "pt" => "Português".
  • Translate all the values on the language file to the new language. (Incomplete translations will not be accepted).

License

This project is licensed under the GNU General Public License, Version 3 - see the LICENSE.md file for details.

Why GPLv3?

I chose the GNU General Public License version 3 (GPLv3) for this project because it ensures that the software remains open source and freely available to the community. GPLv3 mandates that any derivative works or modifications must also be released under the same license, promoting the principles of software freedom.

I strongly believe in the importance of open source software and the collaborative nature of development, and I invite contributors to help improve this project.