--- version: "3.8" services: app: networks: - backend - proxy image: outlinewiki/outline:0.59.0 volumes: - outline_data:/opt/outline depends_on: - postgres - redis - s3 environment: - DATABASE_URL=postgres://user:pass@${STACK_NAME}_postgres:5532/outline - DATABASE_URL_TEST=postgres://user:pass@${STACK_NAME}_postgres:5532/outline-test - REDIS_URL=redis://${STACK_NAME}redis:6479 - URL=https://$DOMAIN - FORCE_HTTPS=true - SECRET_KEY - UTILS_SECRET - AWS_ACCESS_KEY_ID - AWS_SECRET_ACCESS_KEY - AWS_REGION - AWS_S3_UPLOAD_BUCKET_URL - AWS_S3_UPLOAD_BUCKET_NAME - AWS_S3_UPLOAD_MAX_SIZE - AWS_S3_FORCE_PATH_STYLE - AWS_S3_ACL - OIDC_CLIENT_ID - OIDC_CLIENT_SECRET - OIDC_AUTH_URI - OIDC_TOKEN_URI - OIDC_USERINFO_URI - OIDC_USERNAME_CLAIM - OIDC_DISPLAY_NAME - OIDC_SCOPES 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}" ## 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 networks: - backend environment: POSTGRES_USER: user POSTGRES_PASSWORD: pass POSTGRES_DB: outline s3: image: lphoward/fake-s3 networks: - backend volumes: - fakes3_data:/fakes3_root #healthcheck: # test: ["CMD", "curl", "-f", "http://localhost:4569"] # interval: 30s # timeout: 10s # retries: 10 # start_period: 1m networks: proxy: external: true backend: volumes: outline_data: fakes3_data: