services: postgres: image: postgres:16-alpine ports: - "5433:5432" environment: POSTGRES_DB: capakraken POSTGRES_USER: capakraken POSTGRES_PASSWORD: capakraken_dev command: > postgres -c log_connections=on -c log_disconnections=on -c log_statement=ddl -c log_line_prefix='%t [%p] %u@%d ' -c log_min_duration_statement=1000 volumes: - capakraken_pgdata:/var/lib/postgresql/data healthcheck: test: ["CMD-SHELL", "pg_isready -U capakraken -d capakraken"] interval: 5s timeout: 3s retries: 5 redis: image: redis:7-alpine ports: - "6380:6379" healthcheck: test: ["CMD", "redis-cli", "ping"] interval: 5s timeout: 3s retries: 5 pgadmin: image: dpage/pgadmin4 ports: - "5050:80" environment: PGADMIN_DEFAULT_EMAIL: admin@capakraken.dev PGADMIN_DEFAULT_PASSWORD: admin depends_on: postgres: condition: service_healthy app: build: context: . dockerfile: Dockerfile.dev ports: - "3100:3100" environment: DATABASE_URL: postgresql://capakraken:capakraken_dev@postgres:5432/capakraken REDIS_URL: redis://redis:6379 NEXTAUTH_URL: http://localhost:3100 NEXTAUTH_SECRET: dev-secret-change-in-production depends_on: postgres: condition: service_healthy redis: condition: service_healthy volumes: - .:/app - /app/node_modules - /app/.next profiles: - full postgres-test: image: postgres:16-alpine ports: - "5434:5432" environment: POSTGRES_DB: capakraken_test POSTGRES_USER: capakraken POSTGRES_PASSWORD: capakraken_test tmpfs: - /var/lib/postgresql/data profiles: - test volumes: capakraken_pgdata: