Proxmox/ct/create_lxc.sh

142 lines
4.1 KiB
Bash
Raw Normal View History

2022-02-23 12:52:49 +01:00
#!/usr/bin/env bash
2022-12-22 21:04:51 +01:00
if [ "$VERBOSE" == "yes" ]; then set -x; fi
2022-10-30 02:08:41 +02:00
YW=$(echo "\033[33m")
BL=$(echo "\033[36m")
RD=$(echo "\033[01;31m")
GN=$(echo "\033[1;92m")
CL=$(echo "\033[m")
2022-04-16 13:21:54 +02:00
CM="${GN}${CL}"
2022-10-25 09:43:46 +02:00
CROSS="${RD}${CL}"
2022-04-16 15:52:57 +02:00
BFR="\\r\\033[K"
2022-04-16 16:11:31 +02:00
HOLD="-"
2022-04-25 16:20:22 +02:00
function msg_info() {
2022-10-30 02:08:41 +02:00
local msg="$1"
echo -ne " ${HOLD} ${YW}${msg}..."
2022-02-23 12:52:49 +01:00
}
2022-04-25 16:20:22 +02:00
function msg_ok() {
2022-10-30 02:08:41 +02:00
local msg="$1"
echo -e "${BFR} ${CM} ${GN}${msg}${CL}"
2022-02-23 12:52:49 +01:00
}
2022-10-25 09:43:46 +02:00
function msg_error() {
2022-10-30 02:08:41 +02:00
local msg="$1"
echo -e "${BFR} ${CROSS} ${RD}${msg}${CL}"
2022-10-25 09:43:46 +02:00
}
msg_info "Validating Storage"
VALIDCT=$(pvesm status -content rootdir | awk 'NR>1')
2022-10-30 02:08:41 +02:00
if [ -z "$VALIDCT" ]; then
msg_error "Unable to detect a valid Container Storage location."
exit 1
fi
VALIDTMP=$(pvesm status -content vztmpl | awk 'NR>1')
2022-10-30 02:08:41 +02:00
if [ -z "$VALIDTMP" ]; then
msg_error "Unable to detect a valid Template Storage location."
exit 1
fi
2023-02-03 16:53:08 +01: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
function error_exit() {
trap - ERR
local reason="Unknown failure occurred."
local msg="${1:-$reason}"
local flag="${RD}‼ ERROR ${CL}$EXIT@$LINE"
echo -e "$flag $msg" 1>&2
exit $EXIT
}
2022-08-31 01:59:07 +02:00
2022-02-23 12:52:49 +01:00
function select_storage() {
local CLASS=$1
local CONTENT
local CONTENT_LABEL
case $CLASS in
2022-10-30 02:08:41 +02:00
container)
CONTENT='rootdir'
CONTENT_LABEL='Container'
;;
template)
CONTENT='vztmpl'
CONTENT_LABEL='Container template'
;;
2023-02-03 16:53:08 +01:00
*) false || die "Invalid storage class." ;;
2022-02-23 12:52:49 +01:00
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
2022-10-30 02:08:41 +02:00
MENU+=("$TAG" "$ITEM" "OFF")
2022-02-23 12:52:49 +01:00
done < <(pvesm status -content $CONTENT | awk 'NR>1')
2022-10-30 02:08:41 +02:00
if [ $((${#MENU[@]} / 3)) -eq 1 ]; then
2022-02-23 12:52:49 +01:00
printf ${MENU[0]}
2022-10-30 02:08:41 +02:00
else
2022-02-23 12:52:49 +01:00
local STORAGE
2022-10-30 02:08:41 +02:00
while [ -z "${STORAGE:+x}" ]; do
2022-02-23 12:52:49 +01:00
STORAGE=$(whiptail --title "Storage Pools" --radiolist \
2022-10-30 02:08:41 +02:00
"Which storage pool you would like to use for the ${CONTENT_LABEL,,}?\n\n" \
16 $(($MSG_MAX_LENGTH + 23)) 6 \
2023-02-03 16:53:08 +01:00
"${MENU[@]}" 3>&1 1>&2 2>&3) || die "Menu aborted."
2022-02-23 12:52:49 +01:00
done
printf $STORAGE
fi
}
2023-02-03 16:53:08 +01:00
[[ "${CTID:-}" ]] || die "You need to set 'CTID' variable."
[[ "${PCT_OSTYPE:-}" ]] || die "You need to set 'PCT_OSTYPE' variable."
2022-02-23 12:52:49 +01:00
2023-02-03 16:53:08 +01:00
[ "$CTID" -ge "100" ] || die "ID cannot be less than 100."
2022-02-23 12:52:49 +01:00
if pct status $CTID &>/dev/null; then
2022-05-21 13:11:10 +02:00
echo -e "ID '$CTID' is already in use."
2022-02-23 12:52:49 +01:00
unset CTID
2023-02-03 16:53:08 +01:00
die "Cannot use ID that is already in use."
2022-02-23 12:52:49 +01:00
fi
TEMPLATE_STORAGE=$(select_storage template) || exit
2022-04-25 16:27:30 +02:00
msg_ok "Using ${BL}$TEMPLATE_STORAGE${CL} ${GN}for Template Storage."
2022-02-23 12:52:49 +01:00
CONTAINER_STORAGE=$(select_storage container) || exit
2022-04-25 16:27:30 +02:00
msg_ok "Using ${BL}$CONTAINER_STORAGE${CL} ${GN}for Container Storage."
2022-02-23 12:52:49 +01:00
2022-04-16 15:52:57 +02:00
msg_info "Updating LXC Template List"
2022-02-23 12:52:49 +01:00
pveam update >/dev/null
2022-04-16 17:57:11 +02:00
msg_ok "Updated LXC Template List"
2022-02-23 12:52:49 +01: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)
2023-02-03 16:53:08 +01:00
[ ${#TEMPLATES[@]} -gt 0 ] || die "Unable to find a template when searching for '$TEMPLATE_SEARCH'."
2022-02-23 12:52:49 +01:00
TEMPLATE="${TEMPLATES[-1]}"
if ! pveam list $TEMPLATE_STORAGE | grep -q $TEMPLATE; then
2022-04-16 15:52:57 +02:00
msg_info "Downloading LXC Template"
2023-02-03 16:53:08 +01:00
pveam download $TEMPLATE_STORAGE $TEMPLATE >/dev/null ||
die "A problem occured while downloading the LXC template."
2022-04-20 20:27:25 +02:00
msg_ok "Downloaded LXC Template"
2022-02-23 12:52:49 +01:00
fi
DEFAULT_PCT_OPTIONS=(
-arch $(dpkg --print-architecture))
2022-10-30 02:08:41 +02:00
PCT_OPTIONS=(${PCT_OPTIONS[@]:-${DEFAULT_PCT_OPTIONS[@]}})
[[ " ${PCT_OPTIONS[@]} " =~ " -rootfs " ]] || PCT_OPTIONS+=(-rootfs $CONTAINER_STORAGE:${PCT_DISK_SIZE:-8})
2022-02-23 12:52:49 +01:00
2022-04-16 16:05:03 +02:00
msg_info "Creating LXC Container"
2023-02-03 16:53:08 +01:00
pct create $CTID ${TEMPLATE_STORAGE}:vztmpl/${TEMPLATE} ${PCT_OPTIONS[@]} >/dev/null ||
die "A problem occured while trying to create container."
2022-04-16 17:46:18 +02:00
msg_ok "LXC Container ${BL}$CTID${CL} ${GN}was successfully created."