Files
rosterchirp/docker-compose.host.yaml

98 lines
2.9 KiB
YAML

# docker-compose.host.yaml — JAMA-HOST multi-tenant deployment
#
# Use this instead of docker-compose.yaml when running JAMA-HOST.
# Adds Caddy as the reverse proxy for automatic wildcard SSL.
#
# Usage:
# docker compose -f docker-compose.host.yaml up -d
#
# Required .env additions for host mode:
# APP_TYPE=host
# HOST_DOMAIN=jamachat.com
# HOST_ADMIN_KEY=your_secret_host_admin_key
# CF_API_TOKEN=your_cloudflare_dns_api_token (or equivalent for your DNS provider)
services:
jama:
image: jama:${JAMA_VERSION:-latest}
container_name: ${PROJECT_NAME:-jama}
restart: unless-stopped
# No direct port exposure — traffic comes through Caddy
expose:
- "3000"
environment:
- NODE_ENV=production
- TZ=${TZ:-UTC}
- APP_TYPE=host
- ADMIN_NAME=${ADMIN_NAME:-Admin User}
- ADMIN_EMAIL=${ADMIN_EMAIL:-admin@jama.local}
- ADMIN_PASS=${ADMIN_PASS:-Admin@1234}
- ADMPW_RESET=${ADMPW_RESET:-false}
- JWT_SECRET=${JWT_SECRET:?JWT_SECRET is required}
- APP_NAME=${APP_NAME:-jama}
- DEFCHAT_NAME=${DEFCHAT_NAME:-General Chat}
- DB_HOST=db
- DB_PORT=5432
- DB_NAME=${DB_NAME:-jama}
- DB_USER=${DB_USER:-jama}
- DB_PASSWORD=${DB_PASSWORD:?DB_PASSWORD is required}
- HOST_DOMAIN=${HOST_DOMAIN:?HOST_DOMAIN is required in host mode}
- HOST_ADMIN_KEY=${HOST_ADMIN_KEY:?HOST_ADMIN_KEY is required in host mode}
volumes:
- jama_uploads:/app/uploads
depends_on:
db:
condition: service_healthy
healthcheck:
test: ["CMD", "wget", "-q", "--spider", "http://localhost:3000/api/health"]
interval: 30s
timeout: 10s
retries: 3
db:
image: postgres:16-alpine
container_name: ${PROJECT_NAME:-jama}_db
restart: unless-stopped
environment:
- POSTGRES_DB=${DB_NAME:-jama}
- POSTGRES_USER=${DB_USER:-jama}
- POSTGRES_PASSWORD=${DB_PASSWORD:?DB_PASSWORD is required}
volumes:
- jama_db:/var/lib/postgresql/data
healthcheck:
test: ["CMD-SHELL", "pg_isready -U ${DB_USER:-jama} -d ${DB_NAME:-jama}"]
interval: 5s
timeout: 5s
retries: 10
caddy:
# Use a Caddy build with your DNS provider plugin.
# Pre-built images: https://github.com/abiosoft/caddy-docker
# Or build your own: xcaddy build --with github.com/caddy-dns/cloudflare
image: caddy:2-alpine
container_name: ${PROJECT_NAME:-jama}_caddy
restart: unless-stopped
ports:
- "80:80"
- "443:443"
- "443:443/udp" # HTTP/3
environment:
- CF_API_TOKEN=${CF_API_TOKEN:-} # DNS provider token for wildcard certs
volumes:
- ./Caddyfile.example:/etc/caddy/Caddyfile:ro
- caddy_data:/data
- caddy_config:/config
- /var/log/caddy:/var/log/caddy
depends_on:
- jama
volumes:
jama_db:
driver: local
jama_uploads:
driver: local
caddy_data:
driver: local
caddy_config:
driver: local