--- version: "3.8" services: app: image: farmos/farmos:2.x volumes: #- farmos_sites:/opt/drupal/ - farmos_sites:/opt/drupal/web/sites/ environment: - ACCOUNT_MAIL - SITE_NAME - SITE_MAIL - FARM_MODULES secrets: - db_password networks: - proxy - internal depends_on: - db deploy: restart_policy: condition: on-failure labels: - "traefik.enable=true" - "traefik.http.services.${STACK_NAME}.loadbalancer.server.port=80" - "traefik.http.routers.${STACK_NAME}.rule=Host(`${DOMAIN}`${EXTRA_DOMAINS})" - "traefik.http.routers.${STACK_NAME}.entrypoints=web-secure" - "traefik.http.routers.${STACK_NAME}.tls.certresolver=${LETS_ENCRYPT_ENV}" ## Redirect from EXTRA_DOMAINS to DOMAIN #- "traefik.http.routers.${STACK_NAME}.middlewares=${STACK_NAME}-redirect" #- "traefik.http.middlewares.${STACK_NAME}-redirect.headers.SSLForceHost=true" #- "traefik.http.middlewares.${STACK_NAME}-redirect.headers.SSLHost=${DOMAIN}" - "coop-cloud.${STACK_NAME}.version=" # healthcheck: # test: ["CMD", "curl", "-f", "http://localhost"] # interval: 30s # timeout: 10s # retries: 10 # start_period: 1m db: image: postgres:12 networks: - internal volumes: - postgres_data:/var/lib/postgresql/data secrets: - db_password environment: POSTGRES_USER: farm POSTGRES_PASSWORD_FILE: /run/secrets/db_password POSTGRES_DB: farm deploy: labels: backupbot.backup: "true" backupbot.backup.pre-hook: "bash -c 'PGPASSWORD=farm pg_dump -U farm farm > /tmp/backup.sql'" backupbot.backup.post-hook: "rm -f /tmp/backup.sql" backupbot.backup.path: "/tmp/backup.sql" networks: proxy: external: true internal: volumes: farmos_sites: postgres_data: secrets: db_password: external: true name: ${STACK_NAME}_db_password_${SECRET_DB_PASSWORD_VERSION}