mirror of https://github.com/tteck/Proxmox.git
				
				
				
			Update haos-vm-v4.sh
This commit is contained in:
		
							parent
							
								
									e40781bb85
								
							
						
					
					
						commit
						2b41ad24ea
					
				| 
						 | 
					@ -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 "${RD}This script requires Proxmox Virtual Environment 7.0 or greater${CL}"
 | 
				
			||||||
  echo -e "Exiting..."
 | 
					  echo -e "Exiting..."
 | 
				
			||||||
  sleep 2
 | 
					  sleep 2
 | 
				
			||||||
  exit
 | 
					  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
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in New Issue