Az - Automation Account
Grundinformationen
Aus den Dokumenten: Azure Automation bietet einen cloudbasierten Automatisierungs-, Betriebssystem-Updates- und Konfigurationsdienst, der eine konsistente Verwaltung in Ihren Azure- und Nicht-Azure-Umgebungen unterstützt. Es umfasst Prozessautomatisierung, Konfigurationsmanagement, Update-Management, gemeinsame Funktionen und heterogene Merkmale.
Diese sind wie "geplante Aufgaben" in Azure, die es Ihnen ermöglichen, Dinge (Aktionen oder sogar Skripte) auszuführen, um die Azure-Umgebung zu verwalten, zu überprüfen und zu konfigurieren.
Run As-Konto
Wenn das Run as-Konto verwendet wird, erstellt es eine Azure AD Anwendung mit einem selbstsignierten Zertifikat, erstellt einen Dienstprinzipal und weist dem Konto in dem aktuellen Abonnement die Rolle Contributor zu (viele Berechtigungen). Microsoft empfiehlt die Verwendung einer Managed Identity für das Automation Account.
Dies wird am 30. September 2023 entfernt und durch Managed Identities ersetzt.
Runbooks & Jobs
Runbooks ermöglichen es Ihnen, beliebigen PowerShell-Code auszuführen. Dies könnte von einem Angreifer missbraucht werden, um die Berechtigungen des angehängten Prinzips (falls vorhanden) zu stehlen. Im Code der Runbooks könnten Sie auch sensible Informationen (wie Anmeldeinformationen) finden.
Wenn Sie die Jobs lesen können, tun Sie dies, da sie die Ausgabe des Laufs (potenziell sensible Informationen) enthalten.
Gehen Sie zu Automation Accounts
--> <Select Automation Account>
--> Runbooks/Jobs/Hybrid worker groups/Watcher tasks/credentials/variables/certificates/connections
Hybrid Worker
Ein Runbook kann in einem Container innerhalb von Azure oder in einem Hybrid Worker (nicht-Azure-Maschine) ausgeführt werden. Der Log Analytics Agent wird auf der VM bereitgestellt, um sie als Hybrid Worker zu registrieren. Die Hybrid Worker-Jobs werden als SYSTEM unter Windows und als nxautomation-Konto unter Linux ausgeführt. Jeder Hybrid Worker ist in einer Hybrid Worker-Gruppe registriert.
Daher, wenn Sie wählen können, ein Runbook in einem Windows Hybrid Worker auszuführen, führen Sie beliebige Befehle auf einer externen Maschine als System aus (schöne Pivot-Technik).
Kompromittierte Statuskonfiguration (SC)
Aus den Dokumenten: Azure Automation Statuskonfiguration ist ein Azure-Konfigurationsmanagementdienst, der es Ihnen ermöglicht, PowerShell Desired State Configuration (DSC) Konfigurationen für Knoten in jeder Cloud oder in einem lokalen Rechenzentrum zu schreiben, zu verwalten und zu kompilieren. Der Dienst importiert auch DSC-Ressourcen und weist Konfigurationen den Zielknoten zu, alles in der Cloud. Sie können auf Azure Automation State Configuration im Azure-Portal zugreifen, indem Sie Statuskonfiguration (DSC) unter Konfigurationsmanagement auswählen.
Sensible Informationen könnten in diesen Konfigurationen gefunden werden.
RCE
Es ist möglich, SC zu missbrauchen, um beliebige Skripte auf den verwalteten Maschinen auszuführen.
Az - State Configuration RCEEnumeration
Erstellen eines Runbooks
Exfiltrieren von Anmeldeinformationen und Variablen, die in einem Automatisierungskonto definiert sind, mithilfe eines Run Books
Sie könnten dasselbe tun, indem Sie ein vorhandenes Runbook ändern und über die Webkonsole.
Schritte zur Einrichtung einer automatisierten Erstellung von hochprivilegierten Benutzern
1. Ein Automation-Konto initialisieren
Aktion erforderlich: Erstellen Sie ein neues Automation-Konto.
Spezifische Einstellung: Stellen Sie sicher, dass "Azure Run As-Konto erstellen" aktiviert ist.
2. Runbook importieren und einrichten
Quelle: Laden Sie das Beispiel-Runbook aus dem MicroBurst GitHub Repository herunter.
Erforderliche Aktionen:
Importieren Sie das Runbook in das Automation-Konto.
Veröffentlichen Sie das Runbook, um es ausführbar zu machen.
Fügen Sie dem Runbook ein Webhook hinzu, um externe Trigger zu aktivieren.
3. AzureAD-Modul konfigurieren
Aktion erforderlich: Fügen Sie das AzureAD-Modul zum Automation-Konto hinzu.
Zusätzlicher Schritt: Stellen Sie sicher, dass alle Azure Automation-Module auf die neuesten Versionen aktualisiert sind.
4. Berechtigungszuweisung
Zuzuweisende Rollen:
Benutzeradministrator
Abonnementbesitzer
Ziel: Weisen Sie diese Rollen dem Automation-Konto für die erforderlichen Berechtigungen zu.
5. Bewusstsein für potenziellen Zugriffsverlust
Hinweis: Seien Sie sich bewusst, dass die Konfiguration einer solchen Automatisierung dazu führen kann, die Kontrolle über das Abonnement zu verlieren.
6. Benutzererstellung auslösen
Lösen Sie das Webhook aus, um einen neuen Benutzer zu erstellen, indem Sie eine POST-Anfrage senden.
Verwenden Sie das bereitgestellte PowerShell-Skript und stellen Sie sicher, dass Sie die
$uri
durch Ihre tatsächliche Webhook-URL ersetzen und die$AccountInfo
mit dem gewünschten Benutzernamen und Passwort aktualisieren.
Referenzen
Last updated