Actor(s): Equation Group
FancyFilter is a piece of code that documents code overlap between frameworks used by Regin and Equation Group.
rule win_fancyfilter_auto { meta: author = "Felix Bilstein - yara-signator at cocacoding dot com" date = "2023-01-25" version = "1" description = "Detects win.fancyfilter." info = "autogenerated rule brought to you by yara-signator" tool = "yara-signator v0.6.0" signator_config = "callsandjumps;datarefs;binvalue" malpedia_reference = "https://malpedia.caad.fkie.fraunhofer.de/details/win.fancyfilter" malpedia_rule_date = "20230124" malpedia_hash = "2ee0eebba83dce3d019a90519f2f972c0fcf9686" malpedia_version = "20230125" malpedia_license = "CC BY-SA 4.0" malpedia_sharing = "TLP:WHITE" /* DISCLAIMER * The strings used in this rule have been automatically selected from the * disassembly of memory dumps and unpacked files, using YARA-Signator. * The code and documentation is published here: * https://github.com/fxb-cocacoding/yara-signator * As Malpedia is used as data source, please note that for a given * number of families, only single samples are documented. * This likely impacts the degree of generalization these rules will offer. * Take the described generation method also into consideration when you * apply the rules in your use cases and assign them confidence levels. */ strings: $sequence_0 = { 85c0 750d 8b472c a801 7406 83c804 } // n = 6, score = 400 // 85c0 | test eax, eax // 750d | jne 0xf // 8b472c | mov eax, dword ptr [edi + 0x2c] // a801 | test al, 1 // 7406 | je 8 // 83c804 | or eax, 4 $sequence_1 = { 8d4f20 51 50 ff15???????? 8b36 } // n = 5, score = 400 // 8d4f20 | lea ecx, [edi + 0x20] // 51 | push ecx // 50 | push eax // ff15???????? | // 8b36 | mov esi, dword ptr [esi] $sequence_2 = { 81e3ffffff00 ff15???????? 50 ff15???????? } // n = 4, score = 400 // 81e3ffffff00 | and ebx, 0xffffff // ff15???????? | // 50 | push eax // ff15???????? | $sequence_3 = { 740a 66833800 7404 b001 eb02 } // n = 5, score = 400 // 740a | je 0xc // 66833800 | cmp word ptr [eax], 0 // 7404 | je 6 // b001 | mov al, 1 // eb02 | jmp 4 $sequence_4 = { 750d 8b472c a801 7406 83c804 89472c } // n = 6, score = 400 // 750d | jne 0xf // 8b472c | mov eax, dword ptr [edi + 0x2c] // a801 | test al, 1 // 7406 | je 8 // 83c804 | or eax, 4 // 89472c | mov dword ptr [edi + 0x2c], eax $sequence_5 = { 7305 83c030 eb03 83c057 8801 } // n = 5, score = 400 // 7305 | jae 7 // 83c030 | add eax, 0x30 // eb03 | jmp 5 // 83c057 | add eax, 0x57 // 8801 | mov byte ptr [ecx], al $sequence_6 = { ff15???????? 83c420 83f803 7409 } // n = 4, score = 400 // ff15???????? | // 83c420 | add esp, 0x20 // 83f803 | cmp eax, 3 // 7409 | je 0xb $sequence_7 = { 8b07 83e810 50 83c610 } // n = 4, score = 400 // 8b07 | mov eax, dword ptr [edi] // 83e810 | sub eax, 0x10 // 50 | push eax // 83c610 | add esi, 0x10 $sequence_8 = { 740f 8d4f20 51 50 ff15???????? 8b36 } // n = 6, score = 400 // 740f | je 0x11 // 8d4f20 | lea ecx, [edi + 0x20] // 51 | push ecx // 50 | push eax // ff15???????? | // 8b36 | mov esi, dword ptr [esi] $sequence_9 = { b805400080 c20c00 8b442404 83781c00 } // n = 4, score = 400 // b805400080 | mov eax, 0x80004005 // c20c00 | ret 0xc // 8b442404 | mov eax, dword ptr [esp + 4] // 83781c00 | cmp dword ptr [eax + 0x1c], 0 condition: 7 of them and filesize < 169984 }
If your designated proposal does not fit in any other category, feel free to write a free-text in the comment field below.
Please propose all changes regarding references on the Malpedia library page
Your suggestion will be reviewed before being published. Thank you for contributing!
YYYY-MM-DD
YYYY-MM
YYYY