#! /usr/bin/env bash # This script is used to manually prepare an Ubuntu 16.04 server for DetectionLab building export DEBIAN_FRONTEND=noninteractive export SERIALNUMBER="SECRET" export LICENSEFILE="SECRET" sed -i 's#http://archive.ubuntu.com#http://us.archive.ubuntu.com#g' /etc/apt/sources.list # Install VMWare Workstation 15 apt-get update apt-get install -y linux-headers-"$(uname -r)" build-essential unzip git ufw apache2 python-pip ubuntu-desktop python-pip libxtst6 pip install awscli --upgrade --user cp /root/.local/bin/aws /usr/local/bin/aws && chmod +x /usr/local/bin/aws wget -O VMware-Workstation-Full-16.1.1-17801498.x86_64.bundle "https://download3.vmware.com/software/wkst/file/VMware-Workstation-Full-16.1.1-17801498.x86_64.bundle" chmod +x VMware-Workstation-Full-16.1.1-17801498.x86_64.bundle sudo sh VMware-Workstation-Full-16.1.1-17801498.x86_64.bundle --console --required --eulas-agreed --set-setting vmware-workstation serialNumber $SERIALNUMBER # Set up firewall ufw allow ssh ufw default allow outgoing ufw --force enable git clone https://github.com/clong/DetectionLab.git /opt/DetectionLab # Install Vagrant mkdir /opt/vagrant cd /opt/vagrant || exit 1 wget --progress=bar:force https://releases.hashicorp.com/vagrant/2.2.16/vagrant_2.2.16_x86_64.deb dpkg -i vagrant_2.2.16_x86_64.deb # Disable IPv6 - may help with the vagrant-reload plugin: https://github.com/hashicorp/vagrant/issues/8795#issuecomment-468945063 echo "net.ipv6.conf.all.disable_ipv6=1" >> /etc/sysctl.conf sysctl -p /etc/sysctl.conf > /dev/null vagrant plugin install vagrant-reload vagrant plugin install vagrant-vmware-desktop echo $LICENSEFILE | base64 -d > /tmp/license.lic vagrant plugin license vagrant-vmware-desktop /tmp/license.lic wget --progress=bar:force "https://releases.hashicorp.com/vagrant-vmware-utility/1.0.20/vagrant-vmware-utility_1.0.20_x86_64.deb" dpkg -i vagrant-vmware-utility_1.0.20_x86_64.deb # Make the Vagrant instances headless cd /opt/DetectionLab/Vagrant || exit 1 sed -i 's/v.gui = true/v.gui = false/g' Vagrantfile cd /opt/DetectionLab/Vagrant/Exchange || exit 1 sed -i 's/v.gui = true/v.gui = false/g' Vagrantfile cd /opt/DetectionLab/Vagrant || exit 1 # Install Packer mkdir /opt/packer cd /opt/packer || exit 1 wget --progress=bar:force https://releases.hashicorp.com/packer/1.6.6/packer_1.6.6_linux_amd64.zip unzip packer_1.6.6_linux_amd64.zip cp packer /usr/local/bin/packer # Make the Packer images headless cd /opt/DetectionLab/Packer || exit 1 for file in *.json; do sed -i 's/"headless": false,/"headless": true,/g' "$file"; done echo '# This file is automatically generated. # Hand-editing this file is not recommended. network0.name = "Bridged" network0.device = "vmnet0" network1.name = "HostOnly" network1.device = "vmnet1" network2.name = "NAT" network2.device = "vmnet8"' > /etc/vmware/netmap.conf