Skip to content

Red Team Operator: Malware Development Essentials Course

Notifications You must be signed in to change notification settings

jhackz/RTO-Implant

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

6 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

RTO-Implant

This is an overview of my RTO-Implant from the Malware Development Essentials Course by @Sektor7Net

Intro

My background is primarily in malware research and reverse engineering. This course was on sale during quarantine, so I thought it would be a good time to further my understanding of Windows internals and offensive techniques programmatically. The development of my implant was an iterative process; I was constantly making small tweaks and improvements along the way until I arrived at a stopping point that I was happy with. There are plenty of things to improve upon as well as expand the functionality of my loader / implant. If you have any thoughts or tips, I'd be more than happy to hear them!

RTO-Implant.cpp:

This is the entry point for my loader, which I view as the table of contents for the rest of the project. The majority of strings in the binary are z85 encoded, including our target process notepad.exe. The strings are decoded prior to being used by the binary. This idea came from a discussion about malicious delivery mechanisms used by the Lazarus Group.

Alt text

Resolve.cpp:

This file is responsible for dynamically resolving API's. I wanted to implement this anti-analysis technique to see what it would look like when the binary was loaded into a disassembler for static analysis. Many payloads I've reversed dynamically resolve API's including Dridex, Emotet, Qadars and many more. These payloads commonly use API hashing mechanisms to load imports and call API's during runtime. In my binary, the names of the API calls are z85 decoded before being dynamically resolved; however, not every API used in the binary is obfuscated. This is an area for potential improvement in the future. Additionally, a binary with no imports is suspicious and a binary with imports commonly used for malicious purposes will likely be under close watch. Attempting to populate the IAT with common / benign API's and dynamically resolve the ones used to achieve our goal seems to be a worthwhile balancing act.
Alt text

GetProcAddress and GetModuleHandle were resolved first to make loading the rest of the API's easier. All other API's were resolved by passing the module and API name to the ResolveAPI function below.

Alt text

FindProcess.cpp:

I believe that CreateToolhelp32Snapshot and Process32First / Process32Next is the most common method of programatically identifying running processes on a system. I chose to use NtQuerySystemInformation because of the opportunity to review Windows internals structures. The SYSTEM_PROCESS_INFOMATION struct contains an ImageName member of type UNICODE_STRING. This is useful for identifying our target process.

Alt text

CreateMapInject.cpp:

After acquiring the process ID (pid) of our target process, we can then attempt to achieve code execution in the context of the target. I wanted to stay away from VirtualAllocEx and WriteProcessMemory to avoid calling classic sequences of API's related to process injection. Thinking about how I should gain code execution in the context of the target process, a technique I read about last year came to mind. Thankfully, ired.team did most of the leg work here.

Opening IDA to view the strings present in the binary, we can see the strings used in our MessageBox shellcode, "RTO: MalDev" and "Hi from Red Team Operator!". Following where these strings are referenced in IDA leads us to our shellcode buffer. We can then identify which subroutine uses that buffer and begin analysis there. Obfuscating the shellcode buffer is another area for improvement. However, when looking at the "calls from" of this subroutine, we note there are only calls to "decode_string". This means the dynamic API resolution is working as expected.

Alt text Alt text Alt text

Conclusions

For a first iteration, I am happy with how my RTO implant turned out. The implant obtains code execution in the context of another process while implementing various obfuscation techniques. If notepad.exe is running on the system when the payload is executed, we will discover a newly created section mapped in memory with the RTO shellcode present.

Alt text Alt text Alt text

Swapping out the MessageBox payload for a custom payload that implements a second stage is another future improvement. Thanks for reading :)

About

Red Team Operator: Malware Development Essentials Course

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published