Polar's stack consists of the following elements:
- A backend written in Python, exposing a REST API and workers
- A frontend written in JavaScript
- A PostgreSQL database
- A Redis database
- An S3-compatible storage
flowchart TD
subgraph "Backend"
API["Rest API"]
POSTGRESQL["PostgreSQL"]
REDIS["Redis"]
S3["S3 Storage"]
WORKER["Worker"]
WORKER_GITHUB["Worker GitHub"]
end
subgraph "Frontend"
WEB["Web client"]
end
GITHUB_WH["GitHub Webhooks"]
STRIPE_WH["Stripe Webhooks"]
USERS["Users"]
WEB --> API
API --> POSTGRESQL
API --> REDIS
REDIS <--> WORKER
REDIS <--> WORKER_GITHUB
WORKER --> POSTGRESQL
WORKER_GITHUB --> POSTGRESQL
API --> S3
WEB --> S3
GITHUB_WH -.-> API
STRIPE_WH -.-> API
USERS -.-> API
USERS -.-> WEB
Polar needs a Python 3.12 and Node.js 18 installations.
For the Polar stack to run properly, it needs quite a bunch of settings defined as environment variables. To ease things, we provide a script to bootstrap them. It requires uv to be installed on your system.
./dev/setup-environment
Once done, the script will automatically create server/.env
and clients/apps/web/.env.local
files with the necessary environment variables.
Optional: setup GitHub App
If you want to work with GitHub login and issue funding, you'll need to have a GitHub App for your development environment. Our script is able to help in this task by passing the following parameters:
./dev/setup-environment --setup-github-app --backend-external-url mydomain.ngrok.dev
Note that you'll need a valid external URL that'll route to your development server. For this task, we recommend to use ngrok.
Your browser will open a new page and you'll be prompted to create a GitHub App. You can just proceed, all the necessary configuration is already done automatically. The script will then add the necessary values to the environment files.
Tip
If you run on GitHub Codespaces, you can just run it like this:
./dev/setup-environment --setup-github-app
The script will automatically use your external GitHub Codespace URL.
Optional: setup Stripe
Currently, this setup script doesn't support to create a Stripe Sandbox. If you want a ready-to-use Stripe Sandbox, contact us and we'll happily provide you one.
Tip
If you run on GitHub Codespaces, you can skip this step. This is already done for you.
Setting up the backend consists of basically three things:
1. Start the development containers
This will start PostgreSQL, Redis and Minio (S3 storage) containers. You'll need to have Docker installed.
cd server
docker compose up -d
2. Install Python dependencies
We use uv to manage our Python dependencies. Make sure it's installed on your system.
uv sync
Tip
If you run on GitHub Codespaces, you can skip this step. This is already done for you.
1. Install JavaScript dependencies
We use pnpm to manage our JavaScript dependencies. Make sure it's installed on your system.
cd clients
pnpm install
Tip
Use several terminal tabs to run things in parallel.
The backend consists of an API server, a general-purpose worker and a worker dedicated to GitHub synchronization. You can run them like this:
cd server
1. Apply the database migrations
uv run task db_migrate
Note
You don't necessarily need to run it each time you start the server, but it's a good idea to regularly do it nonetheless.
2. Start server and workers
uv run task api
uv run task worker
By default, the API server will be available at http://127.0.0.1:8000.
Tip
The processes will restart automatically if you make changes to the code.
The frontend mainly consists of a web client server, plus other projects useful for testing or examples. You can run them like this:
cd clients
pnpm run dev
By default, the web client will be available at http://127.0.0.1:3000.
Tip
The processes will restart automatically if you make changes to the code.
Note
On GitHub Codespaces, both API backend and web frontend will be routed on the 8080 port.
We have a mechanism to render emails into a file and preview it in the browser. If changes are made to the codebase, they are automatically refreshed.
This can be triggered with the following commands:
uv run task watch_email email_order_confirmation
uv run task watch_email email_subscription_confirmation
Note
Other emails are not yet supported, but can be added if needed.