Detection rules › Sigma

Microsoft Defender security components disabled (PowerShell)

Status
experimental
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 disable Defender security features in PowerShell

MITRE ATT&CK coverage

Event coverage

Rule body yaml

title: Microsoft Defender security components disabled (PowerShell)
description: Detects scenarios where an attacker attempts to disable Defender security features in PowerShell
references:
- https://github.com/mdecrevoisier/EVTX-to-MITRE-Attack/tree/master/TA0005-Defense%20Evasion/T1562.001-Impair%20Defenses-Disable%20or%20Modify%20tool
- https://github.com/swagkarna/Defeat-Defender-V1.2
- https://docs.microsoft.com/en-us/powershell/module/defender/set-mppreference?view=windowsserver2019-ps
- https://docs.microsoft.com/en-us/windows/client-management/mdm/defender-csp
- https://powershell.one/wmi/root/microsoft/windows/defender/msft_mppreference
- https://gist.github.com/pe3zx/7c5e0080c3b0869ccba1f1dc2ea0c5e0
- https://cloudbrothers.info/en/current-limits-defender-av-tamper-protection/
tags:
- attack.defense_evasion
- attack.t1562.001
author: mdecrevoisier
status: experimental
logsource:
  product: windows
  category:
    - ps_module
    - ps_classic_script
    - ps_script
detection: # Set-MpPreference -DisableArchiveScanning $true
  selection1_powershell_native:
    EventID: 800
    EventData|contains: Set-MpPreference
      - Add-MpPreference
    EventData|contains:
      - '1'
      - '$true'
    EventData|contains:
      # Scanning features
      - DisableArchiveScanning
      - DisableRemovableDriveScanning
      - DisableScanningMappedNetworkDrivesForFullScan
      - DisableScanningNetworkFiles
      - DisableRestorePoint
      - DisableScriptScanning
      - DisableEmailScanning
      # Parsing features
      - DisableDnsParsing
      - DisableDnsOverTcpParsing
      - DisableSshParsing
      - DisableTlsParsing
      - DisableHttpParsing
      - DisableRdpParsing
      # Misc features
      - DisableAutoExclusions
      - DisableBlockAtFirstSeen
      - DisableCpuThrottleOnIdleScans
      - DisableDatagramProcessing
      - SignatureDisableUpdateOnStartupWithoutEngine

  selection2_powershell_modern:
    EventID: 4103
    EventData|contains: Set-MpPreference
      - Add-MpPreference
    Payload|contains:
      - '1'
      - '$true'
    Payload|contains:
      # Scanning features
      - DisableArchiveScanning
      - DisableRemovableDriveScanning
      - DisableScanningMappedNetworkDrivesForFullScan
      - DisableScanningNetworkFiles
      - DisableRestorePoint
      - DisableScriptScanning
      - DisableEmailScanning
      # Parsing features
      - DisableDnsParsing
      - DisableDnsOverTcpParsing
      - DisableSshParsing
      - DisableTlsParsing
      - DisableHttpParsing
      - DisableRdpParsing
      # Misc features
      - DisableAutoExclusions
      - DisableBlockAtFirstSeen
      - DisableCpuThrottleOnIdleScans
      - DisableDatagramProcessing

  selection3_powershell_block:
    EventID: 4104
    EventData|contains: Set-MpPreference
      - Add-MpPreference
    ScriptBlockText|contains:
      - '1'
      - '$true'
    ScriptBlockText|contains:
      # Scanning features
      - DisableArchiveScanning
      - DisableRemovableDriveScanning
      - DisableScanningMappedNetworkDrivesForFullScan
      - DisableScanningNetworkFiles
      - DisableRestorePoint
      - DisableScriptScanning
      - DisableEmailScanning
      # Parsing features
      - DisableDnsParsing
      - DisableDnsOverTcpParsing
      - DisableSshParsing
      - DisableTlsParsing
      - DisableHttpParsing
      - DisableRdpParsing
      # Misc features
      - DisableAutoExclusions
      - DisableBlockAtFirstSeen
      - DisableCpuThrottleOnIdleScans
      - DisableDatagramProcessing

  condition: 1 of selection*
falsepositives:
- None
level: medium

Stages and Predicates

Stage 0: condition

1 of selection*

Stage 1: selection1_powershell_native

selection1_powershell_native:
  EventID: 800
  EventData|contains: Set-MpPreference
    - Add-MpPreference
  EventData|contains:
    - '1'
    - '$true'
  EventData|contains:
    - DisableArchiveScanning
    - DisableRemovableDriveScanning
    - DisableScanningMappedNetworkDrivesForFullScan
    - DisableScanningNetworkFiles
    - DisableRestorePoint
    - DisableScriptScanning
    - DisableEmailScanning
    - DisableDnsParsing
    - DisableDnsOverTcpParsing
    - DisableSshParsing
    - DisableTlsParsing
    - DisableHttpParsing
    - DisableRdpParsing
    - DisableAutoExclusions
    - DisableBlockAtFirstSeen
    - DisableCpuThrottleOnIdleScans
    - DisableDatagramProcessing
    - SignatureDisableUpdateOnStartupWithoutEngine

Stage 2: selection2_powershell_modern

selection2_powershell_modern:
  EventID: 4103
  EventData|contains: Set-MpPreference
    - Add-MpPreference
  Payload|contains:
    - '1'
    - '$true'
  Payload|contains:
    - DisableArchiveScanning
    - DisableRemovableDriveScanning
    - DisableScanningMappedNetworkDrivesForFullScan
    - DisableScanningNetworkFiles
    - DisableRestorePoint
    - DisableScriptScanning
    - DisableEmailScanning
    - DisableDnsParsing
    - DisableDnsOverTcpParsing
    - DisableSshParsing
    - DisableTlsParsing
    - DisableHttpParsing
    - DisableRdpParsing
    - DisableAutoExclusions
    - DisableBlockAtFirstSeen
    - DisableCpuThrottleOnIdleScans
    - DisableDatagramProcessing

Stage 3: selection3_powershell_block

selection3_powershell_block:
  EventID: 4104
  EventData|contains: Set-MpPreference
    - Add-MpPreference
  ScriptBlockText|contains:
    - '1'
    - '$true'
  ScriptBlockText|contains:
    - DisableArchiveScanning
    - DisableRemovableDriveScanning
    - DisableScanningMappedNetworkDrivesForFullScan
    - DisableScanningNetworkFiles
    - DisableRestorePoint
    - DisableScriptScanning
    - DisableEmailScanning
    - DisableDnsParsing
    - DisableDnsOverTcpParsing
    - DisableSshParsing
    - DisableTlsParsing
    - DisableHttpParsing
    - DisableRdpParsing
    - DisableAutoExclusions
    - DisableBlockAtFirstSeen
    - DisableCpuThrottleOnIdleScans
    - DisableDatagramProcessing

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
  • DisableArchiveScanning
  • DisableAutoExclusions
  • DisableBlockAtFirstSeen
  • DisableCpuThrottleOnIdleScans
  • DisableDatagramProcessing
  • DisableDnsOverTcpParsing
  • DisableDnsParsing
  • DisableEmailScanning
  • DisableHttpParsing
  • DisableRdpParsing
  • DisableRemovableDriveScanning
  • DisableRestorePoint
  • DisableScanningMappedNetworkDrivesForFullScan
  • DisableScanningNetworkFiles
  • DisableScriptScanning
  • DisableSshParsing
  • DisableTlsParsing
  • Set-MpPreference - Add-MpPreference
  • SignatureDisableUpdateOnStartupWithoutEngine
Payloadmatch
  • DisableArchiveScanning
  • DisableAutoExclusions
  • DisableBlockAtFirstSeen
  • DisableCpuThrottleOnIdleScans
  • DisableDatagramProcessing
  • DisableDnsOverTcpParsing
  • DisableDnsParsing
  • DisableEmailScanning
  • DisableHttpParsing
  • DisableRdpParsing
  • DisableRemovableDriveScanning
  • DisableRestorePoint
  • DisableScanningMappedNetworkDrivesForFullScan
  • DisableScanningNetworkFiles
  • DisableScriptScanning
  • DisableSshParsing
  • DisableTlsParsing
ScriptBlockTextmatch
  • DisableArchiveScanning
  • DisableAutoExclusions
  • DisableBlockAtFirstSeen
  • DisableCpuThrottleOnIdleScans
  • DisableDatagramProcessing
  • DisableDnsOverTcpParsing
  • DisableDnsParsing
  • DisableEmailScanning
  • DisableHttpParsing
  • DisableRdpParsing
  • DisableRemovableDriveScanning
  • DisableRestorePoint
  • DisableScanningMappedNetworkDrivesForFullScan
  • DisableScanningNetworkFiles
  • DisableScriptScanning
  • DisableSshParsing
  • DisableTlsParsing