Skip to content
This repository was archived by the owner on Sep 1, 2025. It is now read-only.

A Easy To use & Deploy comprehensive PHP-based personal and small corporate accounting management system with powerful expense tracking, subscription management, and reporting capabilities.

License

Notifications You must be signed in to change notification settings

moonshadowrev/PersonalAccounter

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

51 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

PersonalAccounter v1.0.2

A comprehensive PHP-based personal and business accounting management system with powerful expense tracking, subscription management, and reporting capabilities.

πŸ†• Latest Updates (v1.0.2)

  • 🌐 Enhanced Docker Network Compatibility - Improved subnet configuration to avoid conflicts
  • πŸ› οΈ New CLI Management Tools - control-docker script for easy container management
  • πŸ”§ Network Diagnostic Tools - network-check.sh for troubleshooting network conflicts
  • πŸ“Š Adminer Integration - Lightweight database management (replaces phpMyAdmin)
  • ⚑ Auto-Permission Fixes - Automatic log directory permission resolution on startup
  • πŸŽ›οΈ Flexible Environment Configuration - Customizable Docker network settings

πŸš€ Installation Options

Choose the installation method that best fits your needs:

Method Best For Pros Cons
🐳 Docker Production, Quick Setup Easy deployment, Isolated environment, All dependencies included Requires Docker knowledge, Resource overhead
πŸ“¦ Local PHP Development, Customization Full control, Better debugging, Native performance Manual dependency management, More setup steps

πŸ“¦ Local PHP Setup (Native Installation)

For developers who prefer local PHP environment or want to contribute to the project:

Prerequisites

  • PHP 8.0+ with required extensions:
    • pdo_mysql, json, openssl, mbstring, gd, curl, zip
  • MySQL 8.0+ or MariaDB 10.4+
  • Composer (for dependency management)
  • Web server (Apache/Nginx) or PHP's built-in server

Required PHP Extensions Installation

# Ubuntu/Debian
sudo apt-get install php php-mysql php-gd php-curl php-zip php-mbstring php-json php-openssl

# CentOS/RHEL
sudo yum install php php-mysql php-gd php-curl php-zip php-mbstring php-json php-openssl

# macOS (using Homebrew)
brew install php composer
brew install mysql

# Windows (using Chocolatey)
choco install php composer mysql

Quick Setup Commands

# Clone the repository
git clone https://github.com/moonshadowrev/PersonalAccounter.git
cd PersonalAccounter

# Install PHP dependencies
composer install

# Copy and configure environment
cp .env.example .env
# Edit .env file with your database credentials and settings

# Create database
mysql -u root -p -e "CREATE DATABASE accounting_panel;"
mysql -u root -p -e "CREATE USER 'accounting_user'@'localhost' IDENTIFIED BY 'your_password';"
mysql -u root -p -e "GRANT ALL PRIVILEGES ON accounting_panel.* TO 'accounting_user'@'localhost';"

# Run database migrations
php control migrate run

# Create admin user
php control user admin

# Set proper permissions
chmod 755 -R .
chmod 777 -R logs/
chmod 777 -R sessions/
chmod 777 -R public/uploads/

# Start development server
php -S localhost:8000 -t public/

Web Server Configuration (Optional)

Apache (.htaccess)

The project includes an .htaccess file for Apache. Ensure mod_rewrite is enabled:

sudo a2enmod rewrite
sudo systemctl restart apache2

Nginx

Create a server block configuration:

server {
    listen 80;
    server_name localhost;
    root /path/to/PersonalAccounter/public;
    index index.php index.html;

    location / {
        try_files $uri $uri/ /index.php?$query_string;
    }

    location ~ \.php$ {
        fastcgi_pass unix:/var/run/php/php8.0-fpm.sock;
        fastcgi_param SCRIPT_FILENAME $realpath_root$fastcgi_script_name;
        include fastcgi_params;
    }
}

PHP Built-in Server (Development Only)

# Start on different port if needed
php -S localhost:8080 -t public/

# Or bind to all interfaces
php -S 0.0.0.0:8000 -t public/

Environment Configuration for Local Setup

Edit your .env file with local database settings:

# Application
APP_ENV=development
APP_DEBUG=true
APP_URL=http://localhost:8000
APP_DOMAIN=localhost

# Database (Local)
DB_HOST=localhost
DB_NAME=accounting_panel
DB_USER=accounting_user
DB_PASS=your_password
DB_PORT=3306

# Security
SESSION_LIFETIME=0
SESSION_SECURE=false
SESSION_SAMESITE=Lax

Troubleshooting Local Setup

Common Issues

Database Connection Failed

# Check MySQL service
sudo systemctl status mysql
sudo systemctl start mysql

# Test database connection
mysql -u accounting_user -p accounting_panel -e "SELECT 1;"

Permission Denied Errors

# Fix directory permissions
sudo chown -R $USER:www-data .
chmod 755 -R .
chmod 777 -R logs/ sessions/ public/uploads/

Missing PHP Extensions

# Check installed extensions
php -m | grep -E "(mysql|gd|curl|mbstring)"

# Install missing extensions (Ubuntu/Debian example)
sudo apt-get install php-mysql php-gd php-curl php-mbstring

Composer Issues

# Update Composer
composer self-update

# Clear cache and reinstall
composer clear-cache
composer install --no-cache

Local Development Tips

  • Use APP_DEBUG=true for detailed error messages
  • Check logs/app-*.log for application errors
  • Use php control db status to verify database connectivity
  • Run php control user list to check user accounts

🐳 Docker Setup (Recommended for Production)

Auto Deploy

Accounting Panel Docker Setup Script Production-ready automated deployment with secure configuration

Usage:

   curl -fsSL https://raw.githubusercontent.com/moonshadowrev/PersonalAccounter/main/setup.sh | bash
   wget -qO- https://raw.githubusercontent.com/moonshadowrev/PersonalAccounter/main/setup.sh | bash

Quick Docker Install

git clone https://github.com/moonshadowrev/PersonalAccounter
cd PersonalAccounter
bash ./setup.sh --skip-clone

πŸ› οΈ New Management Tools (v1.0.2)

Docker CLI Management

# Easy container management without entering containers
./control-docker user list                    # List all users
./control-docker migrate run                  # Run database migrations  
./control-docker db status                    # Check database status
./control-docker shell                        # Open interactive shell

Network Troubleshooting

# Diagnose and fix Docker network conflicts
./network-check.sh check                      # Check for network conflicts
./network-check.sh auto                       # Switch to auto-managed networks
./network-check.sh subnet 172.29.0.0/24 172.29.0.1  # Use custom subnet

🌟 Features

πŸ’° Expense Management

  • Multi-method expense tracking with support for credit cards, bank accounts, and cryptocurrency wallets
  • Smart categorization with tags and hierarchical organization
  • Tax calculation with customizable rates and types
  • Approval workflow with pending/approved/rejected/paid status tracking
  • File attachments for receipts and documentation
  • Bulk import/export via Excel, CSV, and JSON formats

πŸ”„ Subscription Management

  • Recurring subscription tracking for all your services and subscriptions
  • Flexible billing cycles: monthly, annual, weekly, daily, and one-time payments
  • Multi-currency support with automatic calculations
  • Status management: active, expired, cancelled, paused
  • Cost projections and spending analysis

πŸ’³ Payment Methods

  • Credit Cards: Full card management with bank association and currency support
  • Bank Accounts: International banking with IBAN, SWIFT/BIC, and routing number support
  • Crypto Wallets: Multi-network cryptocurrency wallet management with address validation

πŸ“Š Analytics & Reporting

  • Real-time dashboard with comprehensive financial statistics
  • Visual analytics with charts and graphs for spending patterns
  • Date-filtered reports for any time period
  • Export capabilities in multiple formats (CSV, JSON, Excel)
  • Category and payment method breakdowns

πŸ” Security & Authentication

  • Two-Factor Authentication (2FA) with Google Authenticator support
  • User role management (admin, superadmin)
  • API key management with permission-based access control
  • CSRF protection and security headers
  • Session security with configurable timeouts

πŸš€ API & Integration

  • RESTful API with OpenAPI/Swagger documentation
  • Authentication via API keys or Bearer tokens
  • Rate limiting and comprehensive error handling
  • Webhooks support for external integrations
  • Comprehensive endpoints for all application features

🐳 Docker & Development (v1.0.2)

  • Enhanced Network Configuration with customizable subnets to avoid conflicts
  • CLI Management Tools for easy container operations without Docker knowledge
  • Network Diagnostic Tools for troubleshooting deployment issues
  • Adminer Database Management - lightweight alternative to phpMyAdmin
  • Auto-Permission Fixes for seamless volume mounting across systems
  • Cross-Platform Compatibility with improved architecture support

πŸ“Έ Screenshots

Main Dashboard

Dashboard Overview Comprehensive financial overview with real-time statistics, recent transactions, and spending analytics

Expense Management

Expense Tracking Intuitive expense tracking interface with category management, bulk operations, and advanced filtering

Financial Reports & Analytics

Reports and Analytics Detailed financial reports with visual charts, spending patterns, and exportable data insights

Account & Settings Management

Settings and Configuration User management, security settings, API configuration, and system administration tools

πŸ“‹ Requirements

  • PHP: 8.0 or higher
  • MySQL: 5.7 or higher
  • Web Server: Apache or Nginx
  • Composer: For dependency management

PHP Extensions Required

  • pdo_mysql
  • json
  • openssl
  • mbstring
  • gd
  • curl
  • zip

πŸš€ Installation

1. Clone the Repository

git clone https://github.com/moonshadowrev/PersonalAccounter
cd PersonalAccounter

2. Install Dependencies

composer install

3. Environment Configuration

cp .env.example .env

Edit the .env file with your configuration:

# Application
APP_ENV=production
APP_DEBUG=false
APP_URL=https://your-domain.com
APP_DOMAIN=your-domain.com
APP_TIMEZONE=UTC

# Database
DB_HOST=localhost
DB_NAME=personal_accounter
DB_USER=your_username
DB_PASS=your_password
DB_PORT=3306

# Security
SESSION_LIFETIME=0
SESSION_SECURE=true
SESSION_SAMESITE=Lax
LOGIN_ATTEMPTS_LIMIT=5
LOGIN_ATTEMPTS_TIMEOUT=300

# API
API_MAX_FAILED_ATTEMPTS=5
API_BLOCK_DURATION=300
API_DEFAULT_RATE_LIMIT=60
API_MAX_RATE_LIMIT=1000

# Logging
LOG_CHANNEL=file
LOG_LEVEL=warning
LOG_MAX_FILES=5

# Docker Network Configuration (v1.0.2)
DOCKER_SUBNET=172.28.0.0/24
DOCKER_GATEWAY=172.28.0.1

4. Database Setup

# Run migrations
php control migrate run

# Create admin user
php control user admin

# Seed with sample data (optional)
php control db seed

5. File Permissions

chmod 755 -R .
chmod 777 -R logs/
chmod 777 -R sessions/
chmod 777 -R public/uploads/

6. Web Server Configuration

Apache (.htaccess)

RewriteEngine On
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(.*)$ public/index.php [QSA,L]

Nginx

location / {
    try_files $uri $uri/ /public/index.php?$query_string;
}

location ~ \.php$ {
    fastcgi_pass unix:/var/run/php/php8.0-fpm.sock;
    fastcgi_param SCRIPT_FILENAME $realpath_root$fastcgi_script_name;
    include fastcgi_params;
}

🎯 Quick Start

1. Access the Application

Navigate to https://your-domain.com and log in with your admin credentials.

2. Setup Payment Methods

  1. Go to Payment Methods β†’ Bank Accounts
  2. Add your bank account information
  3. Add credit cards and crypto wallets as needed

3. Create Categories

  1. Go to Expenses β†’ Categories
  2. Create categories for your expense types (Food, Transport, Utilities, etc.)
  3. Use the "Create Defaults" button to add common categories

4. Start Tracking Expenses

  1. Go to Expenses β†’ All Expenses
  2. Click "Add Expense"
  3. Fill in the details and submit

5. Setup Subscriptions

  1. Go to Subscriptions
  2. Add your recurring services and subscriptions
  3. Set billing cycles and amounts

πŸ“Š Database Management (v1.0.2)

Adminer Interface

Access the lightweight database management interface:

  • URL: http://localhost:8080
  • Database Server: database (or leave blank)
  • Username: accounting_user or root
  • Password: Check your .env file for DB_PASS or DB_ROOT_PASSWORD
  • Database: accounting_panel

Adminer provides:

  • SQL Query Interface for advanced database operations
  • Table Management with visual data browsing
  • Import/Export functionality for database backups
  • Cross-Platform Compatibility (replaces phpMyAdmin)

πŸ“± Usage

Managing Expenses

  • Create: Add new expenses with detailed information including tax calculations
  • Categorize: Organize expenses using categories and tags
  • Approve: Use the approval workflow for business expense management
  • Import: Bulk import expenses from Excel or CSV files
  • Export: Generate reports in various formats

Subscription Tracking

  • Add Services: Track all your recurring subscriptions
  • Monitor Costs: View monthly and annual cost projections
  • Status Management: Mark subscriptions as active, paused, expired, or cancelled
  • Billing Cycles: Support for various billing frequencies

Financial Reporting

  • Dashboard: View comprehensive financial overview
  • Date Filtering: Generate reports for specific time periods
  • Visual Analytics: Charts and graphs for spending patterns
  • Export Options: CSV, JSON, and Excel format exports

πŸ”§ Command Line Interface

Native CLI Tool

The application includes a powerful CLI tool:

# Database migrations
php control migrate run
php control migrate fresh
php control migrate rollback
php control migrate status

# User management
php control user create "John Doe" "john@example.com" "password" "admin"
php control user list
php control user delete "john@example.com"
php control user admin

# Database operations
php control db seed
php control db reset
php control db status

# Fake data generation
php control faker all
php control faker generate --users=10 --expenses=100

Docker CLI Tool (v1.0.2)

For Docker deployments, use the enhanced control-docker wrapper:

# All the same commands but running in Docker containers
./control-docker migrate run
./control-docker user list
./control-docker user create "John Doe" "john@example.com" "password" "admin"
./control-docker db status

# Special Docker commands
./control-docker shell              # Open interactive container shell
./control-docker help               # Show all available commands

Network Management Tools (v1.0.2)

Diagnose and resolve Docker network conflicts:

# Check for network conflicts
./network-check.sh check

# Show configuration options  
./network-check.sh suggest

# Auto-fix conflicts (maximum compatibility)
./network-check.sh auto

# Use custom subnet
./network-check.sh subnet 172.29.0.0/24 172.29.0.1

# Clean up networks
./network-check.sh fix

πŸ”Œ API Usage

Authentication

# Get API key from Profile β†’ API Keys in the web interface
curl -H "X-API-Key: your-api-key" https://your-domain.com/api/v1/expenses

Example API Calls

# Get all expenses
curl -H "X-API-Key: your-key" https://your-domain.com/api/v1/expenses

# Create an expense
curl -X POST -H "X-API-Key: your-key" \
  -H "Content-Type: application/json" \
  -d '{"title":"Lunch","amount":25.50,"category_id":1}' \
  https://your-domain.com/api/v1/expenses

# Get dashboard statistics
curl -H "X-API-Key: your-key" https://your-domain.com/api/v1/reports/dashboard

API Documentation

Access the interactive API documentation at:

  • Swagger UI: https://your-domain.com/api/docs/ui (development mode only)
  • OpenAPI JSON: https://your-domain.com/api/docs (development mode only)

πŸ—οΈ Architecture

Directory Structure

PersonalAccounter/
β”œβ”€β”€ app/
β”‚   β”œβ”€β”€ Controllers/        # Application controllers
β”‚   β”œβ”€β”€ Models/            # Database models
β”‚   β”œβ”€β”€ Services/          # Business logic services
β”‚   β”œβ”€β”€ Routes/            # Route definitions
β”‚   └── Views/             # Template files
β”œβ”€β”€ bootstrap/             # Application bootstrap
β”œβ”€β”€ config/               # Configuration files
β”œβ”€β”€ database/             # Database migrations
β”œβ”€β”€ logs/                 # Application logs
β”œβ”€β”€ public/               # Web accessible files
β”œβ”€β”€ sessions/             # Session storage
└── vendor/               # Composer dependencies

Technology Stack

  • Backend: PHP 8.0+ with custom MVC framework
  • Database: MySQL/MariaDB with Medoo ORM
  • Frontend: HTML5, CSS3, JavaScript (Vanilla JS)
  • Authentication: Custom session-based auth with 2FA
  • API: RESTful with OpenAPI documentation
  • Security: CSRF protection, XSS prevention, input validation
  • Containerization: Docker with optimized networking (v1.0.2)
  • Database Management: Adminer web interface (v1.0.2)
  • CLI Tools: Enhanced Docker and network management (v1.0.2)

🌍 Localization

The application supports multiple currencies and international banking:

  • Currencies: USD, EUR, GBP, CAD, AUD, JPY, CHF, CNY, SEK, NOK, DKK, SGD, HKD
  • Banking: IBAN and SWIFT/BIC support for international accounts
  • Crypto: Multi-network cryptocurrency support

πŸ›‘οΈ Security

PersonalAccounter implements comprehensive security measures:

  • CSRF Protection: All forms protected against cross-site request forgery
  • XSS Prevention: Input sanitization and output encoding
  • SQL Injection: Prepared statements and parameterized queries
  • Session Security: Secure cookie settings and session regeneration
  • Rate Limiting: API and login attempt limitations
  • Security Headers: HSTS, content type options, frame options
  • Two-Factor Authentication: Google Authenticator integration

πŸ“– Documentation

For detailed documentation including:

  • API Reference: Complete endpoint documentation
  • Security Guide: Security implementation details
  • Contribution Guidelines: How to contribute to the project
  • Feature Wiki: Detailed feature documentation

See the docs/ directory.

πŸ“„ License

This project is licensed under the GNU General Public License v3.0 (GPL-3.0).

See LICENSE for the full license text.

🀝 Contributing

We welcome contributions! Please see CONTRIBUTING.md for guidelines.

πŸ› Issues & Support

πŸ”„ Changelog

See CHANGELOG.md for version history and changes.


PersonalAccounter - Take control of your finances with powerful, secure, and flexible accounting management.

About

A Easy To use & Deploy comprehensive PHP-based personal and small corporate accounting management system with powerful expense tracking, subscription management, and reporting capabilities.

Topics

Resources

License

Code of conduct

Contributing

Security policy

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •