Browse Source

Update haos-vm-v4.sh

tteckster 2 years ago
parent
commit
2b41ad24ea
1 changed files with 6 additions and 29 deletions
  1. 6 29
      vm/haos-vm-v4.sh

+ 6 - 29
vm/haos-vm-v4.sh

@@ -23,7 +23,6 @@ shopt -s expand_aliases
 alias die='EXIT=$? LINE=$LINENO error_exit'
 alias die='EXIT=$? LINE=$LINENO error_exit'
 trap die ERR
 trap die ERR
 trap cleanup EXIT
 trap cleanup EXIT
-
 function error_exit() {
 function error_exit() {
   trap - ERR
   trap - ERR
   local reason="Unknown failure occurred."
   local reason="Unknown failure occurred."
@@ -33,7 +32,6 @@ function error_exit() {
   [ ! -z ${VMID-} ] && cleanup_vmid
   [ ! -z ${VMID-} ] && cleanup_vmid
   exit $EXIT
   exit $EXIT
 }
 }
-
 function cleanup_vmid() {
 function cleanup_vmid() {
   if $(qm status $VMID &>/dev/null); then
   if $(qm status $VMID &>/dev/null); then
     if [ "$(qm status $VMID | awk '{print $2}')" == "running" ]; then
     if [ "$(qm status $VMID | awk '{print $2}')" == "running" ]; then
@@ -42,22 +40,18 @@ function cleanup_vmid() {
     qm destroy $VMID
     qm destroy $VMID
   fi
   fi
 }
 }
-
 function cleanup() {
 function cleanup() {
   popd >/dev/null
   popd >/dev/null
   rm -rf $TEMP_DIR
   rm -rf $TEMP_DIR
 }
 }
-
 TEMP_DIR=$(mktemp -d)
 TEMP_DIR=$(mktemp -d)
 pushd $TEMP_DIR >/dev/null
 pushd $TEMP_DIR >/dev/null
-    
 if [[ "$PVE" != "1" ]]; then
 if [[ "$PVE" != "1" ]]; then
-    echo -e "${RD}This script requires Proxmox Virtual Environment 7.0 or greater${CL}"
-    echo -e "Exiting..."
-    sleep 2
-    exit
+  echo -e "${RD}This script requires Proxmox Virtual Environment 7.0 or greater${CL}"
+  echo -e "Exiting..."
+  sleep 2
+  exit
 fi
 fi
-
 if (whiptail --title "HOME ASSISTANT OS VM" --yesno "This will create a New Home Assistant OS VM. Proceed?" 10 58); then
 if (whiptail --title "HOME ASSISTANT OS VM" --yesno "This will create a New Home Assistant OS VM. Proceed?" 10 58); then
     echo "User selected Yes"
     echo "User selected Yes"
 else
 else
@@ -75,12 +69,10 @@ echo -e "${BL}
        |_|  |_/_/ ${CL}${YW}v4${CL}${BL} \_\____/|_____/ 
        |_|  |_/_/ ${CL}${YW}v4${CL}${BL} \_\____/|_____/ 
 ${CL}"
 ${CL}"
 }
 }
-
 function msg_info() {
 function msg_info() {
     local msg="$1"
     local msg="$1"
     echo -ne " ${HOLD} ${YW}${msg}..."
     echo -ne " ${HOLD} ${YW}${msg}..."
 }
 }
-
 function msg_ok() {
 function msg_ok() {
     local msg="$1"
     local msg="$1"
     echo -e "${BFR} ${CM} ${GN}${msg}${CL}"
     echo -e "${BFR} ${CM} ${GN}${msg}${CL}"
@@ -91,7 +83,7 @@ function default_settings() {
 	echo -e "${DGN}Using Virtual Machine ID: ${BGN}$NEXTID${CL}"
 	echo -e "${DGN}Using Virtual Machine ID: ${BGN}$NEXTID${CL}"
 	VMID=$NEXTID
 	VMID=$NEXTID
 	echo -e "${DGN}Using Hostname: ${BGN}haos${STABLE}${CL}"
 	echo -e "${DGN}Using Hostname: ${BGN}haos${STABLE}${CL}"
-	VM_NAME=haos${STABLE}
+	HN=haos${STABLE}
 	echo -e "${DGN}Allocated Cores: ${BGN}2${CL}"
 	echo -e "${DGN}Allocated Cores: ${BGN}2${CL}"
 	CORE_COUNT="2"
 	CORE_COUNT="2"
  	echo -e "${DGN}Allocated RAM: ${BGN}4096${CL}"
  	echo -e "${DGN}Allocated RAM: ${BGN}4096${CL}"
@@ -104,7 +96,7 @@ function default_settings() {
 	VLAN=""
 	VLAN=""
 	echo -e "${DGN}Start VM when completed ${BGN}yes${CL}"
 	echo -e "${DGN}Start VM when completed ${BGN}yes${CL}"
 	START_VM="yes"
 	START_VM="yes"
-
+	echo -e "${BL}Creating a HAOS VM using the above default settings${CL}"
 }
 }
 function advanced_settings() {
 function advanced_settings() {
 BRANCH=$(whiptail --title "HAOS VERSION" --radiolist "Choose Version" 10 58 2 \
 BRANCH=$(whiptail --title "HAOS VERSION" --radiolist "Choose Version" 10 58 2 \
@@ -117,7 +109,6 @@ if [ $exitstatus = 0 ]; then
 else
 else
     exit
     exit
 fi
 fi
-
 VMID=$(whiptail --inputbox "Set Virtual Machine ID" 8 58 $NEXTID --title "VIRTUAL MACHINE ID" 3>&1 1>&2 2>&3)
 VMID=$(whiptail --inputbox "Set Virtual Machine ID" 8 58 $NEXTID --title "VIRTUAL MACHINE ID" 3>&1 1>&2 2>&3)
 exitstatus=$?
 exitstatus=$?
 if [ $exitstatus = 0 ]; then
 if [ $exitstatus = 0 ]; then
@@ -125,7 +116,6 @@ if [ $exitstatus = 0 ]; then
 else
 else
     exit
     exit
 fi
 fi
-
 VM_NAME=$(whiptail --inputbox "Set Hostname" 8 58 haos${STABLE} --title "HOSTNAME" 3>&1 1>&2 2>&3)
 VM_NAME=$(whiptail --inputbox "Set Hostname" 8 58 haos${STABLE} --title "HOSTNAME" 3>&1 1>&2 2>&3)
 exitstatus=$?
 exitstatus=$?
 if [ $exitstatus = 0 ]; then
 if [ $exitstatus = 0 ]; then
@@ -134,7 +124,6 @@ if [ $exitstatus = 0 ]; then
 else
 else
     exit
     exit
 fi
 fi
-
 CORE_COUNT=$(whiptail --inputbox "Allocate CPU Cores" 8 58 2 --title "CORE COUNT" 3>&1 1>&2 2>&3)
 CORE_COUNT=$(whiptail --inputbox "Allocate CPU Cores" 8 58 2 --title "CORE COUNT" 3>&1 1>&2 2>&3)
 exitstatus=$?
 exitstatus=$?
 if [ $exitstatus = 0 ]; then
 if [ $exitstatus = 0 ]; then
@@ -142,7 +131,6 @@ if [ $exitstatus = 0 ]; then
 else
 else
     exit
     exit
 fi
 fi
-
 RAM_SIZE=$(whiptail --inputbox "Allocate RAM in MiB" 8 58 4096 --title "RAM" 3>&1 1>&2 2>&3)
 RAM_SIZE=$(whiptail --inputbox "Allocate RAM in MiB" 8 58 4096 --title "RAM" 3>&1 1>&2 2>&3)
 exitstatus=$?
 exitstatus=$?
 if [ $exitstatus = 0 ]; then
 if [ $exitstatus = 0 ]; then
@@ -150,7 +138,6 @@ if [ $exitstatus = 0 ]; then
 else
 else
     exit
     exit
 fi
 fi
-
 BRG=$(whiptail --inputbox "Set a Bridge" 8 58 vmbr0 --title "BRIDGE" 3>&1 1>&2 2>&3)
 BRG=$(whiptail --inputbox "Set a Bridge" 8 58 vmbr0 --title "BRIDGE" 3>&1 1>&2 2>&3)
 exitstatus=$?
 exitstatus=$?
 if [ $exitstatus = 0 ]; then
 if [ $exitstatus = 0 ]; then
@@ -158,7 +145,6 @@ if [ $exitstatus = 0 ]; then
 else
 else
     exit
     exit
 fi
 fi
-
 MAC1=$(whiptail --inputbox "Set a MAC Address" 8 58 $GEN_MAC --title "MAC ADDRESS" 3>&1 1>&2 2>&3)
 MAC1=$(whiptail --inputbox "Set a MAC Address" 8 58 $GEN_MAC --title "MAC ADDRESS" 3>&1 1>&2 2>&3)
 exitstatus=$?
 exitstatus=$?
 if [ $exitstatus = 0 ]; then
 if [ $exitstatus = 0 ]; then
@@ -167,7 +153,6 @@ if [ $exitstatus = 0 ]; then
 else
 else
     exit
     exit
 fi
 fi
-
 VLAN1=$(whiptail --inputbox "Set a Vlan(leave blank for default)" 8 58  --title "VLAN" 3>&1 1>&2 2>&3)
 VLAN1=$(whiptail --inputbox "Set a Vlan(leave blank for default)" 8 58  --title "VLAN" 3>&1 1>&2 2>&3)
 exitstatus=$?
 exitstatus=$?
 if [ $exitstatus = 0 ]; then
 if [ $exitstatus = 0 ]; then
@@ -178,7 +163,6 @@ else
     echo -e "${DGN}Using Vlan: ${BGN}$VLAN1${CL}"
     echo -e "${DGN}Using Vlan: ${BGN}$VLAN1${CL}"
   fi  
   fi  
 fi
 fi
-
 if (whiptail --title "START VIRTUAL MACHINE" --yesno "Start VM when completed?" 10 58); then
 if (whiptail --title "START VIRTUAL MACHINE" --yesno "Start VM when completed?" 10 58); then
     echo -e "${DGN}Starting VM when completed${CL}"
     echo -e "${DGN}Starting VM when completed${CL}"
     START_VM="yes"
     START_VM="yes"
@@ -194,7 +178,6 @@ else
     advanced_settings
     advanced_settings
 fi
 fi
 }
 }
-
 function start_script() {
 function start_script() {
 if (whiptail --title "SETTINGS" --yesno "Use Default Settings?" 10 58); then
 if (whiptail --title "SETTINGS" --yesno "Use Default Settings?" 10 58); then
   clear
   clear
@@ -208,9 +191,7 @@ else
   advanced_settings
   advanced_settings
 fi
 fi
 }
 }
-
 start_script
 start_script
-
 while read -r line; do
 while read -r line; do
   TAG=$(echo $line | awk '{print $1}')
   TAG=$(echo $line | awk '{print $1}')
   TYPE=$(echo $line | awk '{printf "%-10s", $2}')
   TYPE=$(echo $line | awk '{printf "%-10s", $2}')
@@ -254,14 +235,12 @@ case $STORAGE_TYPE in
     DISK_REF="$VMID/"
     DISK_REF="$VMID/"
     DISK_IMPORT="-format qcow2"
     DISK_IMPORT="-format qcow2"
     ;;
     ;;
-    
   btrfs)
   btrfs)
     DISK_EXT=".raw"
     DISK_EXT=".raw"
     DISK_REF="$VMID/"
     DISK_REF="$VMID/"
     DISK_FORMAT="subvol"
     DISK_FORMAT="subvol"
     DISK_IMPORT="-format raw"
     DISK_IMPORT="-format raw"
     ;;
     ;;
-    
 esac
 esac
 for i in {0,1}; do
 for i in {0,1}; do
   disk="DISK$i"
   disk="DISK$i"
@@ -269,7 +248,6 @@ for i in {0,1}; do
   eval DISK${i}_REF=${STORAGE}:${DISK_REF:-}${!disk}
   eval DISK${i}_REF=${STORAGE}:${DISK_REF:-}${!disk}
 done
 done
 msg_ok "Extracted KVM Disk Image"
 msg_ok "Extracted KVM Disk Image"
-
 msg_info "Creating HAOS VM"
 msg_info "Creating HAOS VM"
 qm create $VMID -agent 1 -tablet 0 -localtime 1 -bios ovmf -cores $CORE_COUNT -memory $RAM_SIZE -name $HN -net0 virtio,bridge=$BRG,macaddr=$MAC$VLAN \
 qm create $VMID -agent 1 -tablet 0 -localtime 1 -bios ovmf -cores $CORE_COUNT -memory $RAM_SIZE -name $HN -net0 virtio,bridge=$BRG,macaddr=$MAC$VLAN \
   -onboot 1 -ostype l26 -scsihw virtio-scsi-pci
   -onboot 1 -ostype l26 -scsihw virtio-scsi-pci
@@ -283,7 +261,6 @@ qm set $VMID \
 qm set $VMID -description "# Home Assistant OS
 qm set $VMID -description "# Home Assistant OS
 ### https://github.com/tteck/Proxmox" >/dev/null
 ### https://github.com/tteck/Proxmox" >/dev/null
 msg_ok "Created HAOS VM ${CL}${BL}${VM_NAME}"
 msg_ok "Created HAOS VM ${CL}${BL}${VM_NAME}"
-
 if [ "$START_VM" == "yes" ]; then
 if [ "$START_VM" == "yes" ]; then
 msg_info "Starting Home Assistant OS VM"
 msg_info "Starting Home Assistant OS VM"
 qm start $VMID
 qm start $VMID