Skip to content

Commit

Permalink
Wallos v0.9
Browse files Browse the repository at this point in the history
  • Loading branch information
ellite committed Oct 5, 2023
0 parents commit 63ce5b0
Show file tree
Hide file tree
Showing 166 changed files with 6,337 additions and 0 deletions.
5 changes: 5 additions & 0 deletions .dockerignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
# Exclude .vscode directory
.vscode/

# Exclude .git directory
.git/
61 changes: 61 additions & 0 deletions Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,61 @@
# Use the php:8.0.5-fpm-alpine base image
FROM php:8.0.5-fpm-alpine

# Set working directory to /var/www/html
WORKDIR /var/www/html

# Install SQLite3 and its dependencies
RUN apk add --no-cache sqlite-dev \
&& docker-php-ext-install pdo pdo_sqlite \
&& docker-php-ext-enable pdo pdo_sqlite

# Install additional PHP extensions and dependencies
RUN apk add --no-cache libpng libpng-dev libjpeg-turbo libjpeg-turbo-dev freetype freetype-dev curl autoconf libgomp \
&& docker-php-ext-configure gd --with-freetype --with-jpeg \
&& docker-php-ext-install -j$(nproc) gd

# Install Imagick extension
RUN apk add --no-cache imagemagick imagemagick-dev \
&& apk add --no-cache --virtual .build-deps $PHPIZE_DEPS \
&& pecl install imagick \
&& docker-php-ext-enable imagick \
&& apk del .build-deps

# Install Nginx and Cron
RUN apk add --no-cache nginx \
&& apk add --no-cache dcron

RUN apk add --no-cache tzdata

# Copy your PHP application files into the container
COPY . .

# Copy Nginx configuration
COPY nginx.conf /etc/nginx/nginx.conf
COPY nginx.default.conf /etc/nginx/http.d/default.conf

# Copy the custom crontab file
COPY cronjobs /etc/cron.d/cronjobs

# Convert the line endings
RUN dos2unix /etc/cron.d/cronjobs

# Allow read access to the cron file
RUN chmod 0644 /etc/cron.d/cronjobs
RUN /usr/bin/crontab /etc/cron.d/cronjobs

# Create cron log folder
RUN mkdir /var/log/cron

# Change ownership and permissions for SQLite database
RUN chown -R www-data:www-data /var/www/html

RUN chmod +x /var/www/html/startup.sh

# Expose port 80 for Nginx
EXPOSE 80

ARG SOFTWARE_VERSION=0.9.0

# Start both PHP-FPM, Nginx
CMD ["sh", "-c", "/var/www/html/startup.sh"]
674 changes: 674 additions & 0 deletions LICENSE.md

Large diffs are not rendered by default.

115 changes: 115 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,115 @@
# WALLOS

Wallos: Open-Source Personal Subscription Tracker

## Table of Contents

- [Introduction](#introduction)
- [Features](#features)
- [Getting Started](#getting-started)
- [Prerequisites](#prerequisites)
- [Baremetal](#baremetal)
- [Docker](#docker)
- [Installation](#installation)
- [Baremetal](#baremetal-1)
- [Docker](#docker-1)
- [Usage](#usage)
- [Contributing](#contributing)
- [Screenshots](#screenshots)
- [License](#license)

## 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.

## Getting Started

See instructions to run Wallos below.

### Prerequisites

#### Baremetal

- NGINX or APACHE websever running
- PHP 7.4 or 8.0 with the following modules enabled:
- curl
- gd
- imagick
- sqlite3

#### Docker

- Docker

### Installation

#### Baremetal

Download or clone this repo and move the files into your web root - usually `/var/www/html`

Add the following scripts to your cronjobs with `crontab -e`

```bash
0 0 * * * php /var/www/html/endpoints/cronjobs/updatenextpayment.php >> /var/log/cron/updatenextpayment.log 2>&1
0 1 * * * php /var/www/html/endpoints/cronjobs/updateexchange.php >> /var/log/cron/updateexchange.log 2>&1
```

#### Docker

```bash
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
```

## 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 add personalise your Avatar and add members of your household. While there add / remove any categories and currencies.
Get a free API Key from [Fixer](https://fixer.io/#pricing_plan) 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](screenshots/dashboardlight.png)

![Screenshot](screenshots/dashboarddark.png)

![Screenshot](screenshots/settings.png)

![Screenshot](screenshots/form.png)

![Screenshot](screenshots/mobilelight.png)

![Screenshot](screenshots/mobiledark.png)

## 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.

## License

This project is licensed under the [GNU General Public License, Version 3](LICENSE.md) - see the [LICENSE.md](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.
Empty file added auth.php
Empty file.
3 changes: 3 additions & 0 deletions cronjobs
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
# Run the script every day
0 0 * * * /usr/local/bin/php /var/www/html/endpoints/cronjobs/updatenextpayment.php >> /var/log/cron/updatenextpayment.log 2>&1
0 1 * * * /usr/local/bin/php /var/www/html/endpoints/cronjobs/updateexchange.php >> /var/log/cron/updateexchange.log 2>&1
Loading

0 comments on commit 63ce5b0

Please sign in to comment.