blob: ef5a7b7291e544ac376a2936c9f69c82f3e028a5 (
plain)
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
91
92
93
94
95
|
services:
# ===================
# OpenLDAP (ARM-native, works great on M1/M2/M3)
# ===================
openldap:
image: osixia/openldap:1.5.0
container_name: openldap
environment:
- LDAP_ORGANISATION=Lab
- LDAP_DOMAIN=lab.local
- LDAP_BASE_DN=dc=lab,dc=local
- LDAP_ADMIN_PASSWORD=admin123
- LDAP_TLS=false
ports:
- "389:389"
- "636:636"
volumes:
- openldap-data:/var/lib/ldap
- openldap-config:/etc/ldap/slapd.d
restart: unless-stopped
# ===================
# Keycloak (OIDC/SAML Provider)
# ===================
keycloak:
image: quay.io/keycloak/keycloak:latest
container_name: keycloak
environment:
- KEYCLOAK_ADMIN=admin
- KEYCLOAK_ADMIN_PASSWORD=admin
- KC_HTTP_ENABLED=true
- KC_HOSTNAME_STRICT=false
ports:
- "8080:8080"
command: start-dev
depends_on:
- openldap
restart: unless-stopped
healthcheck:
test: ["CMD-SHELL", "exec 3<>/dev/tcp/localhost/8080"]
interval: 5s
timeout: 5s
retries: 12
# Disables HTTPS requirement and creates lab realm
keycloak-init:
image: curlimages/curl:latest
container_name: keycloak-init
depends_on:
keycloak:
condition: service_healthy
entrypoint: /bin/sh
command:
- -c
- |
echo "Waiting for Keycloak..."
sleep 10
echo "Getting admin token..."
TOKEN=$$(curl -s -X POST "http://keycloak:8080/realms/master/protocol/openid-connect/token" \
-H "Content-Type: application/x-www-form-urlencoded" \
-d "username=admin" \
-d "password=admin" \
-d "grant_type=password" \
-d "client_id=admin-cli" | sed 's/.*"access_token":"\([^"]*\)".*/\1/')
echo "Disabling SSL on master realm..."
curl -s -X PUT "http://keycloak:8080/admin/realms/master" \
-H "Authorization: Bearer $$TOKEN" \
-H "Content-Type: application/json" \
-d '{"sslRequired":"NONE"}'
echo "Creating lab realm..."
curl -s -X POST "http://keycloak:8080/admin/realms" \
-H "Authorization: Bearer $$TOKEN" \
-H "Content-Type: application/json" \
-d '{"realm":"lab","enabled":true,"sslRequired":"NONE"}'
echo "Done - master and lab realms ready with SSL disabled"
restart: "no"
# ===================
# LDAP Admin UI (browse LDAP visually)
# ===================
ldap-admin:
image: osixia/phpldapadmin
container_name: ldap-admin
environment:
- PHPLDAPADMIN_LDAP_HOSTS=openldap
- PHPLDAPADMIN_HTTPS=false
ports:
- "8081:80"
depends_on:
- openldap
restart: unless-stopped
volumes:
openldap-data:
openldap-config:
|