Detection rules › Splunk

RDP Enabled (PowerShell)

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

Detects if RDP service has been enabled on Windows host

MITRE ATT&CK coverage

References

Event coverage

Rule body yaml

id: '1106.1172'
title: RDP Enabled
description: 'Detects if RDP service has been enabled on Windows host -- Threat Actor
  Association: APT35/Phosphorus/Magic Hound, DarkSide, BlackMatter, FIN7, TA551, Wizard
  Spider, Yanluowang -- Software Association: BianLian, Black Basta, Conti, Hive,
  IcedID, Insekt, Lockbit, Nefilim, Ryuk Ransomware, Sodinokibi/REvil'
logic_format: Splunk
logic: '`get_endpoint_data` `get_endpoint_data_powershell` signature_id=4104 AND (((TERM(reg)
  AND TERM(add)) OR TERM(Set-ItemProperty) ) AND (TERM(fDenyTSConnections) AND "Terminal
  Server") AND ((TERM(REG_DWORD) AND TERM(/d) AND TERM(0)) OR (TERM(-value) AND TERM(0))))
  OR (TERM(netsh) AND TERM(remote) AND TERM(desktop) AND TERM(enable=yes)) OR (TERM(Enable-NetFirewallRule)
  AND TERM(remote) AND TERM(-displaygroup)) | rex field=process mode=sed max_match=0
  "s/(?mi)^(Path:(.+)?)|^(ScriptBlock.+)|^(Creating Scriptblock.+)//g"| rex field=process
  mode=sed "s/[\n\r]+|\s\s+//g" | table _time, host, user process, signature_id |
  bin span=1s | stats values(*) as * by _time, host '
techniques:
- defense-evasion:modify registry
- lateral-movement:remote services:remote desktop protocol
technique_id:
- T1112
- T1021.001
data_category:
- PowerShell logs
- Process command-line parameters
references:
- https://pureinfotech.com/enable-remote-desktop-command-prompt-windows-10/

Stages and Predicates

Stage 1: search

`get_endpoint_data` `get_endpoint_data_powershell` signature_id=4104 AND (((TERM(reg) AND TERM(add)) OR TERM(Set-ItemProperty) ) AND (TERM(fDenyTSConnections) AND "Terminal Server") AND ((TERM(REG_DWORD) AND TERM(/d) AND TERM(0)) OR (TERM(-value) AND TERM(0)))) OR (TERM(netsh) AND TERM(remote) AND TERM(desktop) AND TERM(enable=yes)) OR (TERM(Enable-NetFirewallRule) AND TERM(remote) AND TERM(-displaygroup))

Stage 2: eval

| rex field=process mode=sed max_match=0 "s/(?mi)^(Path:(.+)?)|^(ScriptBlock.+)|^(Creating Scriptblock.+)//g"

Stage 3: eval

| rex field=process mode=sed "s/[\n\r]+|\s\s+//g"

Stage 4: table

| table _time, host, user process, signature_id

Stage 5: bucket

| bin span=1s

Stage 6: stats

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

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
signature_ideq
  • 4104 corpus 4 (splunk 4)

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
1reg
1TERM
1add
1"Set-ItemProperty"
1TERM
1fDenyTSConnections
1"Terminal Server"
1TERM
1REG_DWORD
1"/d"
1TERM
10
1"-value"
1TERM
10
1TERM
1netsh
1TERM
1remote
1TERM
1desktop
1"enable=yes"
1"Enable-NetFirewallRule"
1TERM
1remote
1"-displaygroup"