SYMBOLCOMMON_NAMEaka. SYNONYMS
win.cloud_duke (Back to overview)

CloudDuke

aka: MiniDionis, CloudLook

Actor(s): APT29

VTCollection    

F-Secure describes CloudDuke as a malware toolset known to consist of, at least, a downloader, a loader and two backdoor variants. The CloudDuke downloader will download and execute additional malware from a preconfigured location. Interestingly, that location may be either a web address or a Microsoft OneDrive account. Both CloudDuke backdoor variants support simple backdoor functionality, similar to SeaDuke. While one variant will use a preconfigured C&C server over HTTP or HTTPS, the other variant will use a Microsoft OneDrive account to exchange commands and stolen data with its operators.

References
2015-07-22F-SecureArtturi Lehtiö
Duke APT group's latest tools: cloud services and Linux support
CloudDuke
Yara Rules
[TLP:WHITE] win_cloud_duke_auto (20251219 | Detects win.cloud_duke.)
rule win_cloud_duke_auto {

    meta:
        author = "Felix Bilstein - yara-signator at cocacoding dot com"
        date = "2026-01-05"
        version = "1"
        description = "Detects win.cloud_duke."
        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.cloud_duke"
        malpedia_rule_date = "20260105"
        malpedia_hash = "19b79e7cab4eaf532122e5b45a77dd8f6bb5cc79"
        malpedia_version = "20251219"
        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 = { 8b8a88e8ffff 33c8 e8???????? 83c008 8b4af8 33c8 }
            // n = 6, score = 800
            //   8b8a88e8ffff         | mov                 ecx, dword ptr [edx - 0x1778]
            //   33c8                 | xor                 ecx, eax
            //   e8????????           |                     
            //   83c008               | add                 eax, 8
            //   8b4af8               | mov                 ecx, dword ptr [edx - 8]
            //   33c8                 | xor                 ecx, eax

        $sequence_1 = { 89442420 742b 48 89442414 6aff 6a00 57 }
            // n = 7, score = 800
            //   89442420             | mov                 dword ptr [esp + 0x20], eax
            //   742b                 | je                  0x2d
            //   48                   | dec                 eax
            //   89442414             | mov                 dword ptr [esp + 0x14], eax
            //   6aff                 | push                -1
            //   6a00                 | push                0
            //   57                   | push                edi

        $sequence_2 = { e8???????? 51 8bc8 c645fc13 e8???????? 83c404 c645fc11 }
            // n = 7, score = 800
            //   e8????????           |                     
            //   51                   | push                ecx
            //   8bc8                 | mov                 ecx, eax
            //   c645fc13             | mov                 byte ptr [ebp - 4], 0x13
            //   e8????????           |                     
            //   83c404               | add                 esp, 4
            //   c645fc11             | mov                 byte ptr [ebp - 4], 0x11

        $sequence_3 = { 897da4 6a13 6a00 68???????? 8bce e8???????? 83f8ff }
            // n = 7, score = 800
            //   897da4               | mov                 dword ptr [ebp - 0x5c], edi
            //   6a13                 | push                0x13
            //   6a00                 | push                0
            //   68????????           |                     
            //   8bce                 | mov                 ecx, esi
            //   e8????????           |                     
            //   83f8ff               | cmp                 eax, -1

        $sequence_4 = { 83e4f0 6aff 68???????? 64a100000000 50 81ec2c020000 }
            // n = 6, score = 800
            //   83e4f0               | and                 esp, 0xfffffff0
            //   6aff                 | push                -1
            //   68????????           |                     
            //   64a100000000         | mov                 eax, dword ptr fs:[0]
            //   50                   | push                eax
            //   81ec2c020000         | sub                 esp, 0x22c

        $sequence_5 = { 50 c784240c010000ffffffff e8???????? 8b842404010000 f7d0 39442428 0f8599060000 }
            // n = 7, score = 800
            //   50                   | push                eax
            //   c784240c010000ffffffff     | mov    dword ptr [esp + 0x10c], 0xffffffff
            //   e8????????           |                     
            //   8b842404010000       | mov                 eax, dword ptr [esp + 0x104]
            //   f7d0                 | not                 eax
            //   39442428             | cmp                 dword ptr [esp + 0x28], eax
            //   0f8599060000         | jne                 0x69f

        $sequence_6 = { 75f5 e9???????? 83f805 0f85b8020000 }
            // n = 4, score = 800
            //   75f5                 | jne                 0xfffffff7
            //   e9????????           |                     
            //   83f805               | cmp                 eax, 5
            //   0f85b8020000         | jne                 0x2be

        $sequence_7 = { 8bf0 e8???????? 83c414 39b42418010000 0f8572000000 6a44 }
            // n = 6, score = 800
            //   8bf0                 | mov                 esi, eax
            //   e8????????           |                     
            //   83c414               | add                 esp, 0x14
            //   39b42418010000       | cmp                 dword ptr [esp + 0x118], esi
            //   0f8572000000         | jne                 0x78
            //   6a44                 | push                0x44

        $sequence_8 = { 668906 8945fc 8b4310 8b7e10 83c007 c745f001000000 3bf8 }
            // n = 7, score = 800
            //   668906               | mov                 word ptr [esi], ax
            //   8945fc               | mov                 dword ptr [ebp - 4], eax
            //   8b4310               | mov                 eax, dword ptr [ebx + 0x10]
            //   8b7e10               | mov                 edi, dword ptr [esi + 0x10]
            //   83c007               | add                 eax, 7
            //   c745f001000000       | mov                 dword ptr [ebp - 0x10], 1
            //   3bf8                 | cmp                 edi, eax

        $sequence_9 = { 0f57c0 0f43842420010000 51 8d8c24a0010000 }
            // n = 4, score = 800
            //   0f57c0               | xorps               xmm0, xmm0
            //   0f43842420010000     | cmovae              eax, dword ptr [esp + 0x120]
            //   51                   | push                ecx
            //   8d8c24a0010000       | lea                 ecx, [esp + 0x1a0]

    condition:
        7 of them and filesize < 368640
}
[TLP:WHITE] win_cloud_duke_w0   (20170521 | Detects CloudDuke Malware)
rule win_cloud_duke_w0 {
	meta:
		description = "Detects CloudDuke Malware"
		author = "Florian Roth"
		reference = "https://www.f-secure.com/weblog/archives/00002822.html"
		date = "2015-07-22"
		score = 60
		hash = "97d8725e39d263ed21856477ed09738755134b5c0d0b9ae86ebb1cdd4cdc18b7"
		hash = "88a40d5b679bccf9641009514b3d18b09e68b609ffaf414574a6eca6536e8b8f"
		hash = "1d4ac97d43fab1d464017abb5d57a6b4601f99eaa93b01443427ef25ae5127f7"
		hash = "ed7abf93963395ce9c9cba83a864acb4ed5b6e57fd9a6153f0248b8ccc4fdb46"
		hash = "ee5eb9d57c3611e91a27bb1fc2d0aaa6bbfa6c69ab16e65e7123c7c49d46f145"
		hash = "a713982d04d2048a575912a5fc37c93091619becd5b21e96f049890435940004"
		hash = "56ac764b81eb216ebed5a5ad38e703805ba3e1ca7d63501ba60a1fb52c7ebb6e"
        malpedia_reference = "https://malpedia.caad.fkie.fraunhofer.de/details/win.cloud_duke"
        malpedia_version = "20170521"
        malpedia_license = "CC BY-NC-SA 4.0"
        malpedia_sharing = "TLP:WHITE"
	strings:
		$s1 = "ProcDataWrap" fullword ascii
		$s2 = "imagehlp.dll" fullword ascii
		$s3 = "dnlibsh" fullword ascii
		$s4 = "%ws_out%ws" fullword wide
		$s5 = "Akernel32.dll" fullword wide

		$op0 = { 0f b6 80 68 0e 41 00 0b c8 c1 e1 08 0f b6 c2 8b } /* Opcode */
		$op1 = { 8b ce e8 f8 01 00 00 85 c0 74 41 83 7d f8 00 0f } /* Opcode */
		$op2 = { e8 2f a2 ff ff 83 20 00 83 c8 ff 5f 5e 5d c3 55 } /* Opcode */
	condition:
		filesize < 720KB and 4 of ($s*) and 1 of ($op*)
}
Download all Yara Rules