--- version: "3.8" services: app: networks: - backend - proxy image: outlinewiki/outline:0.60.3 volumes: - outline_data:/opt/outline environment: - AWS_ACCESS_KEY_ID - AWS_REGION - AWS_S3_ACL - AWS_S3_FORCE_PATH_STYLE - AWS_S3_UPLOAD_BUCKET_NAME - AWS_S3_UPLOAD_BUCKET_URL - AWS_S3_UPLOAD_MAX_SIZE - AWS_SECRET_ACCESS_KEY - DATABASE_URL=postgres://user:pass@${STACK_NAME}_postgres:5432/outline - DATABASE_URL_TEST=postgres://user:pass@${STACK_NAME}_postgres:5432/outline-test - FORCE_HTTPS=true - OIDC_AUTH_URI - OIDC_CLIENT_ID - OIDC_CLIENT_SECRET - OIDC_DISPLAY_NAME - OIDC_SCOPES - OIDC_TOKEN_URI - OIDC_USERINFO_URI - OIDC_USERNAME_CLAIM - PGSSLMODE=disable - REDIS_URL=redis://${STACK_NAME}_redis:6379 - SECRET_KEY - TEAM_LOGO - URL=https://$DOMAIN - UTILS_SECRET deploy: labels: - "traefik.enable=true" - "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}" - "coop-cloud.${STACK_NAME}.version=0.1.0+0.60.3" ## 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}" redis: image: redis networks: - backend postgres: image: postgres:11 networks: - backend environment: POSTGRES_DB: outline POSTGRES_PASSWORD: pass POSTGRES_USER: user volumes: - "postgres_data:/var/lib/postgresql/data" networks: proxy: external: true backend: volumes: outline_data: postgres_data: