Kerberos Delegations
Keywords
active directory, kerberos, privesc, rbcdDelegations
graph LR A[User]<-->B[Service]; B<-->C[Resource];
- userrequests for- resourcevia- service
- In other words, serviceimpersonateuserto request forresource
- In other words, servicerequest forresourceon behalf ofuser
- personal note: a ST to krbtgtservice is basically a TGT
Unconstrained Delegation
- serviceaccount needs to have- TRUSTED_FOR_DELEGATIONflag enabled
- userneeds to have- NOT_DELEGATEDflag disabled and is not a member of- Protected Usersgroup
- When userrequests for ST (KRB_TGS_REQ) to accessservice, the domain controller responds with ST together with the copy of theuserTGT
- Thus, servicecan request for anyresourceimpersonating asuserusing theusercopied TGT
Abusing Unconstrained Delegation
Requirements:
- Compromised computer with unconstrained delegation
Attack:
- coerce authentication to our compromised computer to obtain a TGT
- use the TGT to do stuff
Constrained Delegation
- servicecan only request for- resourcedefined in- msDS-AllowedToDelegateTo
- Validation is done on serviceaccount side
- Requires SeEnableDelegationPrivilege(domain admin level privilege) to modifymsDS-AllowedToDelegateTo
- Unlike unconstrained delegation, no copy of the userTGT is given to theservice
Without Protocol Transition (Kerberos Only)
- possible attack path:
- S4U2Selfproduces non-forwardable ST
With Protocol Transition (Any Authentication)
- Identified by TrustedToAuthForDelegationproperty
- S4U2Selfproduces forwardable ST
Resource-based Constrained Delegation (RBCD)
- resourcecan only be requested from- servicedefined in- msDS-AllowedToActOnBehalfOfOtherIdentity
- Validation is done on resourceaccount side
- Only requires rights like GenericAll,GenericWrite,WriteDacl, etc., to modifymsDS-AllowedToActOnBehalfOfOtherIdentity
- Unlike unconstrained delegation, no copy of the userTGT is given to theservice
S4U2Self
- TRUSTED_TO_AUTH_FOR_DELEGATIONappears to have no impact based on Elad's research
- TRUSTED_TO_AUTH_FOR_DELEGATION(Constrained Delegation w/ Protocol Transition) only determines the- forwardableflag on ST- If flag is set, the ST is forwardable
- If flag is not set, the ST is not forwardable
 
- If flag is set, the ST is 
- For this to work, it only requires the service performing S4U2Selfto have SPN
- impersonating protected user would result in non-forwardable ST
Abusing S4U2Self
- To perform local privilege escalation
- Regardless of the impersonated user being sensitive for delegation, S4U2Self could be abused since the SPN (sname/service name) on the ST can be modified as it is not encrypted
S4U2Proxy
- Every ST generated from S4U2Proxyis always forwardable
Constrained Delegation
- requires ST to be forwardable
- userneeds to have- NOT_DELEGATEDflag disabled and is not a member of- Protected Usersgroup (such that the requested ST is- forwardable)
- serviceembeds the- userST in- additional-ticketsfield when requesting ST to access- resource
Resource-based Constrained Delegation (RBCD)
- Does not require the user ST to be forwardable but the user NOT_DELEGATEDflag has the highest priority to determine the success ofS4U2Proxy
- In other words, if the user can be impersonated (NOT_DELEGATEDnot set and is not a member ofProtected Usersgroup), regardless of the existence offorwardableflag in STS4U2Proxywill always success
- If the user NOT_DELEGATEDflag is set and is not a member ofProtected Usersgroup, regardless of the existence offorwardableflag in STS4U2Proxywill always fail
Attack Scenario
Scenario 1 (Generic DACL Abuse)
Scenario:
- ServiceA is compromised computer account with:
- credentials and the ability
- DACL write privilege to modify msDS-AllowedToActOnBehalfOfOtherIdentityon the desired target
 
- ServiceB is our desired target
Attack Path:
- Use ServiceA's DACL write privilege to include ServiceA on ServiceB's msDS-AllowedToActOnBehalfOfOtherIdentity- result: now ServiceA is RBCD to ServiceB
 
- S4U2Selfon ServiceA impersonating non-sensitive user- result: ST for non-sensitive user to access ServiceA
 
- S4U2Proxyon ServiceA- result: ST for the impersonated user to access ServiceB
- reason: this works regardless of previous ST forwardable flag
 
.\Rubeus.exe s4u /user:ServiceA$ /rc4:$ServiceANtlmHash /domain:domain.local /msdsspn:cifs/serviceb.domain.local /impersonateuser:administrator /ptt
# Outcome: PrivEsc on `ServiceB`
Scenario 2 (Reflective RBCD)
warning
According to @M4yFly testing, this has been sliently patched by Microsoft
Pre-requisites:
- computer account credentials or TGT (to perform S4U2Self)
- TRUSTED_TO_AUTH_FOR_DELEGATIONset on computer account (if the computer account is constrained delegation w/o protocol transition, then the- S4U2Proxywould fail since the resulting ST from- S4U2Selfis non-forwardable due to the absence of- TRUSTED_TO_AUTH_FOR_DELEGATION)
- DACL to modify the computer account msDS-AllowedToActOnBehalfOfOtherIdentity
# Use DACL to include `ServiceA` on `ServiceA`'s `msDS-AllowedToActOnBehalfOfOtherIdentity`
# With credentials
.\Rubeus.exe s4u /user:ServiceA$ /rc4:$ServiceANtlmHash /domain:domain.local /msdsspn:cifs/servicea.domain.local /impersonateuser:administrator /ptt
# Or with TGT
.\Rubeus.exe s4u /user:ServiceA$ /ticket:<bas64 blob> /domain:domain.local /msdsspn:cifs/servicea.domain.local /impersonateuser:administrator /ptt
# Outcome: PrivEsc on `ServiceA`
Scenario 3 (Reflective RBCD Impersonating Protected Users)
warning
According to @M4yFly testing, this has been sliently patched by Microsoft
Pre-requisites:
- computer account credentials or TGT (to perform S4U2Self)
- TRUSTED_TO_AUTH_FOR_DELEGATIONset on computer account (if the computer account is constrained delegation w/o protocol transition, then the- S4U2Proxywould fail since the resulting ST from- S4U2Selfis non-forwardable due to the absence of TRUSTED_TO_AUTH_FOR_DELEGATION)
- DACL to modify the computer account msDS-AllowedToActOnBehalfOfOtherIdentity(?)
# Use DACL to include `ServiceA` on `ServiceA`'s `msDS-AllowedToActOnBehalfOfOtherIdentity`
# Successful `S4U2Self`, but failed when `S4U2Proxy`
.\Rubeus.exe s4u /user:ServiceA$ /rc4:$ServiceANtlmHash /domain:domain.local /msdsspn:cifs/servicea.domain.local /impersonateuser:administrator /ptt
# Edit the `sname` field on the ST generated from `S4U2Self` from `ServiceA$` to `cifs/servicea.domain.local`
# Outcome: PrivEsc on `ServiceA`
Scenario 4 (Constrained Delegation w/o Protocol Transition)
Pre-requisites:
- computer account credentials or TGT (to perform DACL write msDS-AllowedToActOnBehalfOfOtherIdentity) that has constrained delegation without protocol transition
- attacker controlled account with SPN (can be achieved by creating a computer account) and no delegation
Scenario:
- ServiceA (attacker controlled account with SPN and no delegation)
- ServiceB (compromised computer account credentials that has constrained delegation without protocol transition)
- ServiceC (ServiceB's msDS-AllowedToDelegateTo target)
Attack Path:
- Use DACL to write ServiceA on ServiceB's msDS-AllowedToActOnBehalfOfOtherIdentity
- S4U2Selfon ServiceA- result: non-forwardable ST (administrator -> ServiceA)
- reason: non-forwardable due to the absence of TrustedToAuthForDelegationon ServiceA
 
- S4U2Proxyon ServiceA targetting ServiceB host SPN by embedding previously obtained non-forwardable ST on- additional-ticketsfield- result: forwardable ST (administrator -> ServiceB)
- reason: this works because ServiceA is not configured to be constrained delegation which does not requires the embedded ST to be forwardable
 
- S4U2Proxyon ServiceB targetting ServiceC SPN (according to ServiceB's- msDS-AllowedToDelegateTovalue) by embedding previously obtained forwardable ST on- additional-ticketsfield- result: forwardable ST (administrator -> ServiceC)
- reason: S4U2Proxyon ServiceB works because the embedded ST is forwardable, otherwise this fails
 
Scenario 5 (Double KCD)
Scenario:
- ServiceA is KCD w/ protocol transition with msDS-AllowedToDelegateToset to ServiceB
- ServiceB is KCD w/o protocol transition with msDS-AllowedToDelegateToset to ServiceC
Pre-requisites:
- ServiceA credentials
Attack Path:
- S4U2Selfon ServiceA- result: forwardable ST (administrator -> ServiceA)
- reason: forwardable as ServiceA has TrustedToAuthForDelegation(with protocol transition)
 
- S4U2Proxyon ServiceA to ServiceB- result: forwardable ST (administrator -> ServiceB)
- reason: success because the embedded ST from previous S4U2Selfis forwardable
 
- S4U2Proxyon ServiceB to ServiceC- result: forwardable ST (administrator -> ServiceC)
- reason: success because the embedded ST from previous S4U2Proxyis forwardable
 
References
- https://en.hackndo.com/constrained-unconstrained-delegation/
- https://beta.hackndo.com/unconstrained-delegation-attack/
- https://beta.hackndo.com/resource-based-constrained-delegation-attack/
- https://labs.withsecure.com/publications/trust-years-to-earn-seconds-to-break
- https://blog.harmj0y.net/activedirectory/s4u2pwnage/
- https://blog.harmj0y.net/redteaming/another-word-on-delegation/
- https://blog.harmj0y.net/activedirectory/a-case-study-in-wagging-the-dog-computer-takeover/
- https://eladshamir.com/2019/01/28/Wagging-the-Dog.html
- https://shenaniganslabs.io/2019/01/28/Wagging-the-Dog.html
- https://dirkjanm.io/worst-of-both-worlds-ntlm-relaying-and-kerberos-delegation/
- https://dirkjanm.io/krbrelayx-unconstrained-delegation-abuse-toolkit/
- https://exploit.ph/delegate-2-thyself.html
- https://exploit.ph/revisiting-delegate-2-thyself.html
- https://cyberstoph.org/posts/2021/06/abusing-kerberos-s4u2self-for-local-privilege-escalation/
- https://en.hackndo.com/service-principal-name-spn/#edge-case---host
- https://attl4s.github.io/assets/pdf/You_do_(not)_Understand_Kerberos_Delegation.pdf
- https://www.notsoshant.io/blog/attacking-kerberos-constrained-delegation/
- https://www.thehacker.recipes/ad/movement/kerberos/delegations#talk
- https://sensepost.com/blog/2020/chaining-multiple-techniques-and-tools-for-domain-takeover-using-rbcd/