This is similar to the basic [Constrained Delegation](constrained-delegation.md) but **instead **of giving permissions to an **object **to **impersonate any user against a service**. Resource-based Constrain Delegation **sets **in** the object who is able to impersonate any user against it**.
In this case, the constrained object will have an attribute called_** msDS-AllowedToActOnBehalfOfOtherIdentity**_ with the name of the user that can impersonate any other user against it.
Another important difference from this Constrained Delegation to the other delegations is that any user with **write permissions over a machine account **(_GenericAll/GenericWrite/WriteDacl/WriteProperty/etc_)** **can set the _**msDS-AllowedToActOnBehalfOfOtherIdentity **_(In the other forms of Delegation you needed domain admin privs).
Back in Constrained Delegation it was told that the _**TrustedToAuthForDelegation **_flag inside the _userAccountControl _ value of the user is needed to perform a **S4U2Self. **But that's not completely truth.\
The reality is that even without that value, you can perform a **S4U2Self **against any user if you are a **service **(have a SPN) but, if you **have **_**TrustedToAuthForDelegation ** _the returned TGS will be **Forwardable **and if you **don't have** that flag the returned TGS **won't **be **Forwardable**.
However, if the **TGS **used in **S4U2Proxy **is **NOT Forwardable** trying to abuse a **basic Constrain Delegation **it **won't work**. But if you are trying to exploit a **Resource-Based constrain delegation, it will work **(this is not a vulnerability, it's a feature, apparently).
1. The attacker **compromises **an account that has a **SPN **or **creates one **(“Service A”). Note that **any **_Admin User _without any other special privilege can **create **up****until 10 **Computer objects (**_**MachineAccountQuota**_**) **and set them a **SPN**. So the attacker can just create a Computer object and set a SPN.
3. The attacker uses Rubeus to perform a **full S4U attack** (S4U2Self and S4U2Proxy) from Service A to Service B for a user **with privileged access to Service B**.
1. S4U2Self (from the SPN compromised/created account): Ask for a **TGS of Administrator to me** (Not Forwardable).
2. S4U2Proxy: Use the **not Forwardable TGS** of the step before to ask for a **TGS **from **Administrator **to the **victim host**.
Note that users has an attribute called "**Cannot be delegated**". If a user has this attribute to True, you won't be able to impersonate him . This property can be seen inside bloodhound.
* **`KDC_ERR_ETYPE_NOTSUPP`**: This means that kerberos is configured to not use DES or RC4 and you are supplying just the RC4 hash. Supply to Rubeus at least the AES256 hash (or just supply it the rc4, aes128 and aes256 hashes). Example:` [Rubeus.Program]::MainString("s4u /user:FAKECOMPUTER /aes256:CC648CF0F809EE1AA25C52E963AC0487E87AC32B1F71ACC5304C73BF566268DA /aes128:5FC3D06ED6E8EA2C9BB9CC301EA37AD4 /rc4:EF266C6B963C0BB683941032008AD47F /impersonateuser:Administrator /msdsspn:CIFS/M3DC.M3C.LOCAL /ptt".split())`
* **`preauth_failed`**: This means that the given username + hashes aren't working to login. You may have forgotten to put the "$" inside the username when generating the hashes (`.\Rubeus.exe hash /password:123456 /user:FAKECOMPUTER$ /domain:domain.local`)
* The user you are trying to impersonate cannot access the desired service (because you cannot impersonate it or because it doesn't have enough privileges)
* The asked service doesn't exist (if you ask for a ticket for winrm but winrm isn't running)