--- services: blinko: image: blinkospace/blinko:latest container_name: blinko environment: TZ: ${TIMEZONE:-Europe/Amsterdam} NODE_ENV: production NEXTAUTH_URL: https://${TRAEFIK_HOST} NEXT_PUBLIC_BASE_URL: https://${TRAEFIK_HOST} NEXTAUTH_SECRET: ${BLINKO_NEXTAUTH_SECRET} DATABASE_URL: postgresql://blinko:blinko@blinko_db:5432/blinko volumes: - ../.data/blinko/app:/app/.blinko depends_on: db: condition: service_healthy restart: always labels: - "traefik.enable=true" - "traefik.http.middlewares.blinko-redirect-web-secure.redirectscheme.scheme=https" - "traefik.http.routers.blinko-web.middlewares=blinko-redirect-web-secure" - "traefik.http.routers.blinko-web.rule=Host(`${TRAEFIK_HOST}`)" - "traefik.http.routers.blinko-web.entrypoints=web" - "traefik.http.routers.blinko-web-secure.rule=Host(`${TRAEFIK_HOST}`)" - "traefik.http.routers.blinko-web-secure.tls.certresolver=resolver" - "traefik.http.routers.blinko-web-secure.entrypoints=web-secure" - "traefik.http.routers.blinko-web-secure.middlewares=security-headers@file" - "traefik.http.services.blinko-web-secure.loadbalancer.server.port=1111" - "traefik.docker.network=${NETWORK_NAME}" - "com.centurylinklabs.watchtower.enable=true" networks: - compose_network db: image: postgres:14-alpine container_name: blinko_db environment: POSTGRES_DB: blinko POSTGRES_USER: blinko POSTGRES_PASSWORD: blinko volumes: - ../.data/blinko/db:/var/lib/postgresql/data restart: always healthcheck: test: ["CMD-SHELL", "pg_isready -U $${POSTGRES_USER} -d $${POSTGRES_DB}"] interval: 5s timeout: 5s retries: 5 networks: - compose_network networks: compose_network: name: ${NETWORK_NAME} external: true