Zuletzt geändert von Jonas Mayer am 2022/05/25 00:02

Von Version 31.2
bearbeitet von David Haido
am 2022/05/02 18:14
Änderungskommentar: Update document after refactoring.
Auf Version 51.1
bearbeitet von Jonas Mayer
am 2022/05/04 14:44
Änderungskommentar: Es gibt keinen Kommentar für diese Version

Zusammenfassung

Details

Seiteneigenschaften
Titel
... ... @@ -1,1 +1,1 @@
1 -Geändert: LDAP Admin-Benutzer und ReadOnly-Benutzer
1 +Geändert: LDAP Admin-Benutzer und ReadOnly-Benutzer im logosrv
Dokument-Autor
... ... @@ -1,1 +1,1 @@
1 -XWiki.davidhaido@sbede
1 +XWiki.jonasmayer@sbede
Inhalt
... ... @@ -1,43 +1,47 @@
1 -(% style="color:#000000" %)Um externe oder interne Dienste über LDAPS einzubinden, gibt es nach wie vor den sogenannten LDAP-Admin und den seit der Umstellung auf LDAPS neu hinzugefügten ReadOnly-Benutzer.
1 +(% style="color:#000000" %)Um externe oder interne Dienste über das LDAPS-Protokoll einzubinden, gibt es seit Puppet-Version 1.3.22 neben dem sogenannten LDAP-Admin Konto einen neu hinzugefügten ReadOnly-Benutzer zur Anmeldung am integrierten OpenLDAP-Verzeichnisdienst.
2 2  
3 -(% style="color:#000000" %)In diesem Artikel erfahren Sie, wo Sie die Benutzernamen & Kennwörter der zwei Benutzer finden und welche Nutzer sich für welches Vorhaben am besten eignen.
3 +(% style="color:#000000" %)In diesem Artikel erfahren Sie, wo Sie die Benutzernamen & Kennwörter der zwei Benutzer finden und welches Konto sich für welches Vorhaben am besten eignen.
4 4  
5 -(% style="color:#000000" %)[[image:Grafik für LDAp.png||height="331" width="622"]]
5 +----
6 6  
7 -=== ===
7 +{{toc start="2"/}}
8 8  
9 -=== (% style="color:#000000" %)__**LDAP-Admin Benutzer**__(%%) ===
10 10  
10 +(% style="color:#000000" %)[[image:Grafik für LDAp.png||height="331" width="622"]]
11 11  
12 -=== (% style="color:#000000" %)__Nutzungsgebiet:__(%%) ===
13 13  
14 -(% style="color:#000000" %)Der LDAP-Admin Benutzer ist mit äußerster Vorsicht einzusetzen, da dieser einen beinahe uneingeschränkten Zugriff auf das Abrufen und Bearbeiten der Nutzerattribute des Servers besitzt. Daher sollte der Benutzer nur möglichst Intern eingesetzt werden.
13 +== (% style="color:#000000" %)__**Übersicht der Benutzer**__(%%) ==
15 15  
16 -(% style="color:#000000" %)Sollten die Daten des Admins in unbefugte Hände gelangen, stellt dies ein massives datenschutz- und sicherheitstechnisches Problem dar. **__Von einem externen Gebrauch ist daher strengstens abzuraten!__**
17 17  
16 +=== (% style="color:#000000" %)**LDAP-Admin Benutzer:**(%%) ===
18 18  
19 -==== (% style="color:#000000" %)__Benutzername & Kennwort__(%%) ====
18 +(% style="color:#000000; font-size:20px" %)__Nutzungsgebiet:__
20 20  
21 -====== ======
20 +(% style="color:#000000" %)Der LDAP-Admin Benutzer ist mit äußerster Vorsicht einzusetzen, da dieser einen beinahe uneingeschränkten (Schreib-)Zugriff auf den Inhalt des OpenLDAP-Verzeichnisdienst sowie die Nutzerattribute besitzt. Daher sollte der Benutzer möglichst nur intern durch LogoDIDACT-integrierte Dienste zum Einsatz kommen.
22 22  
23 -====== (% style="color:#000000" %)__Benutzername__(%%) ======
22 +(% style="color:#000000" %)Sollten die Daten des LDAP-Admins in unbefugte Hände gelangen, stellt dies ein massives datenschutz- und sicherheitstechnisches Problem dar. **__Von einem externen Gebrauch des Benutzerkontos ist daher strengstens abzuraten!__**
24 24  
25 -(% style="color:#000000" %)Der Benutzername des LDAP Admins wäre:
26 26  
25 +(% class="wikigeneratedid" id="HZugangsdaten:" %)
26 +(% style="color:#000000; font-size:20px" %)__Zugangsdaten:__
27 +
28 +(% class="wikigeneratedid" id="HBenutzername" %)
29 +(% style="color:#000000" %)Der Benutzername des LDAP Admins lautet:
30 +
27 27  {{code language="bash"}}
28 28  cn=ldap-admin
29 29  {{/code}}
30 30  
31 -====== ======
32 32  
33 -====== (% style="color:#000000" %)__Attribute des Benutzernamens__(%%) ======
36 +(% class="wikigeneratedid" id="HAttributedesBenutzernamens" %)
37 +(% style="color:#000000; font-size:16px" %)__Vollständiger Benutzername__
34 34  
35 -(% style="color:#000000" %)Die Attribute des LDAP Namens sind über ein zusätzliches Programm auszulesen wie z.B. die Software LDAP Admin auszulesen. In diesem Beispiel wären die Attribute {{code language="bash"}}dc=schule,dc=local{{/code}}. Dies kann von Installation zu Installation abweichen und wird durch die Intern verwendete DNS Domain bestimmt.
39 +(% style="color:#000000" %)Die BaseDN als Einstiegspunkt zum LDAP-Verzeichnisdienst kann über ein zusätzliches Programm ausgelesen werden, z.B. über das freie Tool LDAP Admin. In diesem Beispiel lautet die BaseDN {{code language="bash"}}dc=schule,dc=local{{/code}}. Dies kann von Installation zu Installation abweichen und wird durch die intern verwendete DNS Domain bestimmt, hier im Beispiel handelt es sich um den Standardwert.
36 36  
37 37  (% style="color:#000000" %)[[image:1651243652049-471.png]]
38 38  
39 39  
40 -(% style="color:#000000" %)In diesem Beispiel wäre der Benutzername durch die ausgelesenen Attribute nun:
44 +(% style="color:#000000" %)In diesem Beispiel ergibt sich der vollständige Benutzername (sogenannter //Distinguished Name// des Benutzerkontos) durch Anfügen der BaseDN:
41 41  
42 42  {{code language="bash"}}
43 43  cn=ldap-admin,dc=schule,dc=local
... ... @@ -44,7 +44,8 @@
44 44  {{/code}}
45 45  
46 46  
47 -====== (% style="color:#000000" %)__Kennwort__(%%) ======
51 +(% class="wikigeneratedid" id="HKennwort" %)
52 +(% style="color:#000000; font-size:16px" %)__Kennwort__
48 48  
49 49  (% style="color:#000000" %)Das Kennwort ist im logosrv unter folgendem Pfad einsehbar:
50 50  
... ... @@ -52,7 +52,7 @@
52 52  root@logosrv:~ # cat /etc/ldap.secret
53 53  {{/code}}
54 54  
55 -(% style="color:#000000" %)Optional kann man das Passwort auch mit folgendem Befehl unter dem Punkt "Credentials" einsehen:
60 +(% style="color:#000000" %)Optional kann man das Passwort (sowie die gültige BaseDN als Suffix des Benutzernamens) auch mit folgendem Befehl unter dem Punkt "Credentials" einsehen:
56 56  
57 57  {{code language="bash"}}
58 58  root@logosrv:~ # ldconf -o
... ... @@ -59,44 +59,48 @@
59 59  {{/code}}
60 60  
61 61  
62 -=== (% style="color:#000000" %)**__LDAP-ReadOnly (ldap-ro) Benutzer__**(%%) ===
67 +=== (% style="color:#000000" %)**LDAP-ReadOnly (ldap-ro) Benutzer**(%%) ===
63 63  
69 +(% class="wikigeneratedid" id="HNutzungsgebiet:" %)
70 +(% style="color:#000000; font-size:20px" %)__Nutzungsgebiet:__
64 64  
65 -==== (% style="color:#000000" %)__Nutzungsgebiet:__(%%) ====
66 -
67 67  (% style="color:#000000" %)Der LDAP-ReadOnly Benutzer ist für die Verwendung von externen Diensten/Anbindungen gedacht.
68 68  
69 -(% style="color:#000000" %)Mögliche Nutzungsmöglichkeiten wären unteranderem die Nutzung und Einbindung  von einem extern gehosteten moodle, WebUntis oder einer Nextcloud.
74 +(% style="color:#000000" %)Mögliche Nutzungsszenarien wären unter anderem die Anbindung  von extern gehosteten Webdiensten (z.B. Moodle, WebUntis oder Nextcloud) an die LogoDIDACT-integrierte Benutzerdatenbank über das LDAP-Protokoll.
70 70  
71 71  
72 -==== (% style="color:#000000" %)__Benutzername & Passwort:__(%%) ====
73 73  
78 +(% class="wikigeneratedid" id="HBenutzername26Passwort:" %)
79 +(% style="color:#000000; font-size:20px" %)__Zugangsdaten:__
74 74  
75 -====== (% style="color:#000000" %)__Benutzername__(%%) ======
81 +(% class="wikigeneratedid" id="HBenutzername" %)
82 +(% style="color:#000000" %)Der Benutzername des LDAP ReadOnly Benutzers lautet:
76 76  
77 -(% style="color:#000000" %)Relevant für den Zugriff von Außen wäre folgender Benutzername:
78 -
79 79  {{code language="bash"}}
80 80  cn=ldap-ro
81 81  {{/code}}
82 82  
83 -====== (% id="cke_bm_979S" style="color: rgb(0, 0, 0); display: none" %)__ __(%%) ======
88 +====== (% id="cke_bm_979S" style="color:#000000; display:none" %)__ __(%%) ======
84 84  
85 -====== (% style="color:#000000" %)__Attribute des Benutzernamens__(%%) ======
86 86  
87 -(% style="color:#000000" %)Die Attribute des LDAP Namens sind über ein zusätzliches Programm auszulesen wie z.B. die Software LDAP Admin auszulesen. In diesem Beispiel wären die Attribute {{code language="bash"}}dc=schule,dc=local{{/code}}. Dies kann von Installation zu Installation abweichen und wird durch die Intern verwendete DNS Domain bestimmt.
88 88  
92 +(% class="wikigeneratedid" id="HAttributedesBenutzernamens" %)
93 +(% style="color:#000000; font-size:16px" %)__Vollständiger Benutzername__
94 +
95 +(% style="color:#000000" %)Die BaseDN als Einstiegspunkt zum LDAP-Verzeichnisdienst kann über ein zusätzliches Programm ausgelesen werden, z.B. über das freie Tool LDAP Admin. In diesem Beispiel lautet die BaseDN {{code language="bash"}}dc=schule,dc=local{{/code}}. Dies kann von Installation zu Installation abweichen und wird durch die intern verwendete DNS Domain bestimmt, hier im Beispiel handelt es sich um den Standardwert.
96 +
89 89  (% style="color:#000000" %)[[image:1651243652049-471.png]]
90 90  
91 91  
92 -(% style="color:#000000" %)In diesem Beispiel re der Benutzername durch die ausgelesenen Attribute nun:
100 +(% style="color:#000000" %)Im Unterschied zum vorherigen Benutzer steckt das Konto verschachtelt in der OU //services//. Dadurch ergibt sich nachfolgender, vollständiger Benutzername (sogenannter //Distinguished Name//):
93 93  
94 94  {{code language="bash"}}
95 -cn=ldap-ro,dc=schule,dc=local
103 +cn=ldap-ro,ou=services,dc=schule,dc=local
96 96  {{/code}}
97 97  
98 98  
99 -====== (% style="color:#000000" %)__Kennwort__(%%) ======
107 +(% class="wikigeneratedid" id="HKennwort" %)
108 +(% style="color:#000000; font-size:16px" %)__Kennwort__
100 100  
101 101  (% style="color:#000000" %)Das Kennwort ist im logosrv unter folgendem Pfad einsehbar:
102 102  
... ... @@ -105,10 +105,102 @@
105 105  {{/code}}
106 106  
107 107  
117 +(% style="color:#000000" %)Im Zuge der Anbindung externer Dienste sollte stets darauf geachtet werden, die verschlüsselte Form des LDAP-Protokolls (d.h. LDAPS auf TCP-Port 636) zu verwenden, damit sensible Information wie Benutzer-Zugangsdaten prinzipiell per SSL-Transportverschlüsselung versendet werden. Zur Nutzung der SSL-Transportverschlüsselung ist es wiederum wichtig, ein gültiges Let's Encrypt Zertifikat zu beantragen, damit die Verbindungssicherheit zwischen zwei Servern gewährleistet werden kann.
108 108  
109 -=== (% style="color:#000000" %)**__LDAP Attribute__**(%%) ===
110 110  
120 +== __**Ports über Firewall an Rev-Proxy weiterleiten**__ ==
111 111  
122 +Damit externe LDAPS-Verbindungen zum Server möglich werden, muss der TCP-Port 636 vom vorgeschalteten Router auf die externe IP-Adresse des LogoDIDACT Servers weitergeleitet werden. Vom ldhost wird die Verbindung dann entgegengenommen und abermals an den Rev-Proxy LXC-Container weitergeleitet. Die Einrichtung der zugehörige Poerweiterleitungs-Regel wird nachfolgend beschrieben.
123 +
124 +
125 +Wechseln Sie vom ldhost aus in das Verzeichnis der Shorewall:
126 +
127 +{{code language="bash"}}
128 +root@ldhosts:~ # cd /etc/shorewall
129 +{{/code}}
130 +
131 +
132 +Öffnen Sie die Datei rules mit einem Editor ihrer Wahl:
133 +
134 +{{code language="bash"}}
135 +root@ldhost:/etc/shorewall # vim rules
136 +{{/code}}
137 +
138 +
139 +Ergänzen Sie die Liste innerhalb der Datei um den obersten DNAT-Eintrag (lila eingefärbte Zeile). Dadurch werden externe Verbindungsanfragen auf Port 636 (LDAPS) vom ldhost zum rev-proxy LXC-Container weitergeleitet, so wie im Schaubild am Anfang des Artikels abgebildet. Falls diese Regel bereits vorhanden ist, können Sie den Schritt überspringen.
140 +
141 +(% class="box" %)
142 +(((
143 +(% style="color:#16a085" %)###
144 +# Shorewall version 4.0##(%%)
145 +(% style="color:#16a085" %)#(%%)
146 +(% style="color:#8e44ad" %)##**DNAT ext dmz:172.28.29.3 tcp 636**##(%%)##
147 +DNAT ext dmz:172.28.29.3 tcp 80,443
148 +DNAT ext dmz:172.28.29.2 tcp 1:21
149 +DNAT ext dmz:172.28.29.2 tcp 23:2221
150 +DNAT ext dmz:172.28.29.2 tcp 2223:65535
151 +DNAT ext dmz:172.28.29.2 udp 1:65535##
152 +)))
153 +
154 +
155 +Starten Sie nun die Firewall des ldhost neu:
156 +
157 +{{code language="bash"}}
158 +root@ldhosts:~ # /etc/init.d/shorewall restart
159 +{{/code}}
160 +
161 +
162 +== __**Zertifikat für Rev-Proxy erstellen und prüfen**__ ==
163 +
164 +Damit die Verbindung gesichert werden kann, wird ein Let's Encrypt Zertifikat benötigt. Dieses können Sie nach folgender Anleitung erstellen:
165 +
166 +====== __acmetool__ ======
167 +
168 +Wechseln Sie in den puppeteer Container:
169 +
170 +{{code language="bash"}}
171 +root@ldhost:~ # lxc-ssh -n puppeteer
172 +{{/code}}
173 +
174 +Fordern Sie das Zertifikat mit folgendem Befehl an (Ersetzen Sie "SCHULKUERZEL" mit dem jeweiligen Shortname):
175 +
176 +{{code language="bash"}}
177 +root@puppeteer:~ # acmetool want kopano.SCHULKUERZEL.logoip.de
178 +{{/code}}
179 +
180 +====== __acme.sh__ ======
181 +
182 +Wechseln Sie in den puppeteer Container:
183 +
184 +{{code language="bash"}}
185 +root@ldhost:~ # lxc-ssh -n puppeteer
186 +{{/code}}
187 +
188 +
189 +Wechseln Sie im puppeteer Container in die Umgebung für das Verwalten der Zertifikate:
190 +
191 +{{code language="bash"}}
192 +root@puppeteer:~ # sle
193 +{{/code}}
194 +
195 +
196 +Beantragen Sie ein neues Zertifikat mit folgendem Befehl (Ersetzen Sie "SCHULKUERZEL" mit dem jeweiligen Shortname):
197 +
198 +{{code language="bash"}}
199 +le-acme@puppeteer:~ $ issue kopano.SCHULKUERZEL.logoip.de
200 +{{/code}}
201 +
202 +
203 +Um das verteilen der Zertifikate zu beschleunigen können Sie ggf. einen prun im puppeteer und rev-proxy Container durchführen:
204 +
205 +{{code language="bash"}}
206 +root@puppeteer:~ # prun
207 +root@rev-proxy:~ # prun
208 +{{/code}}
209 +
210 +
211 +== (% style="color:#000000" %)**__LDAP Attribute__**(%%) ==
212 +
112 112  (% style="color:#000000" %)Standardmäßig werden folgende Attribute an die externe LDAP Schnittstelle weitergegeben:
113 113  
114 114  {{code language="bash"}}
... ... @@ -146,7 +146,7 @@
146 146  {{/code}}
147 147  
148 148  
149 -(% style="color:#000000" %)Die angepassten Änderungen können nun logosrv in der slapd.puppet.conf angeschaut werden:
250 +(% style="color:#000000" %)Die angepassten ACL-Änderungen können zur Kontrolle im logosrv in der Konfigurationsdatei slapd.puppet.conf angeschaut werden:
150 150  
151 151  {{code language="bash"}}
152 152  root@logosrv:~ # cat /etc/ldap/slapd.puppet.conf