Azure AD Application Proxy
Mittlerweile nennt Microsoft den Dienst "Microsoft Entra private network connector"
Jede Firma hat irgendwelche Webseiten oder Webservices, die sicher veröffentlicht werden müssen. Anstatt sich selbst im Reverse Proxy, öffentliche IP-Adresse, Zertifikat, MultiFaktor-Auth und DoS-Attacken zu kümmern, kann diese Funktion auch Azure übernehmen. Der Azure AD Application Proxy ist vermutlich bei den Administratoren die am wenigsten bekannte Möglichkeit. Es ist Zeit das zu ändern. Denn auch wenn Microsoft die Zusammenhänge und selbst die Konfiguration selbst sehr ausführlich dokumentiert hat, sind Kunden immer wieder überrascht, wenn ich ihnen diese Funktion von Azure vorstelle.
Funktionsweise
Ehe ich die technischen Schritte erläutere, möchte ich eine Lanze für den Azure AD Application Proxy brechen, denn damit können speziell mittlere und kleine Firmen selbst lokal bereit gestellte Webseiten einfach und vor allem Sicher im Internet und für Partner veröffentlichen. Das gilt nicht nur für neue Dienste sondern quasi für jeden Webservice, der auch heute schon On-Premises betrieben wird. Ob ein Service im Internet diesen Dienst nutzt, können Sie entweder direkt an der Adresse oder einem CNAME erkennen. Microsoft nutzt die Domain "msappproxy.net" für die Veröffentlichung und wenn Sie einen eigenen Namen nutzen, dann reicht ein CNAME auf diese Adresse. Also muss ich mal schnell die Funktion erklären. Der Service bietet nämlich durchaus etwas mehr als nur ein HTTP-Reverse Proxy, wie es auch heute schon jede bessere Firewall kann.
Die Komponenten sind schnell aufgeführt:
- Der Webservice ...
... steht wie bisher im internen LAN und ist aus dem Internet nicht erreichbar. Er sollte natürlich dennoch per HTTPS erreichbar sein aber das Zertifikat kann notfalls auch "Self Signed" sein. Besser ist natürlich ein richtiges Zertifikat, denn auch interne Clients sprechen vielleicht den Services von intern direkt an. - On-Premises Connector
Auf einem Server im LAN wird der Azure AD Proxy Connector installiert. Dieser Windows Dienst baut dann von intern eine ausgehende Verbindung zu Azure auf und wartet auf Anfragen durch Azure, die er dann intern an die verschiedenen Webserver weiterreichen kann. Die eigene Firewall muss also weder Reverse-Proxy spielen noch benötigen Sie öffentliche IP-Adressen oder Zertifikate. - Azure AD App Proxy
Dies ist eigentlich "nur" eine Konfiguration in Azure AD, mit der sie einen Service im Internet freigeben und über den bereits installierten Connector zu einem internen Server verbinden. Der AzureAD App Proxy ist der Schlüssel, denn hier können Sie nicht einfach nur die Zugriffe durchreichen, sondern auch eine Authentifizierung gegen ihre eigenes AzureAD oder sogar gegen alle Azure AD Tenants durchführen lassen. Sie können auch die Benutzer und Gruppen schon hier beschränken, die den Dienst überhaupt nutzen dürfen und über Conditional Access noch weitere Kriterien umsetzen. - Der Client
Der Nutzer des veröffentlichten WebService kann ein Browser im Internet aber auch im Intranet sein. Es kann ein anonymer Client oder ein Firmen-System sein. Letztlich bestimmen Sie ja auf dem AzureAD App Proxy, ob die Anfrage durchkommt - DNS-CNAME
Sie können den Service natürlich unter "<servicename>.msappproxy.net" ansprechen. Schöner ist aber natürlich ein "sprechender Name" aus ihrer Domain. Das ist auch einfach möglich, indem Sie in ihrer DNS-Zone einen CNAME auf den von Microsoft vergebenen Namen einrichten.
Es klingt so einfach und es ist eigentlich auch so einfach.
- Using Azure AD Application Proxy to
publish On-Premises apps for remote users
https://docs.microsoft.com/de-de/azure/active-directory/manage-apps/what-is-application-proxy
Vorteile
Einen Teil der Vorteile habe ich schon aufgezählt aber ich möchte Sie hier noch einmal als Liste zusammenfassen.
- Eine ausgehende und keine eingehende Verbindung
Sie benötigen keine eingehende HTTPS-Veröffentlichung in ihrer Firewall auf einen internen Webserver. Der Connector intern macht eine ausgehende Verbindung auf. Allerdings kann das auch bedeuten, dass eine Fachabteilung mit einer eigenen Azure-Subscription über den Weg interne Dienste ohne Wissen der Firewall veröffentlicht. - Keine Public-IP
Dies ist besonders interessant, wenn Sie nur wenig oder keine freie öffentliche IP-Adresse mehr haben oder ihre IP-Adresse sich doch immer mal wieder verändert. Es macht eine Verfügbarkeit aber auch einfacher, wenn sie einen Backup-Leitung eines anderen Providers haben und kein Provider-Independend Subnetz mit BGP veröffentlichen. - Kein öffentliches Zertifikat
Die Client Verbindung kann bei Nutzung des *.msappproxy.net-Namens ohne kostenpflichtiges Zertifikat auskommen. Auch er interne Server muss kein öffentliches Zertifikat nutzen. - PreAuth, Conditional Access, MFA
Sie können auch "Passthough" auswählen aber die Vorqualifizierung der Nutzer ist ein großer Schutz gegen Angriffe auf Konten, da Azure diese Anmeldungen schon abwehren kann - DDoS-Schutz
Da ihr eigener Webserver immer hinter den Azure-Diensten verborgen ist, haben Sie einen sehr guten DoS-Schutz gleich mit eingebaut. - Login Tracking
Wenn der Azure AD App Proxy die Anmeldungen vorab prüft, dann protokolliert Azure auch diese Vorgänge wie jede andere Anmeldung an einem Office 365 oder Azure Dienst. Das kann für Compliance-Anforderungen und Analysen bei Missbrauch sehr wichtig werden - Guest Access
Die Pre-Authentifizierung ist nicht auf ihren eigenen Tenant beschränkt. Sie können auch die Anwender anderer Tenants über den Azure AD App Proxy legitimieren - OAUTH
Wenn sich ein Anwender nun schon am AzureAD Ap Proxy authentifiziert hat, dann möchte man vielleicht eine zweite Anmeldung am eigentlichen Backend vermeiden. Das ist über OAUTH-Tokens möglich. Der Azure AD App Proxy "kennt" ja nun den Benutzer und ihre Backend App ist ebenfalls in Azure AD bekannt. Dann können Sie dem Anwender auch ein passendes Token übermitteln, welches er an den Backend-Service weiterreicht. Ihre BackendApp muss also einfach nur diese Bearer-Tokens decodieren und dem Aussteller vertrauen. Immer mehr Applikationen unterstützen diese Anmeldung.
Das alles gibt es natürlich nicht "kostenfrei".
Kosten
Über die Lizenzseite von Microsoft können Sie direkt sehen, welche Lizenz sie für den Einsatz des Azure AD App Proxy benötigen
Quelle:
https://azure.microsoft.com/en-us/pricing/details/active-directory/
Allerdings spreche ich bei jedem Kunden aktiv das Thema "Azure AD P1" an, da ohne diese Funktion auch kein "Conditional Access" nutzbar ist und damit jeder Anwender mit gültigem Benutzernamen und Kennwort auf jedem Client der Welt mal eben Outlook und OneDrive installieren kann und damit Firmendaten per OST-Datei oder OneDrive-Replikation auf einem ungesicherten Endgerät landen könnten. Insofern sollte jeder Office 365 Kunde auch immer Azure AD P1 mit lizenzieren. Azure AD P1 ist übrigens auch in EMS E3 und Microsoft E3 mit enthalten. Irritieren ist dann aber wieder die Anzeige im Azure Portal
Auf der einen Seite wird von AAD Premium aber auch "Basic" gesprochen, was definitiv nicht stimmen kann. Als Trial angeboten bekomme ich aber Azure AD P2 oder EMS E5 (enthält AzureAD P2) aber nicht Azure AD P1. Hier sollten Sie also ganz genau prüfen, welche Lizenz Sie kaufen.
Freischaltung
Der Azure AD Proxy Connector muss natürlich eine ausgehende HTTPS-Verbindung zu Azure aufbauen können, um dort die anstehenden Anfragen abzuholen. Je nach ihrem Netzwerk bedeutet das zusätzliche Freischaltungen auf einem HTTP-ProxyServer, eine entsprechende Namensauflösung und Firewall-Regeln. Microsoft hat die entsprechenden Adressen und DNS-Namen veröffentlicht. Genauso wird beschrieben, wie bei der Verwendung eines Proxy-Servers dieser zu konfigurieren ist.
- Ausgehender Zugriff auf Azure
https://docs.microsoft.com/de-de/azure/active-directory/manage-apps/application-proxy-configure-connectors-with-proxy-servers
*.msappproxy.net *.servicebus.windows.net
Einrichtung Connector
Die Nutzung von Azure AD App Proxy beginnt mit der Installation des ersten Connectors auf einem Server in der Nähe ihres Dienstes.
Der Einsatz ist nicht auf lokale
On-Premises Installationen beschränkt. Sie können genauso
gut eine AzureVM mit einem WebServer über diese Funktion
veröffentlichen. Wichtig ist nur, dass die Weg möglichst
kurz sind. Der Zugriff aus dem Internet über einen
On-Premises Connector und dann über ein AzureVPN zu einer VM
in Azure ist vielleicht nicht optimal gelöst.
Über mehrere "Connector Groups" können wie später je
veröffentlichter Applikation bestimmen, welche Connectoren
genutzt werden.
Es gibt hier verschiedene Überlegungen zu beachten hinsichtlich Netzwerklatenz, Bandbreite, Verfügbarkeit etc. Microsoft hat dazu eine nette Anleitung veröffentlicht:
- Network topology considerations when
using Azure Active Directory Application
Proxy
https://docs.microsoft.com/de-de/azure/active-directory/manage-apps/application-proxy-network-topology
Sie starten einfach im Azure Portal unter "Active Directory" und dann "Application Proxy":
Den Download gibt es aber auch eigenständig:
Azure AD Application Proxy Connector Download
https://download.msappproxy.net/subscription/d3c8b69d-6bf7-42be-a529-3fe9c2e70c90/connector/download
- Azure AD Application Proxy: Version release history
https://docs.microsoft.com/en-us/azure/active-directory/app-proxy/application-proxy-release-version-history
Bei der Installation müssen Sie Tenant Admin sein, denn der Connector authentifiziert sich über ein Client Zertifikat am Azure AD App Proxy, welches alle 180 Tage automatisch erneuert wird. Bei der Installation kann das initiale Zertifikat nur als Tenant Admin erstellt werden. Der Connector holt sich dann aus Azure die Konfiguration, d.h. welche Dienste er bereitstellen soll.
Um Updates müssen Sie sich eigentlich nicht kümmern:
The Azure AD team regularly updates Application Proxy with new features and
functionality. Application Proxy connectors are updated automatically when a new
major version is released.
Quelle: Azure AD Application Proxy: Version release history
https://docs.microsoft.com/en-us/azure/active-directory/app-proxy/application-proxy-release-version-history
- Why is my connector still using an older
version and not auto-upgraded to latest
version?
https://docs.microsoft.com/en-us/azure/active-directory/app-proxy/application-proxy-faq#why-is-my-connector-still-using-an-older-version-and-not-auto-upgraded-to-latest-version-
Für eine bessere Verfügbarkeit können Sie mehrere Connectoren als "Gruppe" zusammenfassen. Dann ist es auch einfacher anstehende Updates mal schnell auszuführen. Es gibt auf dem Connector selbst als keine GUI o.ä.
Outbound Proxy
Zum Ende der Installation kommen ein Hinweis, wie ein ausgehender HTTP-Proxy einzurichten ist:
- "Learn More"
https://go.microsoft.com/fwlink/?linkid=869882,
https://docs.microsoft.com/en-us/azure/active-directory/manage-apps/application-proxy-configure-connectors-with-proxy-servers.
Achtung:
Das Skript "ConfigureOutBoundProxy.ps1" addiert nur den
Proxy in die application.config des Connectors und des
Update Service aber hat keinen Code um einmal gemachte
Eintragungen wird zu entfernen.
Sie können natürlich per Notepad die beiden
Dateien manuell konfigurieren
C:\Program Files\Microsoft AAD App Proxy
Connector\ApplicationProxyConnectorService.exe.config
C:\Program Files\Microsoft AAD App Proxy Connector
Updater\ApplicationProxyConnectorUpdaterService.exe.config
Aber es gibt natürlich eine PowerShell, Eventlogs und Performance Counter:
- Under the hood
https://docs.microsoft.com/de-de/azure/active-directory/manage-apps/application-proxy-connectors#under-the-hood - Troubleshoot Application Proxy problems
and error messages
https://docs.microsoft.com/de-de/azure/active-directory/manage-apps/application-proxy-troubleshoot - Work with existing On-Premises proxy
servers
https://docs.microsoft.com/en-us/azure/active-directory/manage-apps/application-proxy-configure-connectors-with-proxy-servers - Microsoft Entra Private Access hinter
DATEVnet Proxy
https://jans.cloud/2024/08/microsoft-entra-private-access-hinter-datevnet-proxy/
AppProxy aktivieren
Es kann sein, dass die Funktion App Proxy noch deaktiviert ist. Dann ist es aber nur einen Mausklick entfernt
Ich denke, es ist einfach ein doppelter Schutz. Sie werden darauf hingewiesen, dass Sie immer noch die einzelnen Apps einrichten müssen.
An der gleichen Stelle können Sie den Service auch deaktivieren.
Einrichtung App Proxy
Nach dem Sie den Connector installiert haben, können Sie direkt auf dem Connector ein "Configure an App" starten:
Im dann folgenden Dialog stellen Sie die zumindest die "Internal URL" ein.
Standardmäßig ist eine "Pre Authentication" am Azure AD erforderlich. Die externe URL können Sie natürlich anpassen.
Translate URLs
Sie haben bei den Einstellungen sicher auch die beiden Schieber unter "Translate URLs in" für "Headers" und ApplicationBody" gesehen. Diese Einstellung muss erklärt werden, denn sie ist immer dann wichtig, wenn die Werte bei "Internal URL" und "External URL" sich unterscheiden:
Ich bin ein Fan der "Ein Service = Ein Name = Ein Port". Egal wo der Clients ist, muss er mit der URL immer den gleichen Service erreichen. Die Zwischenstationen können natürlich unterschiedlich sein.
Wenn die angesprochene URL identisch ist, gibt es keinen Bedarf etwas umzuschreiben. Ansonsten muss die Umschreibung dem Server dabei helfen, die richtigen Daten und URLs zu liefern. Nehmen wir an ich greife von Extern aus www.msxfaq.de zu und ein Reverse Proxy, eine Firewall, ein Loadbalancer oder eben der AzureAD Application Proxy muss den Request intern auf einen anderen Namen, z.B. server1.msxfaq.net umsetzen, dann müssen mehrere Dinge beachten.
- DNS und TLS
Der Request wird vom AzureAD App Proxy per HTTPS angenommen decodiert und liegt in Reinform vor. Damit der Request zum Backend-Server gesendet wird, muss der ProxyAgent nicht nur den Namen auslösen und eine IP-Verbindung aufbauen sondern auch das Zertifikat prüfen. Wenn der interne Server nur ein Zertifikat für den internen Namen hat, muss der AppProxy dies verstehen. Hier könnte auch der Subject Name Indication (SNI) mitspielen. - HostHeader
Wenn er dann den Request an den veröffentlichten Webserver sendet, muss er eventuell den HostHeader im HTTP-Request umschreiben. Der interne Server "reagiert" vielleicht gar nicht auf den externen Namen. HostHeader-Checks sind üblich. Darauf bezieht sich das "Rewrite auf den Header". Überall, wo die externe URL enthalten ist, kann die interne URL eingesetzt werden. Das ist nicht trivial, weil Servernamen z.B. auch in einem Authentication-Cookie codiert enthalten sein können und damit ein einfaches Rewriting nicht möglich ist. - Serverantwort
Der Webserver bearbeitet die Anfrage und generiert die Rückantwort. Es ist natürlich höflich mit relativen URLs zu arbeiten, in denen kein Hostname vorkommt. Aber wenn Sie auch die Pfade in den externen URL umschreiben, dann muss im Body auch diese Änderung angewendet werden. Wenn der Server aber weiss, wie er "extern" heißt, dann kann er das schon selbst.
Heute liefern Webserver aber nicht nur HTML,CSS und Bilder sondern viele moderne Apps nutzen JSON/REST/WebSockts und da wird es schwer für einen AppProxy die relevanten Strings zu erkennen und umzuschreiben. - Pfade
Wenn sie nicht den ganzen Server sondern nur einen Teilpfad veröffentlichen, dann müssen Sie sicher sei, dass wirklich alle Inhalte auch unter diesem Pfad sind. Sehr oft erlebe ich aber, dass z.B. Style Sheets (CSS) oder JavaScript (js) aus allgemeinem Verzeichnissen nachgeladen werden. Hier müssen Sie dann die Anwendung ggfls. doch komplett veröffentlichen. Auch wenn das ein Risiko beinhaltet, dass andere URLs ebenfalls erreichbar werden - Port Umsetzung / SSL Offload
Sie können mit dem AzureAD AppProxy externe Anfragen nur auf Port 443 annehmen. Die interne URL kann aber natürlich auf einen abweichen Port gehen oder z.B. auch Verschlüsselung verzichten. Dann kommen Sie ohne Rewriting nicht aus, das der interne Webserver per HTTP oder auf einem anderen Port angesprochen wird und diese Vorkommen im Header oder Body ebenfalls umgeschrieben werden müssen.
Sie sehne, dass hier ganz schön viel schief gehen kann und nur weil ihre ersten Tests erfolgreich waren, ist das noch lange keine Stabilitätsgarantie. Daher wünsche ich ihnen, dass Sie am besten ganz ohne Rewriting auskommen und alle Server über die Standardport 80/443 und dem gleichen Namen aus dem internen LAN als auch aus dem Internet angesprochen werden können. Nebenbei hat der App Proxy damit auch weniger Arbeit und sie müssen Link in Mails, auf anderen Webseiten, in Favoriten und sonst wo nicht nach "Intern/Extern" unterscheiden. Mir ist natürlich bewusst, dass Sie sich dann auch über "SplitDNS" Gedanken machen müssen.
Custom Domains
Im DropDown-Feld können sie jede Domain nutzen, die sie in ihrem Tenant registriert haben. Das Portal weist sie dann schon darauf hin, dass Sie natürlich den entsprechenden DNS-CNAME noch eintragen müssen aber auch, dass Sie ggfls. noch ein Zertifikat bereitstellen müssen.
Für die "Pre Authentication" muss der App Proxy ja den SSL-Tunnel aufbrechen.
- Configure custom domains with Azure AD
Application Proxy
https://docs.microsoft.com/en-us/azure/active-directory/manage-apps/application-proxy-configure-custom-domain
Authentifizierung anpassen
Sie haben zwar nun den Connector und die App eingerichtet, aber bezüglich der Authentifizierung gibt es noch etwas zu tun, da aktuell noch niemand diese App nutzen kann. Das Portal springt aber schon auf die passende Seite, auf der Sie nun auch die Benutzer oder Gruppen zulassen müssen.
Im gleichen Zug können Sie steuern, ob die App auf dem Portal der Anwender erscheint, welche "Conditional Access"-Policy angewendet wird und welche Berechtigungen die App bekommt. Hierüber steuern sie, welche Inhalte das OAUTH-Ticket bekommt, welches später an die Applikation weitergereicht werden kann. Unter "Activity" können Sie später nachvollziehen, welche Anwender die App genutzt haben.
- Tutorial: Add an On-Premises application
for remote access through Application Proxy
in Azure Active Directory
https://docs.microsoft.com/de-de/azure/active-directory/manage-apps/application-proxy-add-On-Premises-application#test-the-application
Single SignOn
Die Enterprise Application kann so konfiguriert werden, dass Sie von den Anwendern schon eine Authentifizierung erfordert. Das macht Sinn, um schon sehr früh zu filtern aber auf der anderen Seite möchte man dem Anwender natürlich eine "doppelte" Anmeldung ersparen. Also sollten dann die erhaltenen Anmeldedaten zum Backend Server weiter gereicht werden. Dazu gibt es gleich eine ganze Menge:
Wenn die Dienste heute schon die Authentifizierung per Kerberos nutzen, dann würde ich den Weg auch für den AzureAD Application Proxy nutzen. Die Menge an Optionen kann Sie natürlich erschlagen. Da ist es hilfreich zu wissen, welche Möglichkeit mit welchem Backend und Frontend harmoniert. Wenn z.B. ein Server "integrated" anbietet, was bei vielen Windows Services der Regelfall ist, dann können Sie "Kerberos Contraint Delegation" die AzureAD Authentifizierung einfach nutzen. Ich versuche mich mal an einer Tabelle, dann SSO möglich sein könnte. Nur wenn der Azure AD Proxy die Authentifizierung macht, können Sie über Conditional Access weitere Kriterien abprüfen.
Was kann das Backend | Azure AD Proxy Einstellung für SSO/Preauth | Client |
---|---|---|
Windows Auth/SPNEGO |
|
Kerberos - Constraint Delegation und Double Hop |
Header Based Authentication |
|
Ein Client könnte aber SSO über ein "JWT_Bearer Grant" ermöglichen |
OAUTH2 |
|
Ein Client könnte aber selbst mi einem OAUTH Token ein SSO ermöglichen |
SAML - WS/FED |
|
Bei der Einstellung "Disabled" könnte ein Client aber selbst ein Token per SSO liefern |
Basic/NTLM |
|
Der AzureAD App Proxy kann bei NTLM/Basic nicht unterstützen. Der Client könnte aber selbst direkt NTLM machen, wenn er denn dies kann. |
SOAP |
|
Eine Unterstützung durch den AzureAD Proxy aber Clients könnten direkte Tokens senden und damit SSO erlauben. |
Client Zertifikat |
|
Der gerade für Remote User gerne genutzte Ansatz mit Zertifikaten (Smartcard etc) wird vom AzureAD Proxy aktuell nicht unterstützt. |
Ich würde bei internen Diensten, die z.B. Kerberos unterstützen, über diesen Weg eine Authentifizierung am AzureAD Proxy anfordern, der dann als Benutzer an den Backend-Service geht. Damit die per Kerberos möglich ist, müssen Sie mehrere Dinge tun:
- IIS Authentication auf "Windows
Integrated"
Gerade mit Exchange Servern wird intern gerne eine Anmeldung per "Formular" angeboten. - Besorgen Sie sich den SPN des internen
Servers
Bei meinem Exchange Server ist das "HOST/ex01.msxfaq.de". Mit ADSIEDIT oder SETSPN können Sie für das Zielsystem diesen Eintrag schnell finden - Kerberos Delegation eintragen
Dann müssen Sie im Active Directory auf dem Computerkonto der AzureAD Connectoren diese Zielserver auf der Karteikarte "Delegation" addieren - SPN in AzureAD eintragen
Zuletzt tragen Sie den SPN auch noch in der Azure AD Enterprise Applikation ein
Anscheinend nutzt der Connector "genau" den angegebenen SPN. Wenn Sie hier "http/ex01.msxfaq.de" angeben, dann scheint er kein Fallback auf "host/ex01.msxfaq.de" zu machen.
Es kann einige Minuten dauern, bis all die Änderungen aktiv sind aber sollten Sie nach einer Anmeldung am Azure AD Application Proxy direkt zum Zielserver ohne weitere Anmeldung kommen.
- Kerberos Constrained Delegation for
single sign-on to your apps with Application
Proxy
https://docs.microsoft.com/en-us/azure/active-directory/manage-apps/application-proxy-configure-single-sign-on-with-kcd
Im Fehlerfall sehen Sie bei Kerberos dann folgende Seite:
Die Links führen direkt zu den Einstellungen im Azure Portal und folgenden Seiten in der Microsoft Dokumentation.
- Configure KCD for your single sign-on
Application Proxy Application
https://docs.microsoft.com/en-us/azure/active-directory/active-directory-application-proxy-sso-using-kcd#working-with-sso-when-On-Premises-and-cloud-identities-are-not-identical - Troubleshoot KCD Configurations for
Application Proxy
https://docs.microsoft.com/en-us/azure/active-directory/application-proxy-back-end-kerberos-constrained-delegation-how-to - Kerberos Constrained Delegation for
single sign-on to your apps with Application
Proxy
https://docs.microsoft.com/en-us/azure/active-directory/manage-apps/application-proxy-configure-single-sign-on-with-kcd - Azure AD Application Proxy – SSO and Authorization notes from the field
https://securecloud.blog/2020/01/07/azure-ad-application-proxy-sso-and-authorization-notes-from-the-field/ - Header-based authentication for single sign-on with Application Proxy and
PingAccess
https://docs.microsoft.com/en-us/azure/active-directory/manage-apps/application-proxy-configure-single-sign-on-with-ping-access
Manchmal ist die Seite aber auch "nichtssagend weil Sie innerhalb einer Webapplikation einen Fehler bekommen. Dann hilft zum einen Fiddler:
Aber auch die Debugging Tools des Browsers sind hier manchmal hilfreich:
Hier blockiert der Browser das Nachladen wohl anhand einer CORS-Richtlinie
- Cross-origin resource sharing
https://en.wikipedia.org/wiki/Cross-origin_resource_sharing
Auf die anderen Anmeldeverfahren gehe ich hier nicht weiter ein und verweise auf die Dokumentation von Microsoft.
Debugging in Azure
Auf der Fehlerseite bei Kerberos aber auch einen Link auf im Portal können Sie eine URL auslesen, mit der Sie einen "Debug-mode" aktivieren können.
Die URL ist einfach die Adresse der Application mit einem eigenen Parameter:
https://servicename.msxfaq.de/?appproxy=debug
Danach sehen Sie je nach Anwendungsfall oder Fehler ausführlichere Informationen, auf die ich aber nicht weiter hier eingehe.
Debugging auf dem Gateway
Interessanter ist aber die Möglichkeit, auf dem Gateway-System nach Fehlern zu suchen. Hier ist der Connector doch recht gesprächig und schreibt sowohl Eventlogs als auch Protokolldateien. Im Eventlog finde ich sowohl ein Log für den Dienst selbst als auch für den Updater:
Folgende Eventlogs des Connectors habe ich schon gesehen.
EventID | Description |
---|---|
13006 |
Connection to the backend server failed. Error: (0x80072efd). |
13022 |
Microsoft Entra private network connector cannot authenticate the user because the backend server responds to Kerberos authentication attempts with an HTTP 401 error. |
13007 |
The HTTP response from the backend server was not received within the expected interval. Expected interval: 85 seconds. |
12015 |
The Connector failed to establish connection with the service. If this error persists, please use the following link to verify that all necessary ports are open in your firewall: https://go.microsoft.com/fwlink/?linkid=843463. For more details, please see our troubleshooting page: http://go.microsoft.com/fwlink/?LinkID=512316&clcid=0x409. Request ID: '{6b633ae3-e37d-412a-9733-200d7eceda92}' |
12020 |
The Connector was unable to connect to the service due to networking issues. The Connector tried to access the following URL: 'https://<GUID>.bootstrap.msappproxy.net/', Request ID: '{8859cc41-05df-4b4a-9364-02f42a8df4bc}'. See Connector troubleshooting for more information: http://go.microsoft.com/fwlink/?LinkID=512316&clcid=0x409 |
Die meisten Events enthalten auch noch eine "Details"-Sektion.
Details: Transaction ID: {7899470d-c9d8-4f54-a52a-b2528b739437} Session ID: {7899470d-c9d8-4f54-a52a-b2528b739437} Published Application Name: Published Application ID: Published Application External URL: https://tsgw.msxfaq.de/ Published Backend URL: https://tsgwappproxy.msxfaq.de/ User: <Unknown> User-Agent: MSRPC Device ID: <Not Applicable> Token State: NotFound Cookie State: NotFound Client Request URL: https://tsgw.msxfaq.de/rpc/rpcproxy.dll?localhost:3388 Backend Request URL: https://tsgwappproxy.msxfaq.de/rpc/rpcproxy.dll?localhost:3388 Preauthentication Flow: PassThrough Backend Server Authentication Mode: PassThrough State Machine State: BEHeadersReading Response Code to Client: <Not Applicable> Response Message to Client: <Not Applicable> Client Certificate Issuer: <Not Found> Response Code from Backend: <Not Applicable> Frontend Response Location Header: <Not Applicable> Backend Response Location Header: <Not Applicable> Backend Request Http Verb: RPC_IN_DATA Client Request Http Verb: RPC_IN_DATA
Wenn Sie die Fehler per PowerShell auslesen wollen, dann geht das mit:
Get-EventLog application –source "Microsoft Entra private network connector" –EntryType "Error" –Newest 1
Zudem protokollieren beide Dienste ihre Aktivitäten in folgendem Verzeichnis:
C:\ProgramData\Microsoft\Microsoft Entra private network connector\Trace
In der Regel sind die Dateien leer (0 Bytes) aber ansonsten sehen Sie meist die Fehlermeldungen der fehlgeschlagenen HTTP-Requests.
- Troubleshoot problems installing the
private network connector
https://learn.microsoft.com/en-us/entra/global-secure-access/troubleshoot-connectors
Certificate Pinning
Ich habe meinen privaten PRTG-Server über einen AzureAppProxy veröffentlicht. Das funktioniert per Webbrowser sehr gut. Wenn ich aber die "mobile App" auf IOS nutze, dann bekomme ich bei jeder neuen Verbindung eine Warnung.
Das dürfte daran liegen, dass Microsoft auf ihrer Seite sicher viele eingehende Server bereitstellen, die aber nicht alle das gleiche Zertifikat nutzen. Aufgrund der Lastverteilung per DNS-RoundRobin oder Loadbalancer kann es also passieren, dass mein Client auf einem anderen Server landet. Der mobile PRTG-Client merkt sich allerdings das individuelle Zertifikat, was im Prinzip nicht schlecht ist. Nur mit dem AzureADProxy fällt dies bei der Nutzung der Microsoft-Adressen auf.
Enterprise Apps mit AppProxy finden
Leider gibt es keine einfache Möglichkeit (Stand Feb 2024), bei der Konfiguration des App Proxy zu erkennen, wie viele Dienste die Connector Group verwenden. Wenn Sie aber über die Enterprise Applications gehen, können Sie zumindest auf "Is App Proxy = true/false" filtern.
Leider gibt es weder eine Spalte noch einen Filter für eine einzelne "Connector Group". Wer also mehrere Connector Groups mit weiteren App Proxy Gateways konfiguriert hat, ist gut daran, eine Dokumentation zu führen oder im Namen des Services dies mit zu kodieren.
Reporting mit PowerShell
Ich nutze mittlerweile sehr umfangreich die AzureADProxy-Funktion. So kann ich selbst WebServer in meinem Intranet, also auch zuhause hinter einer dynamischen IP-Adresse, sehr einfach im Internet verfügbar machen und muss mich nicht mehr DynDNS und einer Portweiterleitung im DSL-Router herum schlagen.
Etwas unglücklich ist aber aus meiner Sicht die Verwaltung, da ich zwar über den Punkt "AzureAD Proxy" die Agenten finde aber nicht, welche Applikationen über diese Agenten bereitgestellt werden. Ein Blick in die Applikationen liefert aber alle Apps und lässt sich in der GUI (Stand Jun 2020) nicht filtern. Daher muss die PowerShell her. Leider muss man dazu aber mehrere Befehle kombinieren
Nachdem Sie eine Verbindung zur AzureAD Powershell aufgebaut haben, müssen Sie mit "Get-AzureADServicePrincipal" die Objekte suchen, die im Feld "Tags" den Wert "WindowsAzureActiveDirectoryOnPremApp" stehen haben. Die Liste enthält aber z.B.: noch keine Informationen über das Zertifikat. und dann mit deren ObjectIDs die Details holen.
Connect-AzureAD Write-Host "Hole Liste aller OnPremAzureADApps" $AzureADAppServList = Get-AzureADServicePrincipal -Filter "Tags eq 'WindowsAzureActiveDirectoryOnPremApp'" $list = foreach ($App in $AzureADAppServList) { Write-Host "Processing:$($app.displayname)" $application = Get-AzureADApplication -SearchString "$($app.Displayname)" $appProxy = Get-AzureADApplicationProxyApplication -ObjectId "$($application.objectid)" [pscustomobject][ordered]@{ AccountEnabled = $app.AccountEnabled DisplayName = $app.DisplayName ExternalAuthenticationType = $appproxy.ExternalAuthenticationType ExternalUrl = $appproxy.ExternalUrl InternalUrl = $appproxy.InternalUrl IsTranslateHostHeaderEnabled = $appproxy.IsTranslateHostHeaderEnabled IsOnPremPublishingEnabled = $appproxy.IsOnPremPublishingEnabled VerifiedCustomDomainCertificatesMetadata = $appproxy.VerifiedCustomDomainCertificatesMetadata } } $list | select Displayname,{$_.VerifiedCustomDomainCertificatesMetadata.ExpiryDate}
Eine andere Variante besteht im Abrufen mit Get-AzureADApplication, wobei hier als Parameter nur eine GUID aber kein Name möglich ist. Also muss ein Skript auch hier erst alle Einträge holen und dann filtern.
$AllApps = Get-AzureADApplication -All $True Foreach($App in $AllApps){ try { write-host ("Displayname:$($app.displayname)") -nonewline $AppDetails = Get-AzureADApplicationProxyApplication -ObjectId $App.ObjectId write-host (" - Found") $AppDetails } catch { write-host (" - NotAppProxy") } }
Die Abfrage jeder einzelnen Applikation per Suche mit "-SearchString" oder "-Filter" nach der GUID ist langsamer als die Liste komplett zu holen und danach zu filtern. Allerdings funktioniert dies hier auch in sehr großen Tenants mit sehr vielen Apps.
- Abrufen aller Anwendungen für den
Anwendungsproxy und Auflisten grundlegender
Informationen
https://docs.microsoft.com/de-de/azure/active-directory/manage-apps/scripts/powershell-get-all-app-proxy-apps-basic - Abrufen aller Anwendungsproxy-Apps und
Auflisten zusätzlicher Informationen
https://docs.microsoft.com/de-de/azure/active-directory/manage-apps/scripts/powershell-get-all-app-proxy-apps-extended - Get-AzureADServicePrincipal
https://docs.microsoft.com/en-us/powershell/module/azuread/get-azureadserviceprincipal?view=azureadps-2.0 -
Get-AzureADApplicationProxyApplicationConnectorGroup
https://docs.microsoft.com/en-us/powershell/module/azuread/get-azureadapplicationproxyapplicationconnectorgroup?view=azureadps-2.0 -
Get all Application Proxy apps published
with no certificate uploaded
https://docs.microsoft.com/en-us/azure/active-directory/manage-apps/scripts/powershell-get-all-custom-domain-no-cert
Zertifikat tauschen
Mittlerweile sind HTTPS-Zertifikate maximal ein Jahr gültig und leider liefert Microsoft selbst erst einmal keinen Support für Let's Encrypt. Sie müssen also schon selbst die Nutzung der Zertifikate überwachen und diese ggfls. tauschen. Bei der Überwachung gibt es zwei Optionen:
- Die PKI meldet sich, dass ein Zertifikat
ausläuft
Wenn Sie dann eine gute Buchführung haben, wo die Zertifikate genau eingesetzt werden dann können Sie rechtzeitig ein neues Zertifikat einspielen - Eigenüberwachung per TLS
Sie können mit ihrer Überwachungslösung (z.B. PRTG) oder PowerShell Test-CertificateStore oder TLS-Handshake die Gültigkeit auslesen
Ich habe leider noch nicht gesehen, das Azure von sich aus an die Manager oder Owner einer Application frühzeitig eine Warnung sendet.
Die neue PFX können Sie mit dem Kennwort dann einfach einspielen. Sie ersetzt das bestehende Zertifikat. Wichtig ist dabei, dass sie jeden Dient individuell aktualisieren müssen. Es gibt keinen zentralen "Zertifikatsspeicher", in dem man das alte Zertifikat einfach global ersetzt.
Anscheinend gibt es Probleme bei der Auswahl der PFX-Datei, wenn die Extension nicht klein geschrieben ist. Ein "Pfx"-Datei konnte ich nicht hochladen während "pfx" funktioniert hat.
- Automate AppProxy and Let's Encrypt using Azure DNS Zones
https://blog.yevrag35.com/2018/09/automate-appproxy-and-lets-encrypt.html - Automating MS AppProxy and Let'sEncrypt using Azure DNS Zones
https://www.reddit.com/r/PowerShell/comments/9dn2qh/automating_ms_appproxy_and_letsencrypt_using/ - Azure Application Proxy – Zertifikat
tauschen
https://powershell24.de/2019/03/05/azure-application-proxy-zertifikat-tauschen/ - Posh-ACME
https://GitHub.com/rmbolger/Posh-ACME
https://www.powershellgallery.com/packages/Posh-ACME/2.2.0/Content/Public%5CNew-PACertificate.ps1
Es gibt hier sogar ein Azure-DNS-Plug-in, um die erforderlichen DNS-Einträge dynamisch anzulegen
Keine On-Premises-Version
Leider gibt es die Funktion des AzureAD AppProxy nur als Plattform in der Cloud. Manchmal habe ich mich schon gefragt, wo es eine "On-Premises-Version gibt". Wenn ich interne Dienste über den AzureAD Application Proxy aus dem Internet mit Preauthentication etc. verfügbar mache dann könnte ich das intern ja genauso machen.
Heute greifen die internen Anwender direkt auf den Server zu undauthentifizieren sich per NTLM der Kerberos. ich könnte mir es schon interessant vorstellen, die internen Clients, denen ich auch nicht vertraue, ebenfalls auf eine solche Instanz zu leiten und alle Voraussetzungen (Conditional Access etc.) zu prüfen, ehe die Clients auf den Server weitergereicht werden.
Diese Funktion gibt es aber nicht und so muss jede Applikation selbst angepasst werden, damit Sie zur Authentifizierung das AzureAD nutzt. Exchange und Skype for Business können das übrigens schon:
Wann stellen Sie ihre On-Premises-Webanwendungen auf AzureAD um?
AppProxy und Exchange
Natürlich können Sie auch Outlook Web App eines On-Premises Exchange Server per Azure Application Proxy veröffentlichen. Es ist erst einmal "nur" eine Webseite. Allerdings eine eher anspruchsvolle Seite, die auch verschiedene URLs einbindet. Eine einfache Veröffentlichung ohne Seamless Single SignOn erscheint möglich. Allerdings können nicht alle Dienste damit umgehen, dass eine doppelte Authentifizierung erforderlich ist. Wenn Sie nun aber Exchange On-Premises z.B. auf "Hybrid Modern Authentication (HMA)" umstellen um dann mit einem SAML-Token des Azure App Proxy eine Anmeldung zu versuchen, dann gelingt das aber ist nicht stabil. Diese Funktion wurde wohl von Microsoft getestet und als nicht zuverlässig eingestuft. Diese Konfiguration wird daher nicht unterstützt.
Outlook Web App and Exchange Control
Panel do not work with hybrid Modern Authentication. In
addition, publishing Outlook Web App and Exchange Control
Panel through Azure AD Application Proxy is unsupported.
Quelle:
https://learn.microsoft.com/en-us/microsoft-365/enterprise/configure-exchange-server-for-hybrid-modern-authentication?view=o365-worldwide#make-sure-you-meet-all-the-prerequisites
- Hybrid Modern Authentication (HMA)
- How to configure Exchange Server On-Premises
to use Hybrid Modern Authentication
https://learn.microsoft.com/en-us/microsoft-365/enterprise/configure-exchange-server-for-hybrid-modern-authentication
Updates des Agenten
Die Funktion des AzureAD App Proxy besteht aus dem Teil in der Cloud und einem lokalen Agenten. Die Cloud-Komponente wird von Microsoft verwaltet und aktualisiert. Über den lokalen Teil hat Microsoft nur indirekt die Kontrolle. Mit der Installation des AzureAD App Proxy installiert Microsoft zwei Dienste. Ähnlich wie bei ADSync aber auch bei Google Chrome und anderen Produkten hat es sich wohl bewährt, wenn ein separater Update-Dienst für die Aktualisierungen sorgt.
Hier schon das Bild mit dem neuen Namen (Seit Sommer 024)
So ein Update Dienst wird wohl eher selten selbst aktualisiert und wenn er mehrere Jahre lang den aktiven Service aktuell halten und vielleicht ie ein oder anderen Telemetrie-Daten senden kann, dann ist dies für die Verfügbarkeit von Vorteil. Auf meinem Server ist sogar zu sehen, wann die Umbenennung erfolgte und dass die bisherigen Dienste noch Reste hinterlassen hatten
Die Verzeichnisse "Microsoft AAD App Proxy Connector" und "Microsoft AAD App Proxy Connector Update" enthielten aber nur noch Restdateien und konnten daher gefahrlos gelöscht werden. Die jeweils aktuelle Version finden Sie einfach in der Liste der Produkte:
Microsoft veröffentlicht auch die Versionen.
- Microsoft Entra private network
connector: version release history
https://learn.microsoft.com/en-us/entra/global-secure-access/reference-version-history
Fast alle Versionen haben den Status "This version is only available for install via the download page in the Microsoft Entra admin center.". Das bedeutet aber nur, dass Sie den Download nicht einfach so auf der Seite finden. Bei mir hat der lokale Update-Dienst sehr wohl die Updates alleine installiert. Wobei die "Namensänderung" vermutlich als "Major Release" durchgeht.
Only major versions are released for auto-upgrade. We recommend updating your
connector manually only if it's necessary
Quelle:
https://learn.microsoft.com/en-us/entra/global-secure-access/troubleshoot-connectors
Einschätzung
Das war nur ein kleiner Appetithappe, um ihnen eine weitere Funktion von Azure vorzustellen, welche alle Firmen mit Azure AD P1 oder P2-Lizenz einfach so nutzen können. Schon heute können Sie die meisten internen Webseiten, die nur nach erfolgter Authentifizierung erreicht werden dürfen, einfach über diesen Weg deutlich sicherer veröffentlichen.
Wenn der Anwender noch nicht im Browser angemeldet ist, dann wird er sich natürlich beim ersten Zugriff authentifizieren müssen. Aber alle weiteren Dienste über den Azure AD App Proxy erfordern keine weitere Authentifizierung an Azure und landen direkt auf der internen Seite. Dort wird allerdings erneut nach Anmeldedaten gefragt, da eine Anmeldung per Kerberos oder NTLM so nicht möglich ist. Sobald aber die Backend-Applikation mit OAUTH umgehen kann, ist keine weitere Anmeldung erforderlich.
Ich erwarte, dass mehr und mehr Firmen im Besitz einer Azure AD P1-Lizenz sind (durch Microsoft 365 E3, EMS E3 oder Einzelkauf) und damit diese elegante Funktion für die sichere Veröffentlichung von internen Webseiten nutzen können.
Weitere Links
- WAP - Web Application Proxy
- Exchange Webseite absichern
- Hybrid Modern Authentication (HMA)
- TMG 2010 und Exchange
- Apache als Reverse Proxy
- Squid, Apache und andere Proxy Server mit OWA
- OWA Absichern
- FTTH mit IPv6 (DG)
-
Azure MFA
On-Premises
So sichern sie lokale RDP-Gateways, VPN-Zugänge und andere Radius-Dienste mit MFA ab - Security considerations for accessing
apps remotely with Azure AD Application
Proxy
https://docs.microsoft.com/de-de/azure/active-directory/manage-apps/application-proxy-security - Network topology considerations when
using Azure Active Directory Application
Proxy
https://docs.microsoft.com/de-de/azure/active-directory/manage-apps/application-proxy-network-topology - Understand Azure AD Application Proxy connectors
https://docs.microsoft.com/de-de/azure/active-directory/manage-apps/application-proxy-connectors - Work with existing On-Premises proxy servers
https://docs.microsoft.com/en-us/azure/active-directory/app-proxy/application-proxy-configure-connectors-with-proxy-servers - Remote access to On-Premises
applications through Azure Active
Directory's Application Proxy
https://docs.microsoft.com/de-de/azure/active-directory/manage-apps/application-proxy - Application management with Azure Active
Directory
https://docs.microsoft.com/de-de/azure/active-directory/manage-apps/what-is-application-management - Enable SSO (Single Sign On) to
On-Premises Exchange OWA (Outlook Web
Access) via Azure AD Application Proxy
https://jackstromberg.com/2016/06/enable-sso-single-sign-on-to-On-Premises-exchange-owa-outlook-web-access-via-azure-ad-application-proxy/ - Enable remote access to SharePoint with
Azure Active Directory Application Proxy
https://docs.microsoft.com/en-us/azure/active-directory/app-proxy/application-proxy-integrate-with-sharepoint-server - Das versteckte Cloud Juwel: Azure AD Application Proxy
https://www.smartit.ch/blog/arzue-ad-application-proxy