Jafner.net/homelab/fighter/config/keycloak/docker-compose.yml

95 lines
2.8 KiB
YAML

version: '3.9'
services:
keycloak:
image: quay.io/keycloak/keycloak@sha256:33825b7d2d9e317215939851e10b1e184b4f876de1b5b25cf448e425c47802bd
container_name: keycloak_keycloak
networks:
keycloak:
aliases:
- keycloak
web:
aliases:
- keycloak
restart: "no"
depends_on:
- postgres
command: start
env_file:
- path: ./keycloak.env
required: true
- path: ./keycloak_secrets.env
required: false
labels:
traefik.http.routers.keycloak.rule: Host(`keycloak.jafner.net`)
traefik.http.routers.keycloak.tls.certresolver: lets-encrypt
traefik.http.routers.keycloak.middlewares: keycloak-redirect
traefik.http.services.keycloak.loadbalancer.server.port: 8080
traefik.http.middlewares.keycloak-redirect.redirectregex.regex: ^https:\\/\\/([^\\//]+)\\/?$$"
traefik.http.middlewares.keycloak-redirect.redirectregex.replacement: https://$$1/admin"
forwardauth:
image: thomseddon/traefik-forward-auth@sha256:69a2c985d2c518b6f0e77161a98628a148a5d964e4e84fc52cc62e19bb4da634
container_name: keycloak_forwardauth
networks:
web:
aliases:
- forwardauth
restart: "no"
command: "./traefik-forward-auth"
depends_on:
- keycloak
env_file:
- path: ./forwardauth.env
required: true
- path: ./forwardauth_secrets.env
required: false
labels:
- "traefik.enable=false"
- "traefik.http.routers.forwardauth.rule=Path(`/_oauth`)"
- "traefik.http.routers.forwardauth.tls.certresolver=lets-encrypt"
forwardauth-privileged:
image: thomseddon/traefik-forward-auth@sha256:69a2c985d2c518b6f0e77161a98628a148a5d964e4e84fc52cc62e19bb4da634
container_name: keycloak_forwardauth-privileged
networks:
web:
aliases:
- forwardauth-privileged
restart: "no"
command: "./traefik-forward-auth --whitelist=jafner425@gmail.com"
depends_on:
- keycloak
env_file:
- path: ./forwardauth-privileged.env
required: true
- path: ./forwardauth-privileged_secrets.env
required: false
labels:
- "traefik.enable=false"
- "traefik.http.routers.forwardauth-privileged.rule=Path(`/_oauth`)"
- "traefik.http.routers.forwardauth-privileged.tls.certresolver=lets-encrypt"
postgres:
image: postgres@sha256:93c8b6f9c1a297790b1e18efd8fc2964bf5f346425a245c662b042ae371b929a
container_name: keycloak_postgres
networks:
- keycloak
env_file:
- path: ./postgres.env
required: true
- path: ./postgres_secrets.env
required: false
- postgres.env
- postgres_secrets.env
volumes:
- postgres_data:/var/lib/postgresql/data
networks:
web:
external: true
keycloak:
volumes:
postgres_data: