Files
turftracker/docker-compose.yml
Jake Kasper 08072c4404 asdfasdf
2025-09-02 07:46:06 -05:00

109 lines
3.5 KiB
YAML

version: '3.8'
networks:
proxy:
external: true
turftracker:
driver: bridge
services:
frontend:
build:
context: ./frontend
dockerfile: Dockerfile
environment:
- REACT_APP_API_URL=https://turftracker.kaspers.us/api
# Stabilize CRA dev server behind Traefik (WebSocket + polling)
- WDS_SOCKET_HOST=turftracker.kaspers.us
- WDS_SOCKET_PORT=443
- WDS_SOCKET_PATH=/ws
- CHOKIDAR_USEPOLLING=true
- WATCHPACK_POLLING=true
- WATCHPACK_POLLING_INTERVAL=1000
volumes:
- ./frontend:/app
- /app/node_modules
depends_on:
- backend
networks:
- proxy
- turftracker
labels:
- "traefik.enable=true"
- "traefik.http.routers.turftracker-frontend.rule=Host(`turftracker.kaspers.us`)"
- "traefik.http.routers.turftracker-frontend.entrypoints=websecure"
- "traefik.http.routers.turftracker-frontend.tls.certresolver=letsencrypt"
- "traefik.http.services.turftracker-frontend.loadbalancer.server.port=3000"
- "traefik.docker.network=proxy"
- "traefik.constraint=proxy-public"
restart: unless-stopped
backend:
build:
context: ./backend
dockerfile: Dockerfile
environment:
- NODE_ENV=development
- DB_HOST=db
- DB_PORT=5432
- DB_NAME=${DB_NAME:-turftracker}
- DB_USER=${DB_USER:-turftracker}
- DB_PASSWORD=${DB_PASSWORD:-password123}
- JWT_SECRET=${JWT_SECRET:-dev-secret-key-change-in-production-12345}
- AUTHENTIK_CLIENT_ID=${AUTHENTIK_CLIENT_ID:-}
- AUTHENTIK_CLIENT_SECRET=${AUTHENTIK_CLIENT_SECRET:-}
- AUTHENTIK_BASE_URL=${AUTHENTIK_BASE_URL:-}
- AUTHENTIK_CALLBACK_URL=${AUTHENTIK_CALLBACK_URL:-https://turftracker.kaspers.us/api/auth/authentik/callback}
- WEATHER_API_KEY=${WEATHER_API_KEY:-}
- FRONTEND_URL=https://turftracker.kaspers.us
volumes:
- ./backend:/app
- /app/node_modules
depends_on:
- db
networks:
- proxy
- turftracker
labels:
- "traefik.enable=true"
- "traefik.http.routers.turftracker-backend.rule=Host(`turftracker.kaspers.us`) && PathPrefix(`/api`)"
- "traefik.http.routers.turftracker-backend.entrypoints=websecure"
- "traefik.http.routers.turftracker-backend.tls.certresolver=letsencrypt"
- "traefik.http.services.turftracker-backend.loadbalancer.server.port=5000"
- "traefik.docker.network=proxy"
restart: unless-stopped
db:
image: postgres:15-alpine
environment:
- POSTGRES_USER=${DB_USER:-turftracker}
- POSTGRES_PASSWORD=${DB_PASSWORD:-password123}
- POSTGRES_DB=${DB_NAME:-turftracker}
volumes:
- postgres_data:/var/lib/postgresql/data
- ./database/init.sql:/docker-entrypoint-initdb.d/init.sql
networks:
- turftracker
restart: unless-stopped
# Database should not be exposed to proxy network for security
flyway:
image: flyway/flyway:9
depends_on:
- db
environment:
- FLYWAY_URL=jdbc:postgresql://db:5432/${DB_NAME:-turftracker}
- FLYWAY_USER=${DB_USER:-turftracker}
- FLYWAY_PASSWORD=${DB_PASSWORD:-password123}
# Uncomment if you need to baseline an existing DB without schema history
- FLYWAY_BASELINE_ON_MIGRATE=true
command: -locations=filesystem:/migrations migrate
volumes:
- ./database/migrations:/migrations:ro
networks:
- turftracker
# Not started automatically; run with: docker compose run --rm flyway migrate
volumes:
postgres_data: