127 lines
3.5 KiB
Text
127 lines
3.5 KiB
Text
|
import "pe"
|
||
|
import "hash"
|
||
|
rule dragos_crashoverride_exporting_dlls
|
||
|
{
|
||
|
meta:
|
||
|
description = "CRASHOVERRIDE v1 Suspicious Export"
|
||
|
author = "Dragos Inc"
|
||
|
condition:
|
||
|
pe.exports("Crash") & pe.characteristics
|
||
|
}
|
||
|
rule dragos_crashoverride_suspcious
|
||
|
{
|
||
|
meta:
|
||
|
description = "CRASHOVERRIDE v1 Wiper"
|
||
|
author = "Dragos Inc"
|
||
|
strings:
|
||
|
$s0 = "SYS_BASCON.COM" fullword nocase wide
|
||
|
$s1 = ".pcmp" fullword nocase wide
|
||
|
$s2 = ".pcmi" fullword nocase wide
|
||
|
$s3 = ".pcmt" fullword nocase wide
|
||
|
$s4 = ".cin" fullword nocase wide
|
||
|
condition:
|
||
|
pe.exports("Crash") and any of ($s*)
|
||
|
}
|
||
|
|
||
|
rule dragos_crashoverride_name_search {
|
||
|
meta:
|
||
|
description = "CRASHOVERRIDE v1 Suspicious Strings and Export"
|
||
|
author = "Dragos Inc"
|
||
|
strings:
|
||
|
$s0 = "101.dll" fullword nocase wide
|
||
|
$s1 = "Crash101.dll" fullword nocase wide
|
||
|
$s2 = "104.dll" fullword nocase wide
|
||
|
$s3 = "Crash104.dll" fullword nocase wide
|
||
|
$s4 = "61850.dll" fullword nocase wide
|
||
|
$s5 = "Crash61850.dll" fullword nocase wide
|
||
|
$s6 = "OPCClientDemo.dll" fullword nocase wide
|
||
|
$s7 = "OPC" fullword nocase wide
|
||
|
$s8 = "CrashOPCClientDemo.dll" fullword nocase wide
|
||
|
$s9 = "D2MultiCommService.exe" fullword nocase wide
|
||
|
$s10 = "CrashD2MultiCommService.exe" fullword nocase wide
|
||
|
$s11 = "61850.exe" fullword nocase wide
|
||
|
$s12 = "OPC.exe" fullword nocase wide
|
||
|
$s13 = "haslo.exe" fullword nocase wide
|
||
|
$s14 = "haslo.dat" fullword nocase wide
|
||
|
condition:
|
||
|
any of ($s*) and pe.exports("Crash")
|
||
|
}
|
||
|
|
||
|
rule dragos_crashoverride_moduleStrings {
|
||
|
meta:
|
||
|
description = "IEC-104 Interaction Module Program Strings"
|
||
|
author = "Dragos Inc"
|
||
|
strings:
|
||
|
$s1 = "IEC-104 client: ip=%s; port=%s; ASDU=%u" nocase wide ascii
|
||
|
$s2 = " MSTR ->> SLV" nocase wide ascii
|
||
|
$s3 = " MSTR <<- SLV" nocase wide ascii
|
||
|
$s4 = "Unknown APDU format !!!" nocase wide ascii
|
||
|
$s5 = "iec104.log" nocase wide ascii
|
||
|
condition:
|
||
|
any of ($s*)
|
||
|
}
|
||
|
rule dragos_crashoverride_configReader
|
||
|
{
|
||
|
meta:
|
||
|
description = "CRASHOVERRIDE v1 Config File Parsing"
|
||
|
author = "Dragos Inc"
|
||
|
strings:
|
||
|
$s0 = { 68 e8 ?? ?? ?? 6a 00 e8 a3 ?? ?? ?? 8b f8 83 c4 ?8 }
|
||
|
$s1 = { 8a 10 3a 11 75 ?? 84 d2 74 12 }
|
||
|
$s2 = { 33 c0 eb ?? 1b c0 83 c8 ?? }
|
||
|
$s3 = { 85 c0 75 ?? 8d 95 ?? ?? ?? ?? 8b cf ?? ?? }
|
||
|
condition:
|
||
|
all of them
|
||
|
}
|
||
|
|
||
|
rule dragos_crashoverride_weirdMutex
|
||
|
{
|
||
|
meta:
|
||
|
description = "Blank mutex creation assoicated with CRASHOVERRIDE"
|
||
|
author = "Dragos Inc"
|
||
|
strings:
|
||
|
$s1 = { 81 ec 08 02 00 00 57 33 ff 57 57 57 ff 15 ?? ?? 40 00 a3 ?? ?? ?? 00
|
||
|
85 c0 }
|
||
|
$s2 = { 8d 85 ?? ?? ?? ff 50 57 57 6a 2e 57 ff 15 ?? ?? ?? 00 68 ?? ?? 40 00}
|
||
|
condition:
|
||
|
all of them
|
||
|
}
|
||
|
rule dragos_crashoverride_serviceStomper
|
||
|
{
|
||
|
meta:
|
||
|
description = "Identify service hollowing and persistence setting"
|
||
|
author = "Dragos Inc"
|
||
|
strings:
|
||
|
$s0 = { 33 c9 51 51 51 51 51 51 ?? ?? ?? }
|
||
|
$s1 = { 6a ff 6a ff 6a ff 50 ff 15 24 ?? 40 00 ff ?? ?? ff 15 20 ?? 40 00 }
|
||
|
condition:
|
||
|
all of them
|
||
|
}
|
||
|
|
||
|
rule dragos_crashoverride_wiperModuleRegistry
|
||
|
{
|
||
|
meta:
|
||
|
description = "Registry Wiper functionality assoicated with CRASHOVERRIDE"
|
||
|
author = "Dragos Inc"
|
||
|
strings:
|
||
|
$s0 = { 8d 85 a0 ?? ?? ?? 46 50 8d 85 a0 ?? ?? ?? 68 68 0d ?? ?? 50 }
|
||
|
$s1 = { 6a 02 68 78 0b ?? ?? 6a 02 50 68 b4 0d ?? ?? ff b5 98 ?? ?? ?? ff 15
|
||
|
04 ?? ?? ?? }
|
||
|
$s2 = { 68 00 02 00 00 8d 85 a0 ?? ?? ?? 50 56 ff b5 9c ?? ?? ?? ff 15 00 ??
|
||
|
?? ?? 85 c0 }
|
||
|
condition:
|
||
|
all of them
|
||
|
}
|
||
|
rule dragos_crashoverride_wiperFileManipulation
|
||
|
{
|
||
|
meta:
|
||
|
description = "File manipulation actions associated with CRASHOVERRIDE wip- er"
|
||
|
author = "Dragos Inc"
|
||
|
strings:
|
||
|
$s0 = { 6a 00 68 80 00 00 00 6a 03 6a 00 6a 02 8b f9 68 00 00 00 40 57 ff 15
|
||
|
1c ?? ?? ?? 8b d8 }
|
||
|
$s2 = { 6a 00 50 57 56 53 ff 15 4c ?? ?? ?? 56 }
|
||
|
condition:
|
||
|
all of them
|
||
|
}
|