mirror of
https://github.com/plankanban/planka.git
synced 2025-07-18 20:59:44 +02:00
105 lines
3.2 KiB
YAML
105 lines
3.2 KiB
YAML
version: '3'
|
||
|
||
services:
|
||
planka:
|
||
image: ghcr.io/plankanban/planka:latest
|
||
restart: on-failure
|
||
volumes:
|
||
- user-avatars:/app/public/user-avatars
|
||
- project-background-images:/app/public/project-background-images
|
||
- attachments:/app/private/attachments
|
||
ports:
|
||
- 3000:1337
|
||
environment:
|
||
- BASE_URL=http://localhost:3000
|
||
- DATABASE_URL=postgresql://postgres@postgres/planka
|
||
- SECRET_KEY=notsecretkey
|
||
|
||
# - TRUST_PROXY=0
|
||
# - TOKEN_EXPIRES_IN=365 # In days
|
||
|
||
# related: https://github.com/knex/knex/issues/2354
|
||
# As knex does not pass query parameters from the connection string we
|
||
# have to use environment variables in order to pass the desired values, e.g.
|
||
# - PGSSLMODE=<value>
|
||
|
||
# Configure knex to accept SSL certificates
|
||
# - KNEX_REJECT_UNAUTHORIZED_SSL_CERTIFICATE=false
|
||
|
||
# - DEFAULT_ADMIN_EMAIL=demo@demo.demo # Do not remove if you want to prevent this user from being edited/deleted
|
||
# - DEFAULT_ADMIN_PASSWORD=demo
|
||
# - DEFAULT_ADMIN_NAME=Demo Demo
|
||
# - DEFAULT_ADMIN_USERNAME=demo
|
||
|
||
# - SHOW_DETAILED_AUTH_ERRORS=false # Set to true to show more detailed authentication error messages. It should not be enabled without a rate limiter for security reasons.
|
||
|
||
# - ALLOW_ALL_TO_CREATE_PROJECTS=true
|
||
|
||
# - OIDC_ISSUER=
|
||
# - OIDC_CLIENT_ID=
|
||
# - OIDC_CLIENT_SECRET=
|
||
# - OIDC_ID_TOKEN_SIGNED_RESPONSE_ALG=
|
||
# - OIDC_USERINFO_SIGNED_RESPONSE_ALG=
|
||
# - OIDC_SCOPES=openid email profile
|
||
# - OIDC_RESPONSE_MODE=fragment
|
||
# - OIDC_USE_DEFAULT_RESPONSE_MODE=true
|
||
# - OIDC_ADMIN_ROLES=admin
|
||
# - OIDC_CLAIMS_SOURCE=userinfo
|
||
# - OIDC_EMAIL_ATTRIBUTE=email
|
||
# - OIDC_NAME_ATTRIBUTE=name
|
||
# - OIDC_USERNAME_ATTRIBUTE=preferred_username
|
||
# - OIDC_ROLES_ATTRIBUTE=groups
|
||
# - OIDC_IGNORE_USERNAME=true
|
||
# - OIDC_IGNORE_ROLES=true
|
||
# - OIDC_ENFORCED=true
|
||
|
||
# Email Notifications (https://nodemailer.com/smtp/)
|
||
# - SMTP_HOST=
|
||
# - SMTP_PORT=587
|
||
# - SMTP_NAME=
|
||
# - SMTP_SECURE=true
|
||
# - SMTP_USER=
|
||
# - SMTP_PASSWORD=
|
||
# - SMTP_FROM="Demo Demo" <demo@demo.demo>
|
||
# - SMTP_TLS_REJECT_UNAUTHORIZED=false
|
||
|
||
# Optional fields: accessToken, events, excludedEvents
|
||
# - |
|
||
# WEBHOOKS=[{
|
||
# "url": "http://localhost:3001",
|
||
# "accessToken": "notaccesstoken",
|
||
# "events": ["cardCreate", "cardUpdate", "cardDelete"],
|
||
# "excludedEvents": ["notificationCreate", "notificationUpdate"]
|
||
# }]
|
||
|
||
# - SLACK_BOT_TOKEN=
|
||
# - SLACK_CHANNEL_ID=
|
||
|
||
# - GOOGLE_CHAT_WEBHOOK_URL=
|
||
|
||
# - TELEGRAM_BOT_TOKEN=
|
||
# - TELEGRAM_CHAT_ID=
|
||
# - TELEGRAM_THREAD_ID=
|
||
depends_on:
|
||
postgres:
|
||
condition: service_healthy
|
||
|
||
postgres:
|
||
image: postgres:16-alpine
|
||
restart: on-failure
|
||
volumes:
|
||
- db-data:/var/lib/postgresql/data
|
||
environment:
|
||
- POSTGRES_DB=planka
|
||
- POSTGRES_HOST_AUTH_METHOD=trust
|
||
healthcheck:
|
||
test: ["CMD-SHELL", "pg_isready -U postgres -d planka"]
|
||
interval: 10s
|
||
timeout: 5s
|
||
retries: 5
|
||
|
||
volumes:
|
||
user-avatars:
|
||
project-background-images:
|
||
attachments:
|
||
db-data:
|