version: '3.8' services: postgres: image: postgres:16-alpine environment: POSTGRES_DB: dikasterion POSTGRES_USER: dikasterion POSTGRES_PASSWORD: ${DB_PASSWORD:-dikasterion_secret} volumes: - postgres_data:/var/lib/postgresql/data ports: - "5432:5432" healthcheck: test: ["CMD-SHELL", "pg_isready -U dikasterion -d dikasterion"] interval: 5s timeout: 5s retries: 5 backend: build: context: ./backend dockerfile: Dockerfile environment: DATABASE_URL: postgresql+asyncpg://dikasterion:${DB_PASSWORD:-dikasterion_secret}@postgres:5432/dikasterion SECRET_KEY: ${SECRET_KEY:-super-secret-key-change-in-production} TELEGRAM_BOT_TOKEN: ${TELEGRAM_BOT_TOKEN:-} SMTP_HOST: ${SMTP_HOST:-} SMTP_PORT: ${SMTP_PORT:-587} SMTP_USER: ${SMTP_USER:-} SMTP_PASSWORD: ${SMTP_PASSWORD:-} ports: - "8000:8000" depends_on: postgres: condition: service_healthy volumes: - ./backend:/app command: uvicorn app.main:app --host 0.0.0.0 --port 8000 --reload frontend: build: context: ./frontend dockerfile: Dockerfile ports: - "3000:3000" environment: REACT_APP_API_URL: /api/v1 volumes: - ./frontend/src:/app/src - ./frontend/public:/app/public nginx: image: nginx:alpine ports: - "80:80" - "443:443" volumes: - ./nginx/nginx.conf:/etc/nginx/nginx.conf - ./nginx/ssl:/etc/nginx/ssl depends_on: - backend - frontend volumes: postgres_data: