Based on laravel/react-starter-kit
β οΈ Development Status NoticeThis project is currently in active development with no official release yet. The codebase and documentation have been significantly developed using AI assistance and require extensive refactoring and thorough code review before being production-ready. Use at your own risk and contributions are welcome to help improve the code quality and stability.
Spendly is an open-source personal finance tracker that helps you manage your finances, analyze spending patterns, and maintain budgets. It integrates with GoCardless for seamless bank account imports and provides powerful financial analysis tools.
- Bank Account Integration: Import transactions automatically using GoCardless
- Financial Analysis: Get insights into your spending patterns and financial health
- Budget Management WIP: Create and track budgets for different categories
- Transaction Categorization WIP: Automatically categorize transactions with machine learning - currently supports manual categorization
- Reports & Visualizations: Beautiful charts and reports for better financial understanding
- Multi-currency Support WIP: Track finances in multiple currencies
- CSV Import: Import transactions from CSV files with customizable field mapping
- Self-Hosting: Easy deployment with Docker, Kubernetes, or bare metal
- API Access WIP: RESTful API for integrations and automation
- Backend: Laravel 12.x
- Frontend: React 19.x with TypeScript
- Database: SQLite (default), MySQL, PostgreSQL
- Authentication: Laravel Sanctum
- API Integration: GoCardless API
- Testing: PHPUnit, Jest
- Deployment: Docker
Download and run setup script scripts/setup.sh
curl -sSL https://raw.githubusercontent.com/andrejvysny/spendly/refs/heads/main/scripts/setup.sh | bash- Make sure you have Docker installed on your system.
- Download compose.prod.yml.
- Create .env file using .env.example and adjust settings as needed.
- Generate app key using docker or use one from https://laravel-encryption-key-generator.vercel.app/.
docker run --rm \
        --entrypoint="" \
        --user "$(id -u):$(id -g)" \
        -v "$(pwd)/.env:/var/www/html/.env" \
        -v "$(pwd)/compose.yml:/var/www/html/compose.yml" \
        ghcr.io/andrejvysny/spendly:main \
        php artisan key:generate --force- Start Spendly
docker compose up -d- Visit http://localhostin your browser and enjoy.
- Installation Guide - Detailed setup instructions
- Deployment Guide - Self-hosting and production deployment
- Development Setup - Local development environment
- API Documentation - RESTful API reference
- Contributing Guidelines - How to contribute
See Development Guide for detailed instructions. See Testing Guide for testing setup.
Spendly takes security seriously, especially when handling financial data:
- Data encryption for sensitive information
- All data stored locally: Your data remains on your device and is never sent to external servers, giving you full control.
- Secure API keys and credentials management
- Regular security audits and dependency updates
- Secure authentication with Laravel Sanctum
- Input validation and SQL injection prevention
- Security headers and CSRF protection
We welcome contributions! Please see our Contributing Guidelines for details on:
- Code of Conduct
- Development setup
- Submitting pull requests
- Reporting issues
- Financial domain best practices
This project is licensed under the GNU General Public License v3.0 (GPLv3). See LICENSE for details.
- Laravel - The PHP framework for web artisans
- React - A JavaScript library for building user interfaces
- GoCardless - Bank account data API
- Tailwind CSS - A utility-first CSS framework
- All our contributors and supporters
- Documentation: Installation | API | Deployment
- GitHub Issues: Report bugs or request features
- Security Issues: [email protected]
- Community: GitHub Discussions
- Project Repository: GitHub
- Docker Images: GitHub Container Registry
- Issue Tracker: GitHub Issues
- API Documentation: docs/API.md
Made with β€οΈ for the open-source community