Detection rules › Sigma
Kerberos enumeration with existing/unexisting users (Kerbrute)
Detects scenarios where an attacker attempts to enumerate existing or non existing users using "Kerbrute". This use case can also be related to spot vulnearbility "MS14-068".
MITRE ATT&CK coverage
| Tactic | Techniques |
|---|---|
| Credential Access | T1110 Brute Force |
Event coverage
| Provider | Event | Title |
|---|---|---|
| Security-Auditing | Event ID 4768 | A Kerberos authentication ticket (TGT) was requested. |
| Security-Auditing | Event ID 4771 | Kerberos pre-authentication failed. |
Rule body yaml
title: Kerberos enumeration with existing/unexisting users (Kerbrute)
name: kerbrute_enumeration
description: Detects scenarios where an attacker attempts to enumerate existing or non existing users using "Kerbrute". This use case can also be related to spot vulnearbility "MS14-068".
references:
- https://github.com/mdecrevoisier/EVTX-to-MITRE-Attack/tree/master/TA0006-Credential%20Access/T1110.xxx-Brut%20force
- https://github.com/ropnop/kerbrute
- https://www.jpcert.or.jp/english/pub/sr/20170612ac-ir_research_en.pdf
tags:
- attack.credential_access
- attack.t1110
author: mdecrevoisier
status: experimental
logsource:
product: windows
service: security
detection:
selection:
EventID:
- 4771
- 4768
Status: "0x6" # KDC_ERR_C_PRINCIPAL_UNKNOWN
TicketOptions: 0x50800000
filter:
- IpAddress: "%domain_controllers_ips%" # reduce amount of false positives
- TargetUserName: "%account_allowed_proxy%" # accounts allowed to perform proxiable requests
condition: selection and not filter
falsepositives:
- Missconfigured application or identity services
level: high
---
title: Kerberos enumeration with existing/unexisting users (Kerbrute) Count
status: experimental
correlation:
type: value_count
rules:
- kerbrute_enumeration # Referenced here
group-by:
- Computer
timespan: 30m
condition:
gte: 20
field: TargetUserName # Count how many failed logins were reported on the domain controller.
level: high
Stages and Predicates
Stage 0: condition
selection and not filterStage 1: selection
selection:
EventID:
- 4771
- 4768
Status: "0x6"
TicketOptions: 0x50800000
Stage 2: not filter
filter:
- IpAddress: "%domain_controllers_ips%"
- TargetUserName: "%account_allowed_proxy%"
Exclusions
Top-level NOT(...) conjuncts: predicates this rule actively suppresses.
| Field | Kind | Excluded values |
|---|---|---|
IpAddress | eq | %domain_controllers_ips% |
TargetUserName | eq | %account_allowed_proxy% |
Indicators
Each row is a field, operator, and value that the rule matches. The corpus column counts how many other rules in the catalog look for the same combination: high numbers point to widely-used, community-vetted indicators. Blank or 1 shows that the indicator is specific to this rule.
| Field | Kind | Values |
|---|---|---|
Status | eq |
|
TicketOptions | eq |
|