Subie is a smart subscription management application designed to help individuals tackle subscription fatigue. In a world where digital subscriptions are growing rapidly, Subie provides a streamlined solution to track, manage, and optimize your subscriptions.
With an intuitive interface and powerful backend, Subie empowers users to take control of their finances by consolidating subscriptions, monitoring payments, and offering actionable insights for cost-saving.
- Subscription Tracking: Link accounts or manually add subscriptions for centralized management.
- Payment Monitoring: Get timely notifications for upcoming payments, price changes, or trial expirations.
- AI-Driven Insights: Receive recommendations for cost-saving and subscription optimization.
- Cancellation Assistance: Simplify subscription cancellations with in-app tools or concierge services.
- Discount Discovery: Stay updated with promotions and offers for existing or potential subscriptions.
- Secure Payments: Manage payments with confidence using advanced encryption and virtual cards.
This project uses the FastAPI full stack template that has in turn uses the technologies below.
- ⚡ FastAPI for the Python backend API.
- 🧰 SQLModel for the Python SQL database interactions (ORM).
- 🔍 Pydantic, used by FastAPI, for the data validation and settings management.
- 💾 PostgreSQL as the SQL database.
- 🚀 React for the frontend.
- 💃 Using TypeScript, hooks, Vite, and other parts of a modern frontend stack.
- 🎨 Chakra UI for the frontend components.
- 🤖 An automatically generated frontend client.
- 🧪 Playwright for End-to-End testing.
- 🦇 Dark mode support.
- 🐋 Docker Compose for development and production.
- 🔒 Secure password hashing by default.
- 🔑 JWT (JSON Web Token) authentication.
- 📫 Email based password recovery.
- ✅ Tests with Pytest.
- 📞 Traefik as a reverse proxy / load balancer.
- 🚢 Deployment instructions using Docker Compose, including how to set up a frontend Traefik proxy to handle automatic HTTPS certificates.
- 🏭 CI (continuous integration) and CD (continuous deployment) based on GitHub Actions.
You can just fork or clone this repository and use it as is.
✨ It just works. ✨
You can then update configs in the .env
files to customize your configurations.
Before deploying it, make sure you change at least the values for:
SECRET_KEY
FIRST_SUPERUSER_PASSWORD
POSTGRES_PASSWORD
You can (and should) pass these as environment variables from secrets.
Read the deployment.md docs for more details.
Some environment variables in the .env
file have a default value of changethis
.
You have to change them with a secret key, to generate secret keys you can run the following command:
python -c "import secrets; print(secrets.token_urlsafe(32))"
Copy the content and use that as password / secret key. And run that again to generate another secure key.
Copier will ask you for some data, you might want to have at hand before generating the project.
But don't worry, you can just update any of that in the .env
files afterwards.
The input variables, with their default values (some auto generated) are:
project_name
: (default:"Subie Project"
) The name of the project, shown to API users (in .env).stack_name
: (default:"subie-project"
) The name of the stack used for Docker Compose labels and project name (no spaces, no periods) (in .env).secret_key
: (default:"changethis"
) The secret key for the project, used for security, stored in .env, you can generate one with the method above.first_superuser
: (default:"admin@example.com"
) The email of the first superuser (in .env).first_superuser_password
: (default:"changethis"
) The password of the first superuser (in .env).smtp_host
: (default: "") The SMTP server host to send emails, you can set it later in .env.smtp_user
: (default: "") The SMTP server user to send emails, you can set it later in .env.smtp_password
: (default: "") The SMTP server password to send emails, you can set it later in .env.emails_from_email
: (default:"info@example.com"
) The email account to send emails from, you can set it later in .env.postgres_password
: (default:"changethis"
) The password for the PostgreSQL database, stored in .env, you can generate one with the method above.sentry_dsn
: (default: "") The DSN for Sentry, if you are using it, you can set it later in .env.
Backend docs: backend/README.md.
Frontend docs: frontend/README.md.
Deployment docs: deployment.md.
General development docs: development.md.
This includes using Docker Compose, custom local domains, .env
configurations, etc.
The Subie Project is licensed under the terms of the MIT license.