Detection rules › Sigma

Group discovery (PowerShell)

Severity
medium
Log source
product windows, category ['ps_module', 'ps_classic_script', 'ps_script']
Author
mdecrevoisier
Source
github.com/mdecrevoisier/SIGMA-detection-rules

Detects scenarios where an attacker attempts to enumerate local or domain groups via PowerShell.

MITRE ATT&CK coverage

Event coverage

Rule body yaml

title: Group discovery (PowerShell)
description: Detects scenarios where an attacker attempts to enumerate local or domain groups via PowerShell.
references:
- https://blogs.jpcert.or.jp/en/2016/01/windows-commands-abused-by-attackers.html
- https://github.com/swisskyrepo/PayloadsAllTheThings/blob/master/Methodology%20and%20Resources/Windows%20-%20Privilege%20Escalation.md
- https://docs.microsoft.com/en-us/powershell/module/activedirectory/get-adgroup?view=windowsserver2019-ps
- https://adamtheautomator.com/get-adgroupmember/
tags:
- attack.discovery
- attack.t1069.001 # Permission Groups Discovery: Local Groups 
- attack.t1069.002 # Permission Groups Discovery: Domain Groups 
author: mdecrevoisier
logsource:
  product: windows
  category:
    - ps_module
    - ps_classic_script
    - ps_script
detection:
  selection_powershell_native:
    EventID: 800
    EventData|contains|all:
      - Get-LocalGroupMember # Get-LocalGroupMember -Name Administrators
      - Get-ADGroupMember    # Get-ADGroupMember -Identity Administrators

  selection_powershell_modern:
    EventID: 4103
    Payload|contains|all:
      - Get-LocalGroupMember
      - Get-ADGroupMember

  selection_powershell_block:
    EventID: 4104
    ScriptBlockText|contains|all:
      - Get-LocalGroupMember
      - Get-ADGroupMember

  condition: 1 of selection* | count(EventRecordID) by Computer > 4
falsepositives:
- Pentest
- Administrator activity
level: medium

Stages and Predicates

Stage 0: condition

1 of selection* | count(EventRecordID) by Computer > 4

Stage 1: selection_powershell_native

selection_powershell_native:
  EventID: 800
  EventData|contains|all:
    - Get-LocalGroupMember
    - Get-ADGroupMember
Threshold
> 4

Stage 2: selection_powershell_modern

selection_powershell_modern:
  EventID: 4103
  Payload|contains|all:
    - Get-LocalGroupMember
    - Get-ADGroupMember

Stage 3: selection_powershell_block

selection_powershell_block:
  EventID: 4104
  ScriptBlockText|contains|all:
    - Get-LocalGroupMember
    - Get-ADGroupMember

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
EventDatamatch
  • Get-ADGroupMember
  • Get-LocalGroupMember
Payloadmatch
  • Get-ADGroupMember
  • Get-LocalGroupMember
ScriptBlockTextmatch
  • Get-ADGroupMember
  • Get-LocalGroupMember