services: backend: build: context: ./backend dockerfile: Dockerfile container_name: qquiz_backend environment: - DATABASE_URL=sqlite+aiosqlite:////app/data/qquiz.db - SECRET_KEY=${SECRET_KEY:?Set SECRET_KEY to a random string of at least 32 characters} - ADMIN_PASSWORD=${ADMIN_PASSWORD:?Set ADMIN_PASSWORD to a strong password of at least 12 characters} - UPLOAD_DIR=/app/uploads env_file: - .env volumes: - sqlite_data:/app/data - upload_files:/app/uploads ports: - "8000:8000" healthcheck: test: ["CMD", "python", "-c", "import sys, urllib.request; urllib.request.urlopen('http://127.0.0.1:8000/health', timeout=5); sys.exit(0)"] interval: 30s timeout: 10s retries: 5 start_period: 40s frontend: build: context: ./web dockerfile: Dockerfile container_name: qquiz_frontend ports: - "3000:3000" environment: - API_BASE_URL=http://backend:8000 depends_on: backend: condition: service_started healthcheck: test: ["CMD", "node", "-e", "fetch('http://127.0.0.1:3000/login').then((r) => process.exit(r.ok ? 0 : 1)).catch(() => process.exit(1))"] interval: 30s timeout: 10s retries: 5 start_period: 40s volumes: sqlite_data: upload_files: