Detection rules › Splunk

SecretsDump Credential Harvest (Windows Event Log)

Group by
_time, host, session_id
Source
github.com/anvilogic-forge/armory

SecretsDump.py Performs various techniques to dump hashes from the remote machine without executing any agent there

MITRE ATT&CK coverage

References

Event coverage

Rule body yaml

id: '5412.5535'
title: SecretsDump Credential Harvest
description: 'SecretsDump.py Performs various techniques to dump hashes from the remote
  machine without executing any agent there. -- Threat Actor Association: APT15, Scattered
  Spider (aka. 0ktapus, UNC3944), Volt Typhoon -- Software Association: Rhysida'
logic_format: Splunk
logic: '`get_endpoint_data` `get_endpoint_data_winevent` ((TERM(EventCode=4624) OR
  "<EventID>4624<") Authentication_Package="NTLM") OR ((TERM(EventCode=4661) OR "<EventID>4661<")
  TERM(SAM)) OR ((TERM(EventCode=5145) OR "<EventID>5145<") TERM(SAMR)) | rex field=_raw
  "Account Name:\s+(?<user>\S+\$)" | table _time, host, user signature_id, Account_Name,
  user, Relative_Target_Name, signature_id, src_ip, session_id | bin span=1s | stats
  values(*) as * by _time, host, session_id | where (match(signature_id, "(?i)4624")
  AND match(signature_id, "(?i)5145") AND match(signature_id, "(?i)4661")) | eventstats
  dc(src_ip) as dc_src_ip by host| where dc_src_ip=1 '
techniques:
- credential-access:os credential dumping:security account manager
technique_id:
- T1003.002
data_category:
- Windows event logs
references:
- https://github.com/SecureAuthCorp/impacket/blob/master/examples/secretsdump.py

Stages and Predicates

Stage 1: search

`get_endpoint_data` `get_endpoint_data_winevent` ((TERM(EventCode=4624) OR "<EventID>4624<") Authentication_Package="NTLM") OR ((TERM(EventCode=4661) OR "<EventID>4661<") TERM(SAM)) OR ((TERM(EventCode=5145) OR "<EventID>5145<") TERM(SAMR))

Stage 2: rex

| rex field=_raw "Account Name:\s+(?<user>\S+\$)"

Stage 3: table

| table _time, host, user signature_id, Account_Name, user, Relative_Target_Name, signature_id, src_ip, session_id

Stage 4: bucket

| bin span=1s

Stage 5: stats

| stats values(*) as * by _time, host, session_id

Stage 6: where

| where (match(signature_id, "(?i)4624") AND match(signature_id, "(?i)5145") AND match(signature_id, "(?i)4661"))

Stage 7: eventstats

| eventstats dc(src_ip) as dc_src_ip by host

Stage 8: where

| where dc_src_ip=1

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.

FieldKindValues
Authentication_Packageeq
  • "NTLM" corpus 3 (splunk 3)
EventCodeeq
  • 4624 corpus 25 (splunk 13, kusto 8, chronicle 4)
  • 4661
  • 5145 corpus 18 (splunk 16, kusto 2)
dc_src_ipeq
  • 1
signature_idmatch
  • "(?i)4624" corpus 2 (splunk 2)
  • "(?i)4661"
  • "(?i)5145" corpus 2 (splunk 2)

Search terms

Bare-string tokens in the SPL search body. Splunk matches each token against _raw (the untyped raw event text) anywhere it appears, not against a specific field. These don't surface in the Indicators table because they aren't predicates on a known field.

StageTerm
1TERM
1"<EventID>4624<"
1TERM
1"<EventID>4661<"
1TERM
1SAM
1TERM
1"<EventID>5145<"
1TERM
1SAMR