Detection rules › Sigma
System time changed (PowerShell)
Detects scenarios where an attacker attempts to change the system time to evade defense.
MITRE ATT&CK coverage
| Tactic | Techniques |
|---|---|
| Stealth | T1070.006 Indicator Removal: Timestomp |
Event coverage
| Provider | Event | Title |
|---|---|---|
| PowerShell | Event ID 4103 | Payload Context: ContextInfo User Data: UserData. |
| PowerShell | Event ID 4104 | Creating Scriptblock text (MessageNumber of MessageTotal). |
| PowerShell | Event ID 800 | Event ID 800 |
Rule body yaml
title: System time changed (PowerShell)
description: Detects scenarios where an attacker attempts to change the system time to evade defense.
references:
- https://github.com/mdecrevoisier/EVTX-to-MITRE-Attack/tree/master/TA0005-Defense%20Evasion/T1070.006-Timestomp
- https://blog.menasec.net/2019/02/threat-hunting-19-suspicious-system.html
- https://docs.microsoft.com/en-us/powershell/module/microsoft.powershell.utility/set-date
tags:
- attack.defense_evasion
- attack.t1070.006
author: mdecrevoisier
status: experimental
logsource:
product: windows
category:
- ps_module
- ps_classic_script
- ps_script
detection: # full command: Set-Date -Date (Get-Date).AddDays(3)
selection_powershell_native:
EventID: 800
EventData|contains: Set-Date
EventData|contains:
- -Date
- -Adjust
selection_powershell_modern:
EventID: 4103
Payload|contains: Set-Date
Payload|contains:
- -Date
- -Adjust
selection_powershell_block:
EventID: 4104
ScriptBlockText|contains: Set-Date
ScriptBlockText|contains:
- -Date
- -Adjust
condition: selection_powershell_native or selection_powershell_modern or selection_powershell_block
falsepositives:
- None
level: medium
Stages and Predicates
Stage 0: condition
selection_powershell_native or selection_powershell_modern or selection_powershell_blockStage 1: selection_powershell_native
selection_powershell_native:
EventID: 800
EventData|contains: Set-Date
EventData|contains:
- -Date
- -Adjust
Stage 2: selection_powershell_modern
selection_powershell_modern:
EventID: 4103
Payload|contains: Set-Date
Payload|contains:
- -Date
- -Adjust
Stage 3: selection_powershell_block
selection_powershell_block:
EventID: 4104
ScriptBlockText|contains: Set-Date
ScriptBlockText|contains:
- -Date
- -Adjust
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.
| Field | Kind | Values |
|---|---|---|
EventData | match |
|
Payload | match |
|
ScriptBlockText | match |
|