Kali ISO of DOOM + autossh & stunnel + Kali C2 Server = KaliVirtualDropbox
Create a Kali virtual dropbox appliance (ISO) for use during remote Vulnerability Assessments and Penetration tests that auto installs without any user interaction, and calls home to your C2 server using unique shared secrets.
The most common use case is to run this script on an engagement specific Kali instance (the C2 host). However, the script can be run on another host. In that case, this script creates another bash script (c2_setup.sh) that you need to transfer to and execute on your C2 host.
-
Stand up an engagement specific Kali instance/VM (C2 host)
-
Open up 443/tcp to your C2 host from the outside
-
Clone and execute the script on the C2 host
cd /opt sudo git clone https://github.com/TUVOpenSky-THREATS/KaliVirtualDropbox cd KaliVirtualDropbox sudo ./create_ISO_configure_C2.sh
This script will pull the public IP for the server and use that. If you want to manually specify the C2 IP, provide the IP as the first parameter:
sudo ./create_ISO_configure_C2.sh C2_IP_ADDRESS
-
Transfer the ISO to your remote contact
- The ISO will be in /opt/build/images
- You can use simple-https-server or whatever you want to serve the file. If using simple-https server, make sure to host the private keys outside your temporary web root ;)
-
Your remote contact installs the ISO in a VM, bootable USB, or on hardware
-
On the C2 host, SSH to your dropbox with the randomly generated password provided by the script OR the ssh key located in /root/~.ssh/dropbox.key
ssh root@localhost -p9999 <then enter password> or, sudo ssh root@localhost -p9999 -i /root/.ssh/dropbox.key
-
Configure Nessus or anything else you want on the box
-
Stunnel Configuration
- Creates a new ssl key for stunnel (/etc/stunnel/stunnel.pem)
- Creates a config file for stunnel (/etc/stunnel/stunnel.conf)
- Starts stunnel (listens 443/tcp and redirects to 22/tcp locally)
-
SSH/User Configuration
- Creates a user (autossh)
- Creates ssh keypair for the autossh user
- Adds public key to authorized_keys for autossh
- Private key is copied to ISO and is used by the Dropbox to connect to the C2
- While the dropbox can establish a tunnel with the C2, it can not execute commands on C2
-
Dropbox Custom ISO Creation
- Grabs public IP of C2 host
- Creates a random password for Dropbox
- Installs ISO creation toolkit (live-build, etc.)
- Downloads live-build config from kali.org
- Copies unique, newly created ssh keypair to ISO
- Creates remote callback script on ISO that calls back to public IP of C2
- Adds script to cron on ISO
- Configures ISO to auto install
- Configures sshd config on ISO
- Enables services on ISO
- Asks you if you want to copy a Nessus binary to ISO (optional)
- Builds ISO