Cuckoo comes with an automation shell script that installs Cuckoo, VMCloak, and related dependencies with predefined configuration — the Quickstart.
This configuration has been tested and is known to work for general use or experimentation for regular users. For more fine-tuned installation, please refer to Installing Cuckoo3.
This is a semi-guided installation and will ask for user name and password for Cuckoo installation (Cuckoo will be run as non-root-user) and Python-related prompts if the current Python version does not meet the requirements.
-
System dependencies
-
Cuckoo will be installed with a custom configuration
-
VMCloak will be installed for VM and snapshot creation
-
Qemu will be installed for VMCloak to use
-
Windows 10 will be downloaded for sandboxing
-
Standard Nginx configuration will be created for hosting Cuckoo web.
For the Quickstart setup, run:
curl -sSf https://cuckoo-hatch.cert.ee/static/install/quickstart | sudo bash
The install script does a few checks to make sure that it is run with the correct user at different steps and that Python requirements are met.
- It checks if the script is run with sudo privileges. Some setup parts like installing system dependencies, creating Cuckoo users, and installing Python-related dependencies or repositories.
- Checks if you are running the supported Ubuntu 22.04 release.
If y
is selected, then:
-
The script creates a new non-privileged user to run Cuckoo.
-
It asks for a username and password to create it.
!!! note "Remember!" Please don't forget the credentials. You need them later to use Cuckoo.
If n
is selected, then:
- The script asks for the username and password for the previously created user. NOTE! Make sure the user does not have sudo privileges.
If y
is selected, then:
- This script will download the Windows 10 image form cert-ee.
- Install software on it.
- Make snapshots.
The script uses "templates", which are basically helper functions, to initiate commands under the created Cuckoo user.
- install_vmcloak_with - installs VMCloak for VM creation in Cuckoo users home directory. It also creates VMCloak-specific .vmcloak directory in users home for vm creation later on.
- install_cuckoo_with - installs Cuckoo in Cuckoo users home directory. It also creates .cuckoocwd directory in users home for Cuckoo-related configurations later on.
- configure_cuckoo_for - Unpacks monitor and signatures to
cuckoocwd
. It also builds documentation, performs Django'scollectstatic
command, and generates uwsgi and nginx configurations into users cuckoo3 directory. - download_images_for - Downloads Windows 10 image from cert-ee.
- create_vms_for - This command creates an iso image for Windows 10 with agent, installs software on it, and creates 3 snapshots.
- configure_vms_for - Imports VMs to Cuckoo and deletes the example machine. It also runs database migrations.
- run_cuckoo_for - This allows bash to run Cuckoo user specific commands.
Quickstart installs the following dependencies for:
- building Python packages
- build-essential
- software-properties-common
- unpacking monitor and signatuers
- unzip
- hyperscan
- libhyperscan5
- libhyperscan-dev
- Sflock
- libjpeg8-dev
- zlib1g-dev
- p7zip-full
- rar
- unace-nonfree
- cabextract
- Yara
- yara
- Tcpdump
- tcpdump
- Python dependencies
- libssl-dev libcapstone-dev
- VM creation with VMCloak
- genisoimage
- qemu-system-common
- qemu-utils
- qemu-system-x86
- serving Cuckoo frontend
-uwsgi
- uwsgi-plugin-python3
- nginx
- Python3
- python3.10
- python3.10-venv
- python3.10-dev - required for python C headers
Quickstart will:
-
clone git repo from
https://github.com/cert-ee/vmcloak.git
and checkoutmain
branch -
pip installs dependencies
-
create a new network bridge interface named
br0
with subnet192.168.30.1/24
-
create a new conf file in
/etc/qemu/bridge.conf
with contentallow br0
-
set setuid bit for
/usr/lib/qemu/qemu-bridge-helper
-
download Windows 10 image from CERT-EE repository to
/home/cuckoo/
aswin10x64.iso
-
create a mount at
/mnt/win10x64
-
create a Windows 10 image with settings
Parameter Value Disk 128GB CPU 2 RAM 4096 Subnet 192.168.30.0/24 Virtual Machinery qemu Remote Display (RDP/VNC) true Remote Display port 1 (offset 5900) Guest IP address 192.168.30.2 Mount point /mnt/win10x64
VM name win10base Network adapter br0 -
install default software and configuration to Windows 10
-
make 3 snapshots with IP address starting from
192.168.30.10
-
delete default Cuckoo VM qemu profile
-
import created VMs to Cuckoo.
User will be added to kvm and pcap groups. First is to be able to create VMs with Qemu and second is to use tcpdump Quickstart will also disable tcpdump apparmor profile.
For Cuckoo frontend to work, Quickstart needs to change some configuration values:
- it will add a new subnet 192.168.68.0/24 to allowed subnets
- add STATIC_ROOT location
- make directories for STATIC_ROOT and change ownership to Cuckoo user
- add user to www-data group
- remove uwsgi configuration if it exists and deliver a new configuration to
/etc/uwsgi/apps-available/
- symlinks uwsgi to
apps-enabled
- does the same for nginx
- changes nginx listen port 8080
- restarts
uwsgi
andnginx
services - creates helper script in the home of user who ran the script. It helps bring up network interface and mount iso.
sudo ~/.helper_script.sh
.
Last step Quickstart takes in run cuckoo --debug
which runs cuckoo in debug mode