We delve into the intricate workings of the Kimsuky PowerShell Backdoor, a sophisticated cyber espionage tool attributed to the notorious Kimsuky hacking group.
We provide a detailed examination of its command and control (C2) operations, shedding light on the backdoor’s capabilities to manipulate, exfiltrate, and manage files and processes on compromised systems.
Through an analysis of its operational commands, we unravel the mechanisms that enable this backdoor to maintain stealth and efficiency in conducting cyber espionage activities.
public enum _OP_CODE : ushort
{
OP_UNIQ_ID = 0x401, #Check-In Unique ID - Sent with first packet from Client
OP_REQ_DRIVE_LIST = 0x402, # Request from Server for logical drive info
OP_RES_DRIVE_LIST = 0x403, # Response from client with logical drive info
OP_REQ_PATH_LIST = 0x404, # Request from Server for list of dir & files from path
OP_RES_PATH_LIST = 0x405, # Response from client with list of dir, files from path
OP_REQ_PATH_DOWNLOAD = 0x406, # Request from server to exfiltrate file/dir to the C2 - arg: file/dir_path;c2_url
OP_RES_PATH_DOWNLOAD = 0x407, # Response from client once the file/dir (ZIP + b64 encoded) is exfiltrated to C2
OP_REQ_PATH_DELETE = 0x408, # Request from server to delete dir/file - arg:path
OP_RES_PATH_DELETE = 0x409, # Response from client after deleting dir/file
OP_REQ_FILE_UPLOAD = 0x40A, # Request from server to upload file on the machine
OP_RES_FILE_UPLOAD = 0x40B, # Response from client once the uploaded file is written on the machine
OP_REQ_PATH_RENAME = 0x40C, # Request from server to rename file/folder - arg:oldfilename,newfilename
OP_RES_PATH_RENAME = 0x40D, # Response from client after renaming file/folder
OP_REQ_CREATE_DIR = 0x40E, # Request from server to create directory - arg: path - add (2) if already created
OP_RES_CREATE_DIR = 0x40F, # Response from server after creating directory
OP_REQ_RESTART = 0x410, # Restart connection
OP_REQ_CLOSE = 0x411, # Close connection
OP_REQ_REMOVE = 0x412, # Close connection
OP_RES_DRIVE_ERROR = 0x413, # Sent from client: no drives found / no permissions / io error
OP_REQ_EXECUTE = 0x414, # Request from Server to execute file/command - arg:path
OP_RES_EXECUTE = 0x415, # Response from client after executing the file/command via IEX - uses OP_REQ_EXECUTE
OP_REQ_CREATE_ZIP = 0x416, # Request from server to ZIP archive files/directory arg: path
OP_RES_CREATE_ZIP = 0x417 # Response from server after ZIP archiving the files/directory - uses OP_REQ_CREATE_ZIP
}
Sends across following logical drive information to the server –
Sends across following file & directory information to the server –
Exfiltrate the files/directory to the C2 server via a POST Request.
- filename = ToBase64String(filename) | filename: file to be exfiltrated
- Data: ToBase64String(file_contents) ; File contents of file to be exfiltrated
shadow-rs is a Windows kernel rootkit written in Rust, demonstrating advanced techniques for kernel manipulation…
Extract and execute a PE embedded within a PNG file using an LNK file. The…
Embark on the journey of becoming a certified Red Team professional with our definitive guide.…
This repository contains proof of concept exploits for CVE-2024-5836 and CVE-2024-6778, which are vulnerabilities within…
This took me like 4 days (+2 days for an update), but I got it…
MaLDAPtive is a framework for LDAP SearchFilter parsing, obfuscation, deobfuscation and detection. Its foundation is…