DNS-Persist
DNS-Persist is a post-exploitation agent which uses DNS for command and control. The server-side code is in Python and the agent is coded in C++. This is the first version, more features and improvements will be made in the future.
Architecture
There are two main parts:
- DNS server
- Agent
Features
Persistence mechanisms
This version has only 3 persistence mechanisms. More will be added later.
- LogonScript persistence.
- RunKey persistence.
- Excel Addin persistence.
‘Interactive’ command shell
This version supports pseudo-interactive command shell that you can use to execute system commands.
Shellcode Injection
This version supports injection of 32-bit shellcode. The shellcode gets executed in a new thread in the same process, so crashing shellcode or invalid one will also crash the agent. Avoid NULL bytes on the shellcode.
Shellcode generation example
Installation & Usage
Server side
pip install dnslib
git clone https://github.com/0x09AL/DNS-Persist
python server.py
By default, a DNS server on port 53 will be started. You can change that on the server.py file.
Agent
I used Visual Studio 2010 to code the agent so importing and compiling it should be fairly easy.
Keep in mind to change the DOMAIN_NAME variable in Declarations.h, to match your domain name.
The domain name servers should point to the DNS-Persist IP address.
#define DOMAIN_NAME “example.com”
Screenshots
- Picture-1
- Picture-2
- Picture-3
- Picture-4
Disclaimer
DO NOT USE THIS SOFTWARE FOR ILLEGAL PURPOSES.
THE AUTHOR DOES NOT KEEP ANY RESPONSIBILITY FOR ANY MISUSE OF THE CODE PROVIDED HERE.
Copyright (c) 2017 Rio
Source: https://github.com/0x09AL/