CAPE: Malware Configuration And Payload Extraction - Documentation
It was derived from Cuckoo with the goal of adding automated malware unpacking and config extraction - hence its name is an acronym: 'Config And Payload Extraction'. Automated unpacking allows classification based on Yara signatures to complement network (Suricata) and behavior (API) signatures.
There is a free community instance online that anyone can use:
https://capesandbox.com - For account activation reach to https://twitter.com/capesandbox.
Although config and payload extraction was the original stated goal, it was the development of the debugger in CAPE that first inspired the project: in order to extract configs or unpacked payloads from arbitrary malware families without relying on process dumps (which sooner or later the bad guys will thwart), instruction-level monitoring and control is necessary. The novel debugger in CAPE follows the principle of maximising the use of processor hardware and minimising (almost completely) the use of Windows debugging interfaces, allowing malware to be stealthily instrumented and manipulated from the entry point with hardware breakpoints programmatically set during detonation by Yara signatures or API calls. This allows instruction traces to be captured, or actions to be performed such as control flow manipulation or dumping of a memory region.
There is a community repository of signatures containing several hundred signatures developed by the CAPE community. All new community feature should be pushed to that repo. Later it can be moved to core if devs consider that an interesting extension.
Can be done using either of CAPE's, RATDecoders, DC3-MWCP or MalDuck framework.
- Special thanks to:
- Jason Reaves (@sysopfb) for the TrickBot parser and Fabien Perigaud for the PlugX parser.
- Due to the nature of malware, since it changes constantly when any new version is released, something might become broken!
- We suggest using only pure Python with entry point
def config(data):
that will be called bycape_utils.py
and 0 complications.- As a bonus, you can reuse your extractors in other projects.
Updates summary changelog
The debugger has allowed CAPE to continue to evolve beyond its original capabilities, which now include dynamic anti-evasion bypasses. Since modern malware commonly tries to evade analysis within sandboxes, for example by using timing traps for virtualisation or API hook detection, CAPE allows dynamic countermeasures to be developed combining debugger actions within Yara signatures to detect evasive malware as it detonates, and perform control-flow manipulation to force the sample to detonate fully or skip evasive actions. The list of dynamic bypasses in CAPE is growing but includes:
- Guloader
- Ursnif
- Dridex
- Zloader
- Formbook
- BuerLoader
- Pafish
CAPE takes advantage of many malware techniques or behaviours to allow for unpacked payload capture:
- Process injection
- Shellcode injection
- DLL injection
- Process Hollowing
- Process Doppelganging
- Decompression of executable modules in memory
- Extraction of executable modules or shellcode in memory
These behaviours will result in the capture of payloads being injected, extracted, or decompressed for further analysis. In addition CAPE automatically creates a process dump for each process, or, in the case of a DLL, the DLL's module image in memory. This is useful for samples packed with simple packers, where often the module image dump is fully unpacked.
Quick access to the debugger is made possible with the breakpoint options 'bp0' through 'bp3' accepting RVA or VA values to set breakpoints, whereupon a short instruction trace will be output, governed by 'count' and 'depth' options (e.g. bp0=0x1234,depth=1,count=100). To set a breakpoint at the module entry point, 'ep' is used instead of an address (e.g. bp0=ep). Alternatively 'break-on-return' allows for a breakpoint on the return address of a hooked API (e.g. break-on-return=NtGetContextThread). An optional 'base-on-api' parameter allows the image base for RVA breakpoints to be set by API call (e.g. base-on-api=NtReadFile,bp0=0x2345).
Options 'action0' - 'action3' allow actions to be performed when breakpoints are hit, such as dumping memory regions (e.g. action0=dumpebx) or changing the execution control flow (e.g. action1=skip). CAPE's documentation contains further examples of such actions.
'dump-on-api' allows a module to be dumped when it calls a specific API function that can be specified in the web interface which can be useful for quickly unpacking/dumping novel samples (e.g. dump-on-api=DnsQuery_A).
CAPE also has an option 'upx=1' which can dynamically unpack samples that use 'hacked' (modified) UPX, very popular with malware authors. These samples are run in CAPE's debugger until their OEP (original entry point), whereupon they are dumped, fixed and their imports are automatically reconstructed, ready for analysis.
CAPE is constantly growing in malware family coverage, but has config parsers for the following examples:
- Emotet
- TrickBot
- QakBot
- Hancitor
- Ursnif
- Dridex
- SmokeLoader
- IcedID
- RedLeaf
- ChChes
- HttpBrowser
- Enfal
- PoisonIvy
- Screech
- TSCookie
CAPE uses Yara signatures as its principal classification method to detect unpacked payloads. This list is constantly growing and includes:
- Azorult, Formbook, Ryuk, Hermes, Shade, Remcos, Ramnit, Gootkit, QtBot, ZeroT, WanaCry, NetTraveler, Locky, BadRabbit, Magniber, Redsip, Kronos, PetrWrap, Kovter, Azer, Petya, Dreambot, Atlas, NanoLocker, Mole, Codoso, Cryptoshield, Loki, Jaff, IcedID, Scarab, Cutlet, RokRat, OlympicDestroyer, Gandcrab, Fareit, ZeusPanda, AgentTesla, Imminent, Arkei, Sorgu, tRat, T5000, TClient, TreasureHunter.
The repository containing the code for the monitor DLLs is a distinct one.
Please contribute to this project by helping create new signatures, parsers, or bypasses for further malware families. There are many in the works currently, so watch this space.
A huge thank you to @D00m3dR4v3n for single-handedly porting CAPE to Python 3.
- Python3
- agent.py is tested with python (3.7.2|3.8) x86. You should use x86 python version inside of the VM!
- host tested with python3 version 3.7, 3.8, 3.10, but newer versions should work too
- Only rooter should be executed as root, the rest as cape user. Running as root will mess with permissions.
- Become familiar with the documentation and do read ALL config files inside of
conf
folder! - For best compabitility we strongly suggest installing on Ubuntu 22.04 LTS
kvm-qemu.sh
andcape2.sh
SHOULD BE executed fromtmux
session to prevent any OS problems ifssh
connections breaks.- KVM is recommended as the hypervisor.
- Replace
<username>
with a real pattern. - You need to replace all
<WOOT>
inside! - Read it! You must understand what it does! It has configuration in header of the script.
sudo ./kvm-qemu.sh all <username> | tee kvm-qemu.log
- To install CAPE itself, cape2.sh with all optimizations
- Read and understand what it does! This is not a silver bullet for all your problems! It has configuration in header of the script.
sudo ./cape2.sh base | tee cape.log
- After installing everything save both installation logs as gold!
- Configure CAPE by doing mods to config files inside
conf
folder. - Restart all CAPE services to pick config changes and run CAPE properly!
- CAPE Services
- cape.service
- cape-processor.service
- cape-web.service
- cape-rooter.service
- To restart any service use
systemctl restart <service_name>
- To see service log use
journalctl -u <service_name>
- To debug any problem, stop the relevant service and run the command that runs that service by hand to see more logs. Check
-h
for the help menu. Running the service in debug mode (-d
) can help as well.
- CAPE Services
- Reboot and enjoy!
- All scripts contain help
-h
, but please check the scripts to understand what they are doing.
- CAPE:
git pull
- community:
python3 utils/community.py -waf
see-h
before to ensure you understand
git add --all
git commit -m '[STASH]'
git pull --rebase origin master
# fix conflict (rebase) if needed
git reset HEAD~1
# make sure kevoreilly repo has been added as a remote (only needs to be done once)
git remote add kevoreilly https://github.com/kevoreilly/CAPEv2.git
# make sure all your changes are commited on the branch which you will be merging
git commit -a -m '<your commit message goes here>'
# fetch changes from kevoreilly repo
git fetch kevoreilly
# merge kevoreilly master branch into your current branch
git merge kevoreilly/master
# fix merge conflicts if needed
# push to your repo if desired
git push
If you use CAPEv2 in your work, please cite it as specified in the "Cite this repository" GitHub menu.
- They becoming a headache, specially those that using
pefile
as each pins version that they want.- Our suggestion is clone/fork them, remove
pefile
dependency as you already have it installed. Volia no more pain.
- Our suggestion is clone/fork them, remove