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

Von Version 20.5
bearbeitet von Jens Gruber
am 2022/04/28 14:56
Änderungskommentar: Es gibt keinen Kommentar für diese Version
Auf Version 33.1
bearbeitet von Jonas Mayer
am 2022/05/02 18:41
Änderungskommentar: Es gibt keinen Kommentar für diese Version

Zusammenfassung

Details

Seiteneigenschaften
Titel
... ... @@ -1,1 +1,1 @@
1 -LDAP Admin-Benutzer und ReadOnly-Benutzer
1 +Geändert: LDAP Admin-Benutzer und ReadOnly-Benutzer
Dokument-Autor
... ... @@ -1,1 +1,1 @@
1 -XWiki.JensGruber@sbede
1 +XWiki.jonasmayer@sbede
Inhalt
... ... @@ -1,8 +1,8 @@
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 -[[image:Grafik für LDAp.png||height="331" width="622"]]
5 +(% style="color:#000000" %)[[image:Grafik für LDAp.png||height="331" width="622"]]
6 6  
7 7  === ===
8 8  
... ... @@ -11,9 +11,9 @@
11 11  
12 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.
14 +(% 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.
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 abgeraten!__**
16 +(% 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!__**
17 17  
18 18  
19 19  ==== (% style="color:#000000" %)__Benutzername & Kennwort__(%%) ====
... ... @@ -20,9 +20,9 @@
20 20  
21 21  ====== ======
22 22  
23 -====== __Benutzername__ ======
23 +====== (% style="color:#000000" %)__Benutzername__(%%) ======
24 24  
25 -(% style="color:#000000" %)Der Benutzername mit den jeweiligen Attributen:
25 +(% style="color:#000000" %)Der Benutzername des LDAP Admins lautet:
26 26  
27 27  {{code language="bash"}}
28 28  cn=ldap-admin
... ... @@ -30,16 +30,22 @@
30 30  
31 31  ====== ======
32 32  
33 -====== __Attribute des Benutzernamens__ ======
33 +====== (% style="color:#000000" %)__Attribute des Benutzernamens__(%%) ======
34 34  
35 -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.
35 +(% 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 -[[image:1651127320035-296.png]]
37 +(% style="color:#000000" %)[[image:1651243652049-471.png]]
38 38  
39 -====== ======
40 40  
41 -====== __Kennwort__ ======
40 +(% style="color:#000000" %)In diesem Beispiel ergibt sich der vollständige Benutzername (sogenannter //Distinguished Name// des Benutzerkontos) durch Anfügen der BaseDN:
42 42  
42 +{{code language="bash"}}
43 +cn=ldap-admin,dc=schule,dc=local
44 +{{/code}}
45 +
46 +
47 +====== (% style="color:#000000" %)__Kennwort__(%%) ======
48 +
43 43  (% style="color:#000000" %)Das Kennwort ist im logosrv unter folgendem Pfad einsehbar:
44 44  
45 45  {{code language="bash"}}
... ... @@ -46,7 +46,7 @@
46 46  root@logosrv:~ # cat /etc/ldap.secret
47 47  {{/code}}
48 48  
49 -Optional kann man das Passwort auch mit folgendem Befehl unter dem Punkt "Credentials" einsehen:
55 +(% 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:
50 50  
51 51  {{code language="bash"}}
52 52  root@logosrv:~ # ldconf -o
... ... @@ -60,13 +60,13 @@
60 60  
61 61  (% style="color:#000000" %)Der LDAP-ReadOnly Benutzer ist für die Verwendung von externen Diensten/Anbindungen gedacht.
62 62  
63 -(% style="color:#000000" %)Mögliche Nutzungsmöglichkeiten wären unteranderem die Nutzung und Einbindung  von einem extern gehosteten moodle, WebUntis oder einer Nextcloud.
69 +(% 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.
64 64  
65 65  
66 66  ==== (% style="color:#000000" %)__Benutzername & Passwort:__(%%) ====
67 67  
68 68  
69 -====== __Benutzername__ ======
75 +====== (% style="color:#000000" %)__Benutzername__(%%) ======
70 70  
71 71  (% style="color:#000000" %)Relevant für den Zugriff von Außen wäre folgender Benutzername:
72 72  
... ... @@ -74,17 +74,24 @@
74 74  cn=ldap-ro
75 75  {{/code}}
76 76  
77 -====== (% id="cke_bm_979S" style="display:none" %)__ __(%%) ======
83 +====== (% id="cke_bm_979S" style="color:#000000; display:none" %)__ __(%%) ======
78 78  
79 -====== __Attribute des Benutzernamens__ ======
85 +====== (% style="color:#000000" %)__Attribute des Benutzernamens__(%%) ======
80 80  
81 -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.
87 +(% 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.
82 82  
83 -[[image:1651127322559-640.png]]
89 +(% style="color:#000000" %)[[image:1651243652049-471.png]]
84 84  
85 85  
86 -====== __Kennwort__ ======
92 +(% 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//):
87 87  
94 +{{code language="bash"}}
95 +cn=ldap-ro,ou=services,dc=schule,dc=local
96 +{{/code}}
97 +
98 +
99 +====== (% style="color:#000000" %)__Kennwort__(%%) ======
100 +
88 88  (% style="color:#000000" %)Das Kennwort ist im logosrv unter folgendem Pfad einsehbar:
89 89  
90 90  {{code language="bash"}}
... ... @@ -92,12 +92,55 @@
92 92  {{/code}}
93 93  
94 94  
108 +(% 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 stets per SSL-Transportverschlüsselung versendet werden.
109 +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.
95 95  
96 -=== **__LDAP Attribute__** ===
97 97  
112 +**... [REV-PROXY LDAPS-Freischaltung mit Let's Encrypt einfügen]...**
98 98  
99 -(% style="color:#000000" %)Standardmäßig werden folgende Attribute an den
100 100  
115 +=== (% style="color:#000000" %)**__LDAP Attribute__**(%%) ===
116 +
117 +
118 +(% style="color:#000000" %)Standardmäßig werden folgende Attribute an die externe LDAP Schnittstelle weitergegeben:
119 +
101 101  {{code language="bash"}}
102 102  entry, cn, displayName, gidnumber, givenName, mail, member, memberOf, memberUid, o, objectClass, ou, sn, title, uid, uidnumber, uniqueMember, ldObjectType, ldRole
103 103  {{/code}}
123 +
124 +
125 +(% style="color:#000000" %)Sollen zusätzliche Attribute an die externe Schnittstelle weitergegeben werden, so müssen Sie diese in folgender Datei im Puppeteer Container wie folgt abändern/erstellen:
126 +
127 +{{code language="bash"}}
128 +root@puppeteer:~ # vim /etc/logodidact/hiera/custom.d/ldhost.yaml
129 +
130 +#Ist die Datei nicht vorhanden bitte wie folgt anpassen (Im Beispiel werden die Attribute ldBirthday & ldGender hinzugefügt):
131 +
132 +---
133 +ld_legacy::ldap::ldap_ro_atts:
134 + - ldBirtday
135 + - ldGender
136 +{{/code}}
137 +
138 +
139 +(% style="color:#000000" %)Danach müssen Sie die Änderungen ins Git übernehmen:
140 +
141 +{{code language="bash"}}
142 +root@puppeteer:~ # cd /etc/logodidact/
143 +root@puppeteer:/etc/logodidact # git add .
144 +root@puppeteer:/etc/logodidact # git coomit -am "LDAP Attribute in der ldhost.yaml hinzugefügt"
145 +{{/code}}
146 +
147 +
148 +(% style="color:#000000" %)Um den Prozess zu beschleunigen bietet sich ein prun im ldhost an. Damit werden die Änderungen sofort an den logosrv weitergeleitet:
149 +
150 +{{code language="bash"}}
151 +root@ldhost:~ # prun
152 +{{/code}}
153 +
154 +
155 +(% style="color:#000000" %)Die angepassten ACL-Änderungen können zur Kontrolle im logosrv in der Konfigurationsdatei slapd.puppet.conf angeschaut werden:
156 +
157 +{{code language="bash"}}
158 +root@logosrv:~ # cat /etc/ldap/slapd.puppet.conf
159 +{{/code}}
1651243652049-471.png
Author
... ... @@ -1,0 +1,1 @@
1 +XWiki.JensGruber@sbede
Größe
... ... @@ -1,0 +1,1 @@
1 +16.3 KB
Inhalt