Proxmox/vm/haos_vm.sh

273 lines
8.4 KiB
Bash
Raw Normal View History

2022-01-18 22:29:46 -05:00
#!/usr/bin/env bash
echo -e "Loading..."
2022-05-21 16:42:26 -04:00
GEN_MAC=$(echo '00 60 2f'$(od -An -N3 -t xC /dev/urandom) | sed -e 's/ /:/g' | tr '[:lower:]' '[:upper:]')
2022-04-26 07:06:35 -04:00
NEXTID=$(pvesh get /cluster/nextid)
2022-07-30 00:54:02 -04:00
STABLE=$(curl -s https://raw.githubusercontent.com/home-assistant/version/master/stable.json | grep "ova" | awk '{print substr($2, 2, length($2)-3) }')
2022-08-16 07:38:56 -04:00
BETA=$(curl -sX GET "https://api.github.com/repos/home-assistant/operating-system/releases" | awk '/tag_name/{print $4;exit}' FS='[""]')
DEV=$(curl -s https://raw.githubusercontent.com/home-assistant/version/master/dev.json | grep "ova" | awk '{print substr($2, 2, length($2)-3) }')
2022-04-16 14:27:33 -04:00
YW=`echo "\033[33m"`
BL=`echo "\033[36m"`
2022-08-16 07:38:56 -04:00
HA=`echo "\033[1;34m"`
2022-04-26 07:06:35 -04:00
RD=`echo "\033[01;31m"`
BGN=`echo "\033[4;92m"`
2022-04-16 14:27:33 -04:00
GN=`echo "\033[1;92m"`
2022-04-26 07:06:35 -04:00
DGN=`echo "\033[32m"`
2022-04-16 14:27:33 -04:00
CL=`echo "\033[m"`
BFR="\\r\\033[K"
HOLD="-"
CM="${GN}${CL}"
2022-05-21 16:42:26 -04:00
set -o errexit
set -o errtrace
set -o nounset
set -o pipefail
shopt -s expand_aliases
alias die='EXIT=$? LINE=$LINENO error_exit'
trap die ERR
trap cleanup EXIT
function error_exit() {
trap - ERR
2022-07-19 19:19:44 -04:00
local reason="Unknown failure occurred."
2022-05-21 16:42:26 -04:00
local msg="${1:-$reason}"
local flag="${RD}‼ ERROR ${CL}$EXIT@$LINE"
echo -e "$flag $msg" 1>&2
[ ! -z ${VMID-} ] && cleanup_vmid
exit $EXIT
}
function cleanup_vmid() {
if $(qm status $VMID &>/dev/null); then
if [ "$(qm status $VMID | awk '{print $2}')" == "running" ]; then
qm stop $VMID
fi
qm destroy $VMID
fi
}
function cleanup() {
popd >/dev/null
rm -rf $TEMP_DIR
}
TEMP_DIR=$(mktemp -d)
pushd $TEMP_DIR >/dev/null
2022-08-16 07:38:56 -04:00
if [ `pveversion | grep "pve-manager/7" | wc -l` -eq 1 ]; then
2022-08-25 15:02:28 -04:00
echo -e "\n🚨 ${RD} This script is for Proxmox Virtual Environment 6.xx${CL}\n"
2022-08-25 14:55:31 -04:00
echo "Exiting..."
sleep 3
exit
2022-07-30 00:54:02 -04:00
fi
2022-08-16 07:38:56 -04:00
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"
else
clear
2022-08-16 07:38:56 -04:00
echo -e "⚠ User exited script \n"
exit
fi
2022-02-21 22:29:39 -05:00
function header_info {
2022-08-16 07:38:56 -04:00
echo -e "${HA}
__ _____ ____ _____
/ / / / | / __ \/ ___/
/ /_/ / /| |/ / / /\__ \
/ __ / ___ / /_/ /___/ /
/_/ /_/_/v4|_\____//____/
Home Assistant OS
2022-02-21 22:29:39 -05:00
${CL}"
}
2022-04-16 14:27:33 -04:00
function msg_info() {
local msg="$1"
echo -ne " ${HOLD} ${YW}${msg}..."
}
function msg_ok() {
local msg="$1"
echo -e "${BFR} ${CM} ${GN}${msg}${CL}"
}
2022-04-26 07:06:35 -04:00
function default_settings() {
2022-08-16 07:38:56 -04:00
echo -e "${DGN}Using HAOS Version: ${BGN}${STABLE}${CL}"
BRANCH=${STABLE}
echo -e "${DGN}Using Virtual Machine ID: ${BGN}$NEXTID${CL}"
VMID=$NEXTID
echo -e "${DGN}Using Hostname: ${BGN}haos${STABLE}${CL}"
HN=haos${STABLE}
echo -e "${DGN}Allocated Cores: ${BGN}2${CL}"
CORE_COUNT="2"
echo -e "${DGN}Allocated RAM: ${BGN}4096${CL}"
RAM_SIZE="4096"
echo -e "${DGN}Using Bridge: ${BGN}vmbr0${CL}"
BRG="vmbr0"
echo -e "${DGN}Using MAC Address: ${BGN}$GEN_MAC${CL}"
MAC=$GEN_MAC
echo -e "${DGN}Using VLAN: ${BGN}Default${CL}"
VLAN=""
echo -e "${DGN}Start VM when completed: ${BGN}yes${CL}"
START_VM="yes"
echo -e "${BL}Creating a HAOS VM using the above default settings${CL}"
2022-04-26 07:06:35 -04:00
}
function advanced_settings() {
2022-08-16 07:38:56 -04:00
BRANCH=$(whiptail --title "HAOS VERSION" --radiolist "Choose Version" 10 58 3 \
"$STABLE" "Stable" ON \
"$BETA" "Beta" OFF \
"$DEV" "Dev" OFF \
3>&1 1>&2 2>&3)
exitstatus=$?
if [ $exitstatus = 0 ]; then
echo -e "${DGN}Using HAOS Version: ${BGN}$BRANCH${CL}"
else
exit
fi
VMID=$(whiptail --inputbox "Set Virtual Machine ID" 8 58 $NEXTID --title "VIRTUAL MACHINE ID" 3>&1 1>&2 2>&3)
exitstatus=$?
if [ $exitstatus = 0 ]; then
echo -e "${DGN}Using Virtual Machine ID: ${BGN}$VMID${CL}"
else
exit
fi
VM_NAME=$(whiptail --inputbox "Set Hostname" 8 58 haos${BRANCH} --title "HOSTNAME" 3>&1 1>&2 2>&3)
exitstatus=$?
if [ $exitstatus = 0 ]; then
HN=$(echo ${VM_NAME,,} | tr -d ' ')
echo -e "${DGN}Using Hostname: ${BGN}$HN${CL}"
else
exit
fi
CORE_COUNT=$(whiptail --inputbox "Allocate CPU Cores" 8 58 2 --title "CORE COUNT" 3>&1 1>&2 2>&3)
exitstatus=$?
if [ $exitstatus = 0 ]; then
echo -e "${DGN}Allocated Cores: ${BGN}$CORE_COUNT${CL}"
else
exit
fi
RAM_SIZE=$(whiptail --inputbox "Allocate RAM in MiB" 8 58 4096 --title "RAM" 3>&1 1>&2 2>&3)
exitstatus=$?
if [ $exitstatus = 0 ]; then
echo -e "${DGN}Allocated RAM: ${BGN}$RAM_SIZE${CL}"
else
exit
fi
BRG=$(whiptail --inputbox "Set a Bridge" 8 58 vmbr0 --title "BRIDGE" 3>&1 1>&2 2>&3)
exitstatus=$?
if [ $exitstatus = 0 ]; then
echo -e "${DGN}Using Bridge: ${BGN}$BRG${CL}"
else
exit
fi
MAC1=$(whiptail --inputbox "Set a MAC Address" 8 58 $GEN_MAC --title "MAC ADDRESS" 3>&1 1>&2 2>&3)
exitstatus=$?
if [ $exitstatus = 0 ]; then
MAC="$MAC1"
echo -e "${DGN}Using MAC Address: ${BGN}$MAC1${CL}"
else
exit
fi
VLAN1=$(whiptail --inputbox "Set a Vlan(leave blank for default)" 8 58 --title "VLAN" 3>&1 1>&2 2>&3)
exitstatus=$?
if [ $exitstatus = 0 ]; then
if [ -z $VLAN1 ]; then VLAN1="Default" VLAN="";
echo -e "${DGN}Using Vlan: ${BGN}$VLAN1${CL}"
else
VLAN=",tag=$VLAN1"
echo -e "${DGN}Using Vlan: ${BGN}$VLAN1${CL}"
fi
fi
if (whiptail --title "START VIRTUAL MACHINE" --yesno "Start VM when completed?" 10 58); then
echo -e "${DGN}Start VM when completed: ${BGN}yes${CL}"
START_VM="yes"
else
echo -e "${DGN}Start VM when completed: ${BGN}no${CL}"
START_VM="no"
fi
if (whiptail --title "ADVANCED SETTINGS COMPLETE" --yesno "Ready to create HAOS ${BRANCH} VM?" 10 58); then
echo -e "${RD}Creating a HAOS VM using the above advanced settings${CL}"
else
clear
header_info
echo -e "${RD}Using Advanced Settings${CL}"
advanced_settings
2022-04-26 07:06:35 -04:00
fi
}
function start_script() {
2022-08-16 07:38:56 -04:00
if (whiptail --title "SETTINGS" --yesno "Use Default Settings?" 10 58); then
clear
header_info
echo -e "${BL}Using Default Settings${CL}"
default_settings
else
clear
header_info
echo -e "${RD}Using Advanced Settings${CL}"
advanced_settings
fi
2022-04-26 07:06:35 -04:00
}
start_script
2022-08-16 07:38:56 -04:00
msg_info "Validating Storage"
2022-01-18 22:29:46 -05:00
while read -r line; do
TAG=$(echo $line | awk '{print $1}')
TYPE=$(echo $line | awk '{printf "%-10s", $2}')
FREE=$(echo $line | numfmt --field 4-6 --from-unit=K --to=iec --format %.2f | awk '{printf( "%9sB", $6)}')
ITEM=" Type: $TYPE Free: $FREE "
OFFSET=2
if [[ $((${#ITEM} + $OFFSET)) -gt ${MSG_MAX_LENGTH:-} ]]; then
MSG_MAX_LENGTH=$((${#ITEM} + $OFFSET))
fi
2022-08-16 07:38:56 -04:00
STORAGE_MENU+=( "$TAG" "$ITEM" "OFF" )
2022-01-18 22:29:46 -05:00
done < <(pvesm status -content images | awk 'NR>1')
2022-08-16 07:38:56 -04:00
VALID=$(pvesm status -content images | awk 'NR>1')
if [ -z "$VALID" ]; then
echo -e "\n${RD}⚠ Unable to detect a valid storage location.${CL}"
echo -e "Exiting..."
exit
2022-01-18 22:29:46 -05:00
elif [ $((${#STORAGE_MENU[@]}/3)) -eq 1 ]; then
STORAGE=${STORAGE_MENU[0]}
else
while [ -z "${STORAGE:+x}" ]; do
STORAGE=$(whiptail --title "Storage Pools" --radiolist \
2022-06-28 23:35:45 -04:00
"Which storage pool you would like to use for the HAOS VM?\n\n" \
2022-01-18 22:29:46 -05:00
16 $(($MSG_MAX_LENGTH + 23)) 6 \
"${STORAGE_MENU[@]}" 3>&1 1>&2 2>&3) || exit
done
fi
2022-04-16 14:27:33 -04:00
msg_ok "Using ${CL}${BL}$STORAGE${CL} ${GN}for Storage Location."
2022-07-05 14:33:59 -04:00
msg_ok "Virtual Machine ID is ${CL}${BL}$VMID${CL}."
2022-04-26 09:42:52 -04:00
msg_info "Getting URL for Home Assistant ${BRANCH} Disk Image"
2022-08-16 07:38:56 -04:00
if [ "$BRANCH" == "$DEV" ]; then
URL=https://os-builds.home-assistant.io/${BRANCH}/haos_ova-${BRANCH}.qcow2.xz
else
2022-04-26 09:42:52 -04:00
URL=https://github.com/home-assistant/operating-system/releases/download/${BRANCH}/haos_ova-${BRANCH}.qcow2.xz
2022-08-16 07:38:56 -04:00
fi
2022-07-05 14:33:59 -04:00
sleep 2
2022-04-16 14:27:33 -04:00
msg_ok "${CL}${BL}${URL}${CL}"
2022-01-18 22:29:46 -05:00
wget -q --show-progress $URL
echo -en "\e[1A\e[0K"
FILE=$(basename $URL)
2022-07-05 14:33:59 -04:00
msg_ok "Downloaded ${CL}${BL}haos_ova-${BRANCH}.qcow2.xz${CL}"
msg_info "Extracting KVM Disk Image"
2022-04-26 07:06:35 -04:00
unxz $FILE
2022-01-18 22:29:46 -05:00
STORAGE_TYPE=$(pvesm status -storage $STORAGE | awk 'NR>1 {print $2}')
case $STORAGE_TYPE in
nfs|dir)
DISK_EXT=".qcow2"
DISK_REF="$VMID/"
DISK_IMPORT="-format qcow2"
2022-01-18 22:29:46 -05:00
esac
for i in {0,1}; do
disk="DISK$i"
eval DISK${i}=vm-${VMID}-disk-${i}${DISK_EXT:-}
eval DISK${i}_REF=${STORAGE}:${DISK_REF:-}${!disk}
done
2022-07-05 14:33:59 -04:00
msg_ok "Extracted KVM Disk Image"
2022-04-16 14:27:33 -04:00
msg_info "Creating HAOS VM"
2022-08-16 07:38:56 -04:00
qm create $VMID -agent 1 -bios ovmf -cores $CORE_COUNT -memory $RAM_SIZE -name $HN -net0 virtio,bridge=$BRG,macaddr=$MAC$VLAN \
2022-01-18 22:29:46 -05:00
-onboot 1 -ostype l26 -scsihw virtio-scsi-pci
2022-07-29 17:51:48 -04:00
pvesm alloc $STORAGE $VMID $DISK0 128 1>&/dev/null
qm importdisk $VMID ${FILE%.*} $STORAGE ${DISK_IMPORT:-} 1>&/dev/null
2022-01-18 22:29:46 -05:00
qm set $VMID \
2022-07-29 18:04:22 -04:00
-efidisk0 ${DISK0_REF},size=128K \
2022-01-22 18:17:03 -05:00
-scsi0 ${DISK1_REF},size=32G >/dev/null
2022-01-18 22:29:46 -05:00
qm set $VMID \
2022-01-22 18:17:03 -05:00
-boot order=scsi0 >/dev/null
2022-07-15 12:42:05 -04:00
qm set $VMID -description "# Home Assistant OS
2022-07-15 12:48:01 -04:00
### https://github.com/tteck/Proxmox" >/dev/null
2022-08-16 07:38:56 -04:00
msg_ok "Created HAOS VM ${CL}${BL}(${HN})"
2022-04-26 07:06:35 -04:00
if [ "$START_VM" == "yes" ]; then
2022-04-16 14:27:33 -04:00
msg_info "Starting Home Assistant OS VM"
2022-02-21 11:52:07 -05:00
qm start $VMID
2022-04-16 14:27:33 -04:00
msg_ok "Started Home Assistant OS VM"
2022-04-26 07:06:35 -04:00
fi
2022-04-16 14:27:33 -04:00
msg_ok "Completed Successfully!\n"