--- version: "3.8" services: app: image: calcom.docker.scarf.sh/calcom/cal.com:v3.1.4 networks: - proxy - backend secrets: - db_password - nextauth_secret - calendso_encryption_key environment: - POSTGRES_USER=calendso - POSTGRES_PASSWORD_FILE=/run/secrets/db_password - POSTGRES_DB=calendso - POSTGRES_HOST=db - CALCOM_TELEMETRY_DISABLED=1 - "NEXT_PUBLIC_WEBAPP_URL=https://${DOMAIN}" - NEXTAUTH_SECRET_FILE=/run/secrets/nextauth_secret - CALENDSO_ENCRYPTION_KEY_FILE=/run/secrets/calendso_encryption_key - MS_GRAPH_CLIENT_ID - ZOOM_CLIENT_ID - EMAIL_FROM - EMAIL_SERVER_HOST - EMAIL_SERVER_PORT - EMAIL_SERVER_USER configs: - source: entrypoint_conf target: /docker-entrypoint.sh mode: 0555 entrypoint: ['/docker-entrypoint.sh'] deploy: update_config: failure_action: rollback order: start-first labels: - "traefik.enable=true" - "traefik.http.services.${STACK_NAME}_admin.loadbalancer.server.port=5555" - "traefik.http.routers.${STACK_NAME}_admin.rule=Host(`admin.${DOMAIN}`)" - "traefik.http.routers.${STACK_NAME}_admin.entrypoints=web-secure" - "traefik.http.routers.${STACK_NAME}_admin.tls.certresolver=${LETS_ENCRYPT_ENV}" - "traefik.http.routers.${STACK_NAME}_admin.service=${STACK_NAME}_admin" - "traefik.http.services.${STACK_NAME}.loadbalancer.server.port=3000" - "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}" - "traefik.http.routers.${STACK_NAME}.service=${STACK_NAME}" - "coop-cloud.${STACK_NAME}.version=0.4.0+v3.1.4" ## 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}" # healthcheck: # test: ["CMD", "curl", "-f", "http://localhost"] # interval: 30s # timeout: 10s # retries: 10 # start_period: 1m db: image: "postgres:13-alpine" networks: - backend secrets: - db_password environment: - POSTGRES_DB=calendso - POSTGRES_USER=calendso - POSTGRES_PASSWORD_FILE=/run/secrets/db_password volumes: - "postgres:/var/lib/postgresql/data" deploy: labels: backupbot.backup: "true" backupbot.backup.pre-hook: 'bash -c "mkdir -p /tmp/backup/ && PGPASSWORD=$$(cat $${POSTGRES_PASSWORD_FILE}) pg_dump -U $${POSTGRES_USER} $${POSTGRES_DB} > /tmp/backup/backup.sql"' backupbot.backup.post-hook: "rm -rf /tmp/backup" backupbot.backup.path: "/tmp/backup/" networks: proxy: external: true backend: volumes: postgres: secrets: db_password: external: true name: ${STACK_NAME}_db_password_${SECRET_DB_PASSWORD_VERSION} nextauth_secret: external: true name: ${STACK_NAME}_nextauth_secret_${SECRET_NEXTAUTH_SECRET_VERSION} calendso_encryption_key: external: true name: ${STACK_NAME}_calendso_encryption_key_${SECRET_CALENDSO_ENCRYPTION_KEY_VERSION} configs: entrypoint_conf: name: ${STACK_NAME}_entrypoint_conf_${ENTRYPOINT_CONF_VERSION} file: entrypoint.sh