ImaginaryC2 is a python tool which aims to help in the behavioral (network) analysis of malware. It hosts a HTTP server which captures HTTP requests towards selectively chosen domains/IPs.
Additionally, the tool aims to make it easy to replay captured Command-and-Control responses/served payloads.
By using this tool, an analyst can feed the malware consistent network responses. Additionally, the analyst can capture and inspect HTTP requests towards a domain/IP which is off-line at the time of the analysis.
Imaginary C2 provides two scripts to convert packet captures (PCAPs) or Fiddler Session Archives into request definitions which can be parsed by imaginary C2.
Via these scripts the user can extract HTTP request URLs and domains, as well as HTTP responses. This way, one can quickly replay HTTP responses for a given HTTP request.
Requirements: Imaginary C2 requires Python 2.7 and Windows.
Modules: Currently, Imaginary C2 contains three modules and two configuration files:
| Filename | Function |
|---|---|
| 1. imaginary_c2.py | Hosts python’s simple HTTP server. Main module. |
| 2. redirect_to_imaginary_c2.py | Alters Windows’ host file and Windows’ (IP) Routing Table. |
| 3. unpack_fiddler_archive.py & unpack_pcap.py | Extracts HTTP responses from packet captures. Adds corresponding HTTP request domains and URLs to the configuration files. |
| 4. redirect_config.txt | Contains domains and IPs which needs to be redirected to localhost (to the python HTTP server). |
| 5. requests_config.txt | Contains URL path definitions with the corresponding data sources. |
Request definitions: Each (HTTP) request defined in the request configuration consists of two parameters:
Parameter 1: HTTP request URL path (a.k.a. urlType)
| Value | Meaning |
|---|---|
| fixed | Define the URL path as a literal string |
| regex | Define a regex pattern to be matched on the URL path |
Parameter 2: HTTP response source (a.k.a. sourceType)
| Value | Meaning |
|---|---|
| data | Imaginary C2 will respond with the contents of a file on disk |
| python | Imaginary C2 will run a python script. The output of the python script defines the HTTP response. |
Journalists use OSINT to verify public information before publishing. In 2026, misinformation, AI-generated images, fake…
Docker is an open-source platform that lets you package and run applications inside containers. Each container…
PostgreSQL (often called Postgres) is an open-source relational database system. It supports advanced features like JSON…
Xrdp is an open-source server that lets you connect to your Ubuntu machine from another computer…
Apache Tomcat is an open-source web server and Java servlet container. It is one of the…
Keeping your Ubuntu system updated is one of the best ways to protect it. Security…