2026-05-19 01:48:38 -05:00
|
|
|
name: pipeline
|
2026-05-19 01:17:58 -05:00
|
|
|
|
|
|
|
|
services:
|
|
|
|
|
db:
|
|
|
|
|
image: postgres:16-alpine
|
|
|
|
|
environment:
|
2026-05-19 01:48:38 -05:00
|
|
|
POSTGRES_DB: ${POSTGRES_DB:-pipeline}
|
2026-05-19 01:17:58 -05:00
|
|
|
POSTGRES_USER: ${POSTGRES_USER:-postgres}
|
|
|
|
|
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD:-postgres}
|
|
|
|
|
volumes:
|
|
|
|
|
- postgres_data:/var/lib/postgresql/data
|
|
|
|
|
ports:
|
|
|
|
|
- "127.0.0.1:${POSTGRES_PORT:-5432}:5432"
|
|
|
|
|
healthcheck:
|
|
|
|
|
test: ["CMD-SHELL", "pg_isready -U $$POSTGRES_USER -d $$POSTGRES_DB"]
|
|
|
|
|
interval: 5s
|
|
|
|
|
timeout: 3s
|
|
|
|
|
retries: 20
|
|
|
|
|
|
|
|
|
|
redis:
|
|
|
|
|
image: redis:7-alpine
|
|
|
|
|
ports:
|
|
|
|
|
- "127.0.0.1:${REDIS_PORT:-6379}:6379"
|
|
|
|
|
healthcheck:
|
|
|
|
|
test: ["CMD", "redis-cli", "ping"]
|
|
|
|
|
interval: 5s
|
|
|
|
|
timeout: 3s
|
|
|
|
|
retries: 5
|
|
|
|
|
|
|
|
|
|
backend:
|
|
|
|
|
build:
|
|
|
|
|
# Build from repo root so the backend image can include repo-level assets
|
|
|
|
|
# like `backend/templates/`.
|
|
|
|
|
context: .
|
|
|
|
|
dockerfile: backend/Dockerfile
|
|
|
|
|
env_file:
|
|
|
|
|
- ./backend/.env
|
|
|
|
|
environment:
|
|
|
|
|
# Override localhost defaults for container networking
|
2026-05-19 01:48:38 -05:00
|
|
|
DATABASE_URL: postgresql+psycopg://${POSTGRES_USER:-postgres}:${POSTGRES_PASSWORD:-postgres}@db:5432/${POSTGRES_DB:-pipeline}
|
2026-05-19 01:17:58 -05:00
|
|
|
CORS_ORIGINS: ${CORS_ORIGINS:-http://localhost:3030}
|
|
|
|
|
DB_AUTO_MIGRATE: ${DB_AUTO_MIGRATE:-true}
|
|
|
|
|
AUTH_MODE: ${AUTH_MODE}
|
|
|
|
|
LOCAL_AUTH_TOKEN: ${LOCAL_AUTH_TOKEN}
|
|
|
|
|
BASE_URL: ${BASE_URL:-http://localhost:8000}
|
|
|
|
|
RQ_REDIS_URL: redis://redis:6379/0
|
|
|
|
|
depends_on:
|
|
|
|
|
db:
|
|
|
|
|
condition: service_healthy
|
|
|
|
|
redis:
|
|
|
|
|
condition: service_healthy
|
|
|
|
|
ports:
|
|
|
|
|
- "${BACKEND_PORT:-8001}:8000"
|
|
|
|
|
|
|
|
|
|
frontend:
|
|
|
|
|
build:
|
|
|
|
|
context: ./frontend
|
|
|
|
|
args:
|
|
|
|
|
NEXT_PUBLIC_API_URL: ${NEXT_PUBLIC_API_URL:-auto}
|
|
|
|
|
NEXT_PUBLIC_AUTH_MODE: ${AUTH_MODE}
|
|
|
|
|
# Optional, user-managed env file.
|
|
|
|
|
# IMPORTANT: do NOT load `.env.example` here because it contains non-empty
|
|
|
|
|
# placeholder Clerk keys, which can accidentally flip Clerk "on".
|
|
|
|
|
env_file:
|
|
|
|
|
- ./frontend/.env
|
|
|
|
|
environment:
|
|
|
|
|
NEXT_PUBLIC_API_URL: ${NEXT_PUBLIC_API_URL:-auto}
|
|
|
|
|
NEXT_PUBLIC_AUTH_MODE: ${AUTH_MODE}
|
|
|
|
|
depends_on:
|
|
|
|
|
- backend
|
|
|
|
|
ports:
|
|
|
|
|
- "${FRONTEND_PORT:-3030}:3000"
|
|
|
|
|
|
|
|
|
|
webhook-worker:
|
|
|
|
|
build:
|
|
|
|
|
context: .
|
|
|
|
|
dockerfile: backend/Dockerfile
|
|
|
|
|
command: ["python", "scripts/rq-docker", "worker"]
|
|
|
|
|
env_file:
|
|
|
|
|
- ./backend/.env
|
|
|
|
|
depends_on:
|
|
|
|
|
redis:
|
|
|
|
|
condition: service_healthy
|
|
|
|
|
db:
|
|
|
|
|
condition: service_healthy
|
|
|
|
|
environment:
|
2026-05-19 01:48:38 -05:00
|
|
|
DATABASE_URL: postgresql+psycopg://${POSTGRES_USER:-postgres}:${POSTGRES_PASSWORD:-postgres}@db:5432/${POSTGRES_DB:-pipeline}
|
2026-05-19 01:17:58 -05:00
|
|
|
AUTH_MODE: ${AUTH_MODE}
|
|
|
|
|
LOCAL_AUTH_TOKEN: ${LOCAL_AUTH_TOKEN}
|
|
|
|
|
BASE_URL: ${BASE_URL:-http://localhost:8000}
|
|
|
|
|
RQ_REDIS_URL: redis://redis:6379/0
|
|
|
|
|
RQ_QUEUE_NAME: ${RQ_QUEUE_NAME:-default}
|
|
|
|
|
RQ_DISPATCH_THROTTLE_SECONDS: ${RQ_DISPATCH_THROTTLE_SECONDS:-2.0}
|
|
|
|
|
RQ_DISPATCH_MAX_RETRIES: ${RQ_DISPATCH_MAX_RETRIES:-3}
|
2026-05-19 21:18:18 -05:00
|
|
|
FORGEJO_SYNC_ENABLED: ${FORGEJO_SYNC_ENABLED:-true}
|
|
|
|
|
FORGEJO_SYNC_INTERVAL_SECONDS: ${FORGEJO_SYNC_INTERVAL_SECONDS:-3600}
|
|
|
|
|
FORGEJO_SYNC_STARTUP_DELAY_SECONDS: ${FORGEJO_SYNC_STARTUP_DELAY_SECONDS:-60}
|
2026-05-19 01:17:58 -05:00
|
|
|
restart: unless-stopped
|
|
|
|
|
|
|
|
|
|
volumes:
|
|
|
|
|
postgres_data:
|