-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdocker-compose.yml
More file actions
90 lines (83 loc) · 2.68 KB
/
docker-compose.yml
File metadata and controls
90 lines (83 loc) · 2.68 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
services:
redis:
image: redis:7-alpine
ports:
- "6379:6379"
command: redis-server --maxmemory 256mb --maxmemory-policy allkeys-lru
auth-db:
image: postgres:16
environment:
POSTGRES_DB: auth_db
POSTGRES_USER: admin
POSTGRES_PASSWORD: admin
ports:
- "5433:5432"
product-db:
image: postgres:16
environment:
POSTGRES_DB: product_db
POSTGRES_USER: admin
POSTGRES_PASSWORD: admin
ports:
- "5434:5432"
db-admin:
image: dpage/pgadmin4:latest
container_name: db-admin
environment:
PGADMIN_DEFAULT_EMAIL: admin@example.com
PGADMIN_DEFAULT_PASSWORD: admin
ports:
- "5050:80"
depends_on:
- auth-db
- product-db
# ── Azure AD simulation ────────────────────────────────────────────────────
# Keycloak simulates Azure AD for local development.
# Admin UI: http://localhost:8180 (admin / admin)
# JWKS: http://localhost:8180/realms/corporate/protocol/openid-connect/certs
# Issuer: http://localhost:8180/realms/corporate
# See auth/docker/keycloak/README.md for realm setup instructions.
keycloak:
image: quay.io/keycloak/keycloak:24.0
container_name: keycloak
command: start-dev
environment:
KC_DB: dev-file
KEYCLOAK_ADMIN: admin
KEYCLOAK_ADMIN_PASSWORD: admin
KC_HTTP_PORT: 8180
volumes:
- keycloak_data:/opt/keycloak/data
ports:
- "8180:8180"
# ── Corporate LDAP simulation ──────────────────────────────────────────────
# OpenLDAP simulates a corporate Active Directory LDAP for group sync.
# Base DN: dc=corp,dc=example,dc=com
# Admin DN: cn=admin,dc=corp,dc=example,dc=com password: admin
# Bootstrap LDIF: auth/docker/ldap/bootstrap.ldif (loaded at first start)
openldap:
image: osixia/openldap:1.5.0
container_name: openldap
command: ["--copy-service"]
environment:
LDAP_ORGANISATION: "Corp Example"
LDAP_DOMAIN: corp.example.com
LDAP_ADMIN_PASSWORD: admin
volumes:
- ./auth/docker/ldap/bootstrap.ldif:/container/service/slapd/assets/config/bootstrap/ldif/custom/bootstrap.ldif
ports:
- "389:389"
- "636:636"
# phpLDAPadmin — browser UI for inspecting / managing OpenLDAP
phpldapadmin:
image: osixia/phpldapadmin:0.9.0
container_name: phpldapadmin
environment:
PHPLDAPADMIN_LDAP_HOSTS: openldap
PHPLDAPADMIN_HTTPS: "false"
ports:
- "6443:80"
depends_on:
- openldap
volumes:
keycloak_data: