====== IDP als Saml-Proxy zum Entra-ID ======
{{ :de:shibidp:config-advanced:idp-azure2.png?800 |}}
====== Vorwort ======
Die Idee ist es den IDP nicht gegen eine lokale DB zu authentifizieren, sondern die Authentifizierungsanfrage über den IDP-SAML-Proxy gegen das Entra-ID. Dies hat für die, die auch MS365-Dienste benutzen, gewisse Vorteile.
- Nach dem Authentifizierungsprozess hat der Benutzer eine gültige Shibboleth-Session gegen den IDP und eine gültige OAuth2-Session gegen das Entra-ID.
- Man benötigt zur Implementierung einer MFA-Umgebung jetzt nur noch die Token-Konfiguration im Azure. Man spart sich also den PrivacyIdea-Server plus eine zweimalige Einrichtung der Token.
- Die Attribute die dem SP übergeben werden, können sowohl aus der lokalen DB (LDAP) bezogen werden, als auch aus dem Entra-ID.
===== Wie muss ich mir das vorstellen? =====
Der Benutzer möchte sich an einem Webdienst anmelden, wird zum IDP weitergeleitet. Nun kommt statt der Usernamen und Passwortabfrage der Windows-Anmeldedialog. Dort meldet man sich an, der IDP erhält dem Ouath2-CLAIM vom Entra-ID, es werden im User-Consent die Attribute wieder angezeigt die im Filter freigeben sind. Die Auswahl wird bestätigt und fertig.
===== Voraussetzung =====
An den MS365 Diensten meldet man sich mit seiner E-Mail-Adresse an, aus diesem Grunde ist es wichtig, für die Abfrage an die LDAP-DB die E-Mail zur verwenden, um dann für alles Weitere (persitente-ID Generieung, usw.) die UID zu verwenden.
Die Konfiguration wurde unter
* Debian11, Tomcat9, Shib 4.1.3 konvertiert von 3.x
* Debian12, Tomcat10, Shib 5.0 neuinstall
getestet.
Weiter bildet die Basis zur Umkonfiguration ein funktionierendes System.
===== Konfiguration =====
==== Umkonfiguration Anmeldekennung ====
Im ersten Schritt sollte die Anmeldung so konfiguriert werden, dass die Benutzer sich mit der E-mail aus dem LDAP anmelden können. Dabei muss sichergestellt werden, dass zur ID (persistenten, subject) Generierung weiterhin das korrekte Attribut verwendet wird (bei uns die UID).
conf/ldap.properties
#idp.authn.LDAP.userFilter = (uid={user})
idp.authn.LDAP.userFilter = (mail={user})
#idp.attribute.resolver.LDAP.searchFilter = (uid=$resolutionContext.principal)
idp.attribute.resolver.LDAP.searchFilter = (mail=$resolutionContext.principal)
conf/attribute-resolver.conf
In der conf/saml-nameid.properties muss dann der Wert gesetzt sein:
idp.persistentId.sourceAttribute = uid
Jetzt den Tomcat neustarten und Anmeldung probieren, im zweiten Schritt prüfen, ob die in der DB gespeicherten persistenten IDs korrekt zum SP geliefert werden.
==== Konfiguration Azure ====
=== Eine Enterprise-Applikation erstellen ===
Enterpriese applications | All Applications -> New Application -> Create your own application -> Namen eingeben und den Punkt "Integrate any other application you don't find in the gallery (Non-gallery)” -> Create
=== SAML konfigurieren: ===
In der Konfiguration der neuen Applikation auf Overview -> “2. Setup Single sign on” -> SAML
* Dann unter Entity-ID: https://DNS-DES-IDPS/idp/shibboleth
* und unter Reply-Url: https://DNS-DES-IDPS/idp/profile/Authn/SAML2/POST/SSO
eintragen:
=== Benutzer konfigurieren: ===
Unter “Users and Groups” einen ersten Benutzer hinzufügen.
=== Zertifikat und Tenant-ID ===
Unter Single-Sign-On -> mittig bei “SAML Certificates” die “Federation Metadata XML” herunterladen. Die Konfiguration auf dem Azure ist damit abgeschlossen.
==== IDP ====
=== Metadaten ===
Aus dem Zertifikat und der Tenant-ID und der {{ :de:shibidp:config-advanced:azure_metadata_template.xml |Vorlage}} muss nun eine gültige Metadaten-Datei gebaut werden. Diese dient dann als Vertrauensstellung zwischen dem IDP und dem Entra-ID.
Die Metadaten aus dem Azure habe ich nicht ans Laufen bekommen. Aus diesem Grunde muss manuell eine Metadatei erstellt werden.
Hierzu steht ein {{ :de:shibidp:config-advanced:azure_metadata_template.xml |Template}} bereit, in dieses Template muss das Zertifikat und die Tenant-ID aus den “Federation Metadata XML” eingefügt werden.
Die Metadaten aus dem Azure erst mal formatieren, unter Linux über xmllint.
xmllint idp01-test.xml --format > idp01-test-format.xml
Nun das Template öffnen und dort die Tenant-ID und das Zertifikat mit dem Daten aus der gerade formatierten Datei ersetzen.
Das Zertifikat muss zwischen die “ ” die "Tenant-ID" entsprechnd ersetzen.
Die Metadaten-Datein dann unter metadata/azure.xml abspeichern und unter conf/metadata-providers.xml entsprechend laden:
Nun sollte der IDP neugestartet werden, zeigt das Log keine Fehler, so war dies vermutlich erfolgreich. Ggf. das Log unter conf/logback.xml erweitern und das Logging auf “DEBUG” stellen.
=== SAML-Auth konfigurieren ===
Die Konfiguration einiger Attribute ist aus der Datei “conf/authn/saml-authn-config.xml” in die Datei “conf/authn/authn.properties” gewandert.
Wir edititieren die Datei “conf/authn/authn.properties”:
Den Wert im Attribut von: idp.authn.flows = Password
In: idp.authn.flows = SAML
ändern. Dann weiter unten in der Kategorie SAML: (TENANT-ID nicht vergessen zu ändern)
idp.authn.SAML.nonBrowserSupported = false
idp.authn.SAML.proxyEntityID = https://sts.windows.net/TENANT-ID/
idp.authn.SAML.supportedPrincipals = \
saml2/urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport, \
saml2/urn:oasis:names:tc:SAML:2.0:ac:classes:Password, \
saml1/urn:oasis:names:tc:SAML:1.0:am:password
Nun einmal den Tomcat neustarten und es sollte der Azure-Anmeldedialog kommen.
=== c14n Flow ===
Wir editieren die Datei conf/c14n/subject-c14n.properties”
idp.c14n.attribute.attributeSourceIds = azureName
# Allows direct use of attributes via SAML proxy authn, bypasses resolver
idp.c14n.attribute.resolveFromSubject = true
idp.c14n.attribute.resolutionCondition = shibboleth.Conditions.FALSE
Conf/c14/subject-c14.xml
Folgende Zeile einkommentieren:
In der v5 scheint das Subject zur ID Bestimmung anders zu funktionieren.
**Nur für v4.1.x und früher, v5 braucht diese Einstellungen NICHT**
nano conf/attribute-resolver.xml
nano conf/c14n/attribute-sourced-subject-c14n-config.xml
canonicalNameToUseForJoin
canonicalNameToUseForJoin
**ENDE Konfig v4.x -->**
=== Daten ===
Im ersten Schritt die Attribute des Azure definieren, dazu wird unter conf/attributes eine neue Datei angelegt: {{ :de:shibidp:config-advanced:azureclaims.xml |azureClaims.xml}}
Dann müssen die Werte geladen werden, dazu einen neuen definieren:
Conf/attributes/default-attributes.xml
Einen neuen Connector im attribute-resolver.xml definieren.
Dann im attribute-filter.xml die Werte für die interne Verarbeitung freigeben. ACHTUNG, die TENANT-ID wieder ersetzen!
**Achtung V4.1.x und früher**
Die “Conf/attributes/default-attributes.xml” wurde bei meiner Konfiguration nicht geladen. Um dies nachzuholen, muss der folgende Eintrag gesetzt werden:
**Es wird nur der AzureClaims.xml geladen damit, sollten die Attribute noch im Resolver definiert sein, nichts kaputt geht.**
Nano “conf/services.xml”
%{idp.home}/conf/attributes/azureClaims.xml
**ENDE Konfig v4.x --->**
Nun noch die Attribute zum SP freigeben, Beispiel:
nano conf/attribute-filter.xml
Nun den Tomcat neustarten und es sollte die Anmeldung gelingen und die Daten an den SP übergeben werden. ENDE :)