PowerShellMafia / PowerSploit

PowerSploit - A PowerShell Post-Exploitation Framework
Other
11.68k stars 4.59k forks source link

Prevent constraint violation on objects with restrictive permissions #338

Open pantsman0 opened 4 years ago

pantsman0 commented 4 years ago

This change restricts access to ADSI object so they're only writting to the ACL. This fixes an issue writting an ACL when you exclusively have WriteDacl permission on a object.

I have run up against this issue in a pentest where it meant I wasn't able to get to DA, but didn't know what was going on. I also came up against it in a HtB machine, so I had time to debug the tool and see what was going on.

This was an issue because if you don't set the security mask to Dacl, it will attempt to write the whole object back to LDAP instead of just the ACE. If you only have WriteDacl on the object, this will obviously fail.

This change has been tested against a HtB machine, and successfully wrote DCSync privs where the current master failed.