68 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
			
		
		
	
	
			68 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
| #! /bin/bash
 | |
| 
 | |
| # This script is used to manually prepare an Ubuntu 16.04 server for DetectionLab building
 | |
| 
 | |
| # Put this code in bootstrap.sh
 | |
| # echo -e "    eth1:\n      dhcp4: true\n      nameservers:\n        addresses: [8.8.8.8,8.8.4.4]" >> /etc/netplan/01-netcfg.yaml
 | |
| # netplan apply
 | |
| # sed -i 's/nameserver 127.0.0.53/nameserver 8.8.8.8/g' /etc/resolv.conf && chattr +i /etc/resolv.conf
 | |
| 
 | |
| 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
 | |
| 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-15.5.2-15785246.x86_64.bundle "https://download3.vmware.com/software/wkst/file/VMware-Workstation-Full-15.5.2-15785246.x86_64.bundle"
 | |
| chmod +x VMware-Workstation-Full-15.5.2-15785246.x86_64.bundle
 | |
| sudo sh VMware-Workstation-Full-15.5.2-15785246.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.7/vagrant_2.2.7_x86_64.deb
 | |
| dpkg -i vagrant_2.2.7_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.7/vagrant-vmware-utility_1.0.7_x86_64.deb"
 | |
| dpkg -i vagrant-vmware-utility_1.0.7_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
 | |
| 
 | |
| # Install Packer
 | |
| mkdir /opt/packer
 | |
| cd /opt/packer || exit 1
 | |
| wget --progress=bar:force https://releases.hashicorp.com/packer/1.4.1/packer_1.4.1_linux_amd64.zip
 | |
| unzip packer_1.4.1_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
 | |
| 
 | |
| # Ensure the script is executable
 | |
| chmod +x /opt/DetectionLab/build.sh
 | |
| cd /opt/DetectionLab || exit 1
 | 
