94 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			94 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #! /bin/bash
 | |
| 
 | |
| # This script is run on the Packet.net baremetal server for CI tests.
 | |
| # This script will build the entire lab from scratch and takes 3-4 hours
 | |
| # on a Packet.net host
 | |
| # While building, the server will start a webserver on Port 80 that contains
 | |
| # the text "building". Once the test is completed, the text will be replaced
 | |
| # with "success" or "failed".
 | |
| 
 | |
| ARGS="$1"
 | |
| PACKER_ONLY=0
 | |
| VAGRANT_ONLY=0
 | |
| 
 | |
| if [ ! -z "$1" ]; then
 | |
|   case "$1" in
 | |
|     --packer-only)
 | |
|     PACKER_ONLY=1
 | |
|     ;;
 | |
|     --vagrant-only)
 | |
|     VAGRANT_ONLY=1
 | |
|     ;;
 | |
|     *)
 | |
|     echo "\"$ARGS\" is not a supported argument to this script. Quitting"
 | |
|     exit 1
 | |
|     ;;
 | |
|   esac
 | |
| fi
 | |
| 
 | |
| echo "Args: $ARGS"
 | |
| 
 | |
| if [[ "$VAGRANT_ONLY" -eq 1 ]] && [[ "$PACKER_ONLY" -eq 1 ]]; then
 | |
|   echo "Somehow this build is configured as both packer-only and vagrant-only. This means something has gone horribly wrong."
 | |
|   exit 1
 | |
| fi
 | |
| 
 | |
| # Install Virtualbox 5.2
 | |
| echo "deb http://download.virtualbox.org/virtualbox/debian xenial contrib" >> /etc/apt/sources.list
 | |
| wget -q https://www.virtualbox.org/download/oracle_vbox_2016.asc -O- | sudo apt-key add -
 | |
| apt-get update
 | |
| apt-get install -y linux-headers-"$(uname -r)" virtualbox-5.2 build-essential unzip git ufw apache2
 | |
| 
 | |
| echo "building" > /var/www/html/index.html
 | |
| 
 | |
| # Set up firewall
 | |
| ufw allow ssh
 | |
| ufw allow http
 | |
| ufw default allow outgoing
 | |
| ufw --force enable
 | |
| 
 | |
| if [ "$PACKER_ONLY" -eq 0 ]; then
 | |
|   # Install Vagrant
 | |
|   mkdir /opt/vagrant
 | |
|   cd /opt/vagrant || exit 1
 | |
|   wget https://releases.hashicorp.com/vagrant/2.1.4/vagrant_2.1.4_x86_64.deb
 | |
|   dpkg -i vagrant_2.1.4_x86_64.deb
 | |
|   vagrant plugin install vagrant-reload
 | |
| 
 | |
|   # Make the Vagrant instances headless
 | |
|   cd /opt/DetectionLab/Vagrant || exit 1
 | |
|   sed -i 's/vb.gui = true/vb.gui = false/g' Vagrantfile
 | |
| fi
 | |
| 
 | |
| if [ "$VAGRANT_ONLY" -eq 0 ]; then
 | |
|   # Install Packer
 | |
|   mkdir /opt/packer
 | |
|   cd /opt/packer || exit 1
 | |
|   wget https://releases.hashicorp.com/packer/1.2.5/packer_1.2.5_linux_amd64.zip
 | |
|   unzip packer_1.2.5_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
 | |
| fi
 | |
| 
 | |
| # Ensure the script is executable
 | |
| chmod +x /opt/DetectionLab/build.sh
 | |
| cd /opt/DetectionLab || exit 1
 | |
| 
 | |
| # Start the build in a tmux session
 | |
| sn=tmuxsession
 | |
| tmux new-session -s "$sn" -d
 | |
| if [ "$PACKER_ONLY" -eq 1 ]; then
 | |
|   tmux send-keys -t "$sn:0" './build.sh virtualbox --packer-only && echo "success" > /var/www/html/index.html || echo "failed" > /var/www/html/index.html' Enter
 | |
| fi
 | |
| if [ "$VAGRANT_ONLY" -eq 1 ]; then
 | |
|   tmux send-keys -t "$sn:0" './build.sh virtualbox --vagrant-only && echo "success" > /var/www/html/index.html || echo "failed" > /var/www/html/index.html' Enter
 | |
| fi
 | |
| if [[ "$PACKER_ONLY" -eq 0 ]] && [[ "$VAGRANT_ONLY" -eq 0 ]]; then
 | |
|   tmux send-keys -t "$sn:0" './build.sh virtualbox && echo "success" > /var/www/html/index.html || echo "failed" > /var/www/html/index.html' Enter
 | |
| fi
 | 
