Detection rules › Sigma

Service permissions hijacked for privileges abuse (Reg via PowerShell)

Status
experimental
Severity
high
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 modify the permissions of a service using native PowerShell commands in order to abuse its privileges. Note that it requires PowerShell 7 or higher.

MITRE ATT&CK coverage

Event coverage

Rule body yaml

title: Service permissions hijacked for privileges abuse (Reg via PowerShell)
description: Detects scenarios where an attacker modify the permissions of a service using native PowerShell commands in order to abuse its privileges. Note that it requires PowerShell 7 or higher.
references:
- http://woshub.com/set-permissions-on-windows-service/
- https://www.winhelponline.com/blog/view-edit-service-permissions-windows/
- https://decoder.cloud/2019/02/07/demystifying-windows-service-permissions-configuration/
- https://docs.microsoft.com/en-us/powershell/module/microsoft.powershell.management/set-service?view=powershell-7.1
- https://medium.com/r3d-buck3t/abuse-service-registry-acls-windows-privesc-f88079140509
- https://github.com/rohnedwards/PowerShellAccessControl
tags:
- attack.persistence
- attack.t1543.003
- attack.t1574.010
author: mdecrevoisier
status: experimental
logsource:
  product: windows
  category:
    - ps_module
    - ps_classic_script
    - ps_script
detection:
  selection_powershell_native:
    EventID: 800
    EventData|re: '\\SYSTEM\\CurrentControlSet\\Services\\.*\\Security'
    EventData|contains|all:
      - '-ItemProperty' # Can be New-* or Set-*
      - Security

  selection_powershell_modern:
    EventID: 4103
    Payload|re: '\\SYSTEM\\CurrentControlSet\\Services\\.*\\Security'
    Payload|contains|all:
      - '-ItemProperty' # Can be New-* or Set-*
      - Security

  selection_powershell_block:
    EventID: 4104
    ScriptBlockText|re: '\\SYSTEM\\CurrentControlSet\\Services\\.*\\Security'
    ScriptBlockText|contains|all:
      - '-ItemProperty' # Can be New-* or Set-*
      - Security

  condition: 1 of selection*
falsepositives:
- administrator reconfiguring service
level: high

Stages and Predicates

Stage 0: condition

1 of selection*

Stage 1: selection_powershell_native

selection_powershell_native:
  EventID: 800
  EventData|re: '\\SYSTEM\\CurrentControlSet\\Services\\.*\\Security'
  EventData|contains|all:
    - '-ItemProperty'
    - Security

Stage 2: selection_powershell_modern

selection_powershell_modern:
  EventID: 4103
  Payload|re: '\\SYSTEM\\CurrentControlSet\\Services\\.*\\Security'
  Payload|contains|all:
    - '-ItemProperty'
    - Security

Stage 3: selection_powershell_block

selection_powershell_block:
  EventID: 4104
  ScriptBlockText|re: '\\SYSTEM\\CurrentControlSet\\Services\\.*\\Security'
  ScriptBlockText|contains|all:
    - '-ItemProperty'
    - Security

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
  • -ItemProperty corpus 5 (sigma 5)
  • Security
EventDataregex_match
  • \SYSTEM\CurrentControlSet\Services\.*\Security
Payloadmatch
  • -ItemProperty corpus 5 (sigma 5)
  • Security
Payloadregex_match
  • \SYSTEM\CurrentControlSet\Services\.*\Security
ScriptBlockTextmatch
  • -ItemProperty corpus 5 (sigma 5)
  • Security
ScriptBlockTextregex_match
  • \SYSTEM\CurrentControlSet\Services\.*\Security