63 lines
1.9 KiB
YAML
63 lines
1.9 KiB
YAML
name: openclaw-mission-control
|
|
|
|
services:
|
|
db:
|
|
image: postgres:16-alpine
|
|
environment:
|
|
POSTGRES_DB: ${POSTGRES_DB:-mission_control}
|
|
POSTGRES_USER: ${POSTGRES_USER:-postgres}
|
|
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD:-postgres}
|
|
volumes:
|
|
- postgres_data:/var/lib/postgresql/data
|
|
ports:
|
|
- "${POSTGRES_PORT:-5432}:5432"
|
|
healthcheck:
|
|
test: ["CMD-SHELL", "pg_isready -U $$POSTGRES_USER -d $$POSTGRES_DB"]
|
|
interval: 5s
|
|
timeout: 3s
|
|
retries: 20
|
|
|
|
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.example
|
|
environment:
|
|
# Override localhost defaults for container networking
|
|
DATABASE_URL: postgresql+psycopg://${POSTGRES_USER:-postgres}:${POSTGRES_PASSWORD:-postgres}@db:5432/${POSTGRES_DB:-mission_control}
|
|
CORS_ORIGINS: ${CORS_ORIGINS:-http://localhost:3000}
|
|
DB_AUTO_MIGRATE: ${DB_AUTO_MIGRATE:-true}
|
|
AUTH_MODE: ${AUTH_MODE}
|
|
LOCAL_AUTH_TOKEN: ${LOCAL_AUTH_TOKEN:-change-me}
|
|
depends_on:
|
|
db:
|
|
condition: service_healthy
|
|
ports:
|
|
- "${BACKEND_PORT:-8000}:8000"
|
|
|
|
frontend:
|
|
build:
|
|
context: ./frontend
|
|
args:
|
|
NEXT_PUBLIC_API_URL: ${NEXT_PUBLIC_API_URL:-http://localhost:8000}
|
|
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:
|
|
- path: ./frontend/.env
|
|
required: false
|
|
environment:
|
|
NEXT_PUBLIC_API_URL: ${NEXT_PUBLIC_API_URL:-http://localhost:8000}
|
|
NEXT_PUBLIC_AUTH_MODE: ${AUTH_MODE}
|
|
depends_on:
|
|
- backend
|
|
ports:
|
|
- "${FRONTEND_PORT:-3000}:3000"
|
|
|
|
volumes:
|
|
postgres_data:
|