services: postgresql: env_file: - .env environment: POSTGRES_DB: ${PG_DB:-authentik} POSTGRES_PASSWORD: ${PG_PASS:?database password required} POSTGRES_USER: ${PG_USER:-authentik} healthcheck: interval: 30s retries: 5 start_period: 20s test: - CMD-SHELL - pg_isready -d $${POSTGRES_DB} -U $${POSTGRES_USER} timeout: 5s image: docker.io/library/postgres:16-alpine restart: unless-stopped volumes: - /home/soenke/docker-data/authentik/database:/var/lib/postgresql/data labels: kuma.tools.tag.name: 'Tools' kuma.tools.tag.color: '#FF9900' kuma.homelab.tag.name: 'homelab' kuma.homelab.tag.color: '#FF9955' kuma.authentik.http.name: 'Authentik' kuma.authentik.http.url: 'https://auth.domr.ovh' kuma.authentik.http.tag_names: '[{"name": "tools", "value": "" }, {"name": "homelab", "value": "" }]' homepage.group: Hosting homepage.name: Authentik homepage.icon: authentik.png homepage.href: https://auth.domr.ovh/ homepage.description: Authentik Oauth2 Service homepage.widget.type: authentik homepage.widget.url: https://auth.domr.ovh/ homepage.widget.key: slGO2rsG4xTObyuzRYPEe4Gs92X8TeNblIYOstX0rCID1WEv6wT5wkz4filJ server: command: server depends_on: postgresql: condition: service_healthy env_file: - .env environment: AUTHENTIK_POSTGRESQL__HOST: postgresql AUTHENTIK_POSTGRESQL__NAME: ${PG_DB:-authentik} AUTHENTIK_POSTGRESQL__PASSWORD: ${PG_PASS} AUTHENTIK_POSTGRESQL__USER: ${PG_USER:-authentik} AUTHENTIK_SECRET_KEY: ${AUTHENTIK_SECRET_KEY:?secret key required} image: ${AUTHENTIK_IMAGE:-ghcr.io/goauthentik/server}:${AUTHENTIK_TAG:-2025.12.3} ports: - "${COMPOSE_PORT_HTTP:-9000}:9000" - "${COMPOSE_PORT_HTTPS:-9443}:9443" restart: unless-stopped volumes: - /home/soenke/docker-data/authentik/data:/data - /home/soenke/docker-data/authentik/media:/media - /home/soenke/docker-data/authentik/custom-templates:/templates worker: command: worker depends_on: postgresql: condition: service_healthy env_file: - .env environment: AUTHENTIK_POSTGRESQL__HOST: postgresql AUTHENTIK_POSTGRESQL__NAME: ${PG_DB:-authentik} AUTHENTIK_POSTGRESQL__PASSWORD: ${PG_PASS} AUTHENTIK_POSTGRESQL__USER: ${PG_USER:-authentik} AUTHENTIK_SECRET_KEY: ${AUTHENTIK_SECRET_KEY:?secret key required} image: ${AUTHENTIK_IMAGE:-ghcr.io/goauthentik/server}:${AUTHENTIK_TAG:-2025.12.3} restart: unless-stopped user: root volumes: - /var/run/docker.sock:/var/run/docker.sock - /home/soenke/docker-data/authentik/media:/media - /home/soenke/docker-data/authentik/certs:/certs - /home/soenke/docker-data/authentik/custom-templates:/templates volumes: database: driver: local