Proxmox/ct/create_lxc.sh

126 lines
3.9 KiB
Bash
Raw Normal View History

2022-02-23 06:52:49 -05:00
#!/usr/bin/env bash
2022-04-16 09:55:27 -04:00
YW=`echo "\033[33m"`
2022-02-23 06:52:49 -05:00
BL=`echo "\033[36m"`
RD=`echo "\033[01;31m"`
GN=`echo "\033[1;92m"`
CL=`echo "\033[m"`
2022-04-16 07:21:54 -04:00
CM="${GN}${CL}"
2022-08-30 19:59:07 -04:00
CROSS="${RD}${CL}"
2022-04-16 09:52:57 -04:00
BFR="\\r\\033[K"
2022-04-16 10:11:31 -04:00
HOLD="-"
2022-04-25 10:20:22 -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'
2022-02-23 06:52:49 -05:00
trap die ERR
function error_exit() {
trap - ERR
Correct Spelling (#360) * Update adguard-install.sh * Update daemonsync-install.sh * Update dashy-install.sh * Update debian-install.sh * Update deconz-install.sh * Update docker-install.sh * Update esphome-install.sh * Update grafana-install.sh * Update heimdalldashboard-install.sh * Update homeassistant-install.sh * Update homebridge-install.sh * Update influxdb-install.sh * Update iobroker-install.sh * Update jellyfin-install.sh * Update keycloak-install.sh * Update magicmirror-install.sh * Update mariadb-install.sh * Update meshcentral-install.sh * Update motioneye-install.sh * Update mqtt-install.sh * Update nginx-proxy-manager-install.sh * Update nocodb-install.sh * Update node-red-install.sh * Update omada-install.sh * Update openhab-install.sh * Update photoprism-install.sh * Update pihole-install.sh * Update plex-install.sh * Update podman-homeassistant-install.sh * Update postgresql-install.sh * Update prometheus-install.sh * Update technitiumdns-install.sh * Update ubuntu-install.sh * Update unifi-install.sh * Update uptimekuma-install.sh * Update vaultwarden-install.sh * Update whoogle-install.sh * Update wireguard-install.sh * Update zigbee2mqtt-install.sh * Update zwavejs2mqtt-install.sh * Update adguard-v3.sh * Update create_lxc.sh * Update daemonsync-v3.sh * Update dashy-v3.sh * Update debian-v3.sh * Update deconz-v3.sh * Update docker-v3.sh * Update esphome-v3.sh * Update grafana-v3.sh * Update heimdalldashboard-v3.sh * Update homeassistant-v3.sh * Update homebridge-v3.sh * Update influxdb-v3.sh * Update iobroker-v3.sh * Update jellyfin-v3.sh * Update keycloak-v3.sh * Update magicmirror-v3.sh * Update mariadb-v3.sh * Update meshcentral-v3.sh * Update motioneye-v3.sh * Update mqtt-v3.sh * Update nginx-proxy-manager-v3.sh * Update nocodb-v3.sh * Update node-red-v3.sh * Update omada-v3.sh * Update openhab-v3.sh * Update photoprism-v3.sh * Update pihole-v3.sh * Update plex-v3.sh * Update podman-homeassistant-v3.sh * Update postgresql-v3.sh * Update prometheus-v3.sh * Update technitiumdns-v3.sh * Update ubuntu-v3.sh * Update unifi-v3.sh * Update uptimekuma-v3.sh * Update vaultwarden-v3.sh * Update whoogle-v3.sh * Update wireguard-v3.sh * Update zigbee2mqtt-v3.sh * Update zwavejs2mqtt-v3.sh
2022-07-20 06:10:39 -04:00
local reason="Unknown failure occurred."
2022-04-25 10:20:22 -04:00
local msg="${1:-$reason}"
local flag="${RD}‼ ERROR ${CL}$EXIT@$LINE"
echo -e "$flag $msg" 1>&2
2022-02-23 06:52:49 -05:00
exit $EXIT
}
2022-04-25 10:20:22 -04:00
function msg_info() {
local msg="$1"
echo -ne " ${HOLD} ${YW}${msg}..."
2022-02-23 06:52:49 -05:00
}
2022-04-25 10:20:22 -04:00
function msg_ok() {
local msg="$1"
echo -e "${BFR} ${CM} ${GN}${msg}${CL}"
2022-02-23 06:52:49 -05:00
}
2022-08-30 19:59:07 -04:00
function msg_error() {
local msg="$1"
echo -e "${BFR} ${CROSS} ${RD}${msg}${CL}"
}
2022-08-28 00:28:31 -04:00
msg_info "Validating Storage"
2022-08-30 19:59:07 -04:00
VALID=$(pvesm status -content rootdir | awk 'NR>1')
if [ -z "$VALID" ]; then msg_error "Unable to detect a valid storage location."; exit 1; fi;
2022-02-23 06:52:49 -05:00
function select_storage() {
local CLASS=$1
local CONTENT
local CONTENT_LABEL
case $CLASS in
container) CONTENT='rootdir'; CONTENT_LABEL='Container';;
template) CONTENT='vztmpl'; CONTENT_LABEL='Container template';;
*) false || die "Invalid storage class.";;
esac
local -a MENU
while read -r line; do
local TAG=$(echo $line | awk '{print $1}')
local TYPE=$(echo $line | awk '{printf "%-10s", $2}')
local FREE=$(echo $line | numfmt --field 4-6 --from-unit=K --to=iec --format %.2f | awk '{printf( "%9sB", $6)}')
local ITEM=" Type: $TYPE Free: $FREE "
local OFFSET=2
if [[ $((${#ITEM} + $OFFSET)) -gt ${MSG_MAX_LENGTH:-} ]]; then
local MSG_MAX_LENGTH=$((${#ITEM} + $OFFSET))
fi
MENU+=( "$TAG" "$ITEM" "OFF" )
done < <(pvesm status -content $CONTENT | awk 'NR>1')
2022-08-30 19:59:07 -04:00
if [ $((${#MENU[@]}/3)) -eq 1 ]; then
2022-02-23 06:52:49 -05:00
printf ${MENU[0]}
else
local STORAGE
while [ -z "${STORAGE:+x}" ]; do
STORAGE=$(whiptail --title "Storage Pools" --radiolist \
"Which storage pool you would like to use for the ${CONTENT_LABEL,,}?\n\n" \
16 $(($MSG_MAX_LENGTH + 23)) 6 \
"${MENU[@]}" 3>&1 1>&2 2>&3) || die "Menu aborted."
done
printf $STORAGE
fi
}
[[ "${CTID:-}" ]] || die "You need to set 'CTID' variable."
[[ "${PCT_OSTYPE:-}" ]] || die "You need to set 'PCT_OSTYPE' variable."
[ "$CTID" -ge "100" ] || die "ID cannot be less than 100."
if pct status $CTID &>/dev/null; then
2022-05-21 07:11:10 -04:00
echo -e "ID '$CTID' is already in use."
2022-02-23 06:52:49 -05:00
unset CTID
die "Cannot use ID that is already in use."
fi
TEMPLATE_STORAGE=$(select_storage template) || exit
2022-04-25 10:27:30 -04:00
msg_ok "Using ${BL}$TEMPLATE_STORAGE${CL} ${GN}for Template Storage."
2022-02-23 06:52:49 -05:00
CONTAINER_STORAGE=$(select_storage container) || exit
2022-04-25 10:27:30 -04:00
msg_ok "Using ${BL}$CONTAINER_STORAGE${CL} ${GN}for Container Storage."
2022-02-23 06:52:49 -05:00
2022-04-16 09:52:57 -04:00
msg_info "Updating LXC Template List"
2022-02-23 06:52:49 -05:00
pveam update >/dev/null
2022-04-16 11:57:11 -04:00
msg_ok "Updated LXC Template List"
2022-02-23 06:52:49 -05:00
TEMPLATE_SEARCH=${PCT_OSTYPE}-${PCT_OSVERSION:-}
mapfile -t TEMPLATES < <(pveam available -section system | sed -n "s/.*\($TEMPLATE_SEARCH.*\)/\1/p" | sort -t - -k 2 -V)
[ ${#TEMPLATES[@]} -gt 0 ] || die "Unable to find a template when searching for '$TEMPLATE_SEARCH'."
TEMPLATE="${TEMPLATES[-1]}"
if ! pveam list $TEMPLATE_STORAGE | grep -q $TEMPLATE; then
2022-04-16 09:52:57 -04:00
msg_info "Downloading LXC Template"
2022-02-23 06:52:49 -05:00
pveam download $TEMPLATE_STORAGE $TEMPLATE >/dev/null ||
die "A problem occured while downloading the LXC template."
2022-04-20 14:27:25 -04:00
msg_ok "Downloaded LXC Template"
2022-02-23 06:52:49 -05:00
fi
DEFAULT_PCT_OPTIONS=(
-arch $(dpkg --print-architecture))
PCT_OPTIONS=( ${PCT_OPTIONS[@]:-${DEFAULT_PCT_OPTIONS[@]}} )
[[ " ${PCT_OPTIONS[@]} " =~ " -rootfs " ]] || PCT_OPTIONS+=( -rootfs $CONTAINER_STORAGE:${PCT_DISK_SIZE:-8} )
2022-04-16 10:05:03 -04:00
msg_info "Creating LXC Container"
2022-02-23 06:52:49 -05:00
pct create $CTID ${TEMPLATE_STORAGE}:vztmpl/${TEMPLATE} ${PCT_OPTIONS[@]} >/dev/null ||
die "A problem occured while trying to create container."
2022-04-16 11:46:18 -04:00
msg_ok "LXC Container ${BL}$CTID${CL} ${GN}was successfully created."