vaultwarden-v1.sh 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  1. #!/usr/bin/env bash
  2. CHECKMARK='\033[0;32m\xE2\x9C\x94\033[0m'
  3. RD=`echo "\033[01;31m"`
  4. BL=`echo "\033[36m"`
  5. CM='\xE2\x9C\x94\033'
  6. GN=`echo "\033[1;92m"`
  7. CL=`echo "\033[m"`
  8. while true; do
  9. read -p "This will create a New Vaultwarden LXC Container. Proceed(y/n)?" yn
  10. case $yn in
  11. [Yy]* ) break;;
  12. [Nn]* ) exit;;
  13. * ) echo "Please answer yes or no.";;
  14. esac
  15. done
  16. clear
  17. function header_info {
  18. echo -e "${BL}
  19. __ __ _ _ _
  20. \ \ / / | | | | |
  21. \ \ / /_ _ _ _| | |___ ____ _ _ __ __| | ___ _ __
  22. \ \/ / _ | | | | | __\ \ /\ / / _ | __/ _ |/ _ \ _ \
  23. \ / (_| | |_| | | |_ \ V V / (_| | | | (_| | __/ | | |
  24. \/ \__,_|\__,_|_|\__| \_/\_/ \__,_|_| \__,_|\___|_| |_|
  25. ${CL}"
  26. }
  27. header_info
  28. set -o errexit
  29. set -o errtrace
  30. set -o nounset
  31. set -o pipefail
  32. shopt -s expand_aliases
  33. alias die='EXIT=$? LINE=$LINENO error_exit'
  34. trap die ERR
  35. trap cleanup EXIT
  36. function error_exit() {
  37. trap - ERR
  38. local DEFAULT='Unknown failure occured.'
  39. local REASON="\e[97m${1:-$DEFAULT}\e[39m"
  40. local FLAG="\e[91m[ERROR] \e[93m$EXIT@$LINE"
  41. msg "$FLAG $REASON"
  42. [ ! -z ${CTID-} ] && cleanup_ctid
  43. exit $EXIT
  44. }
  45. function warn() {
  46. local REASON="\e[97m$1\e[39m"
  47. local FLAG="\e[93m[WARNING]\e[39m"
  48. msg "$FLAG $REASON"
  49. }
  50. function info() {
  51. local REASON="$1"
  52. local FLAG="\e[36m[INFO]\e[39m"
  53. msg "$FLAG $REASON"
  54. }
  55. function msg() {
  56. local TEXT="$1"
  57. echo -e "$TEXT"
  58. }
  59. function cleanup_ctid() {
  60. if [ ! -z ${MOUNT+x} ]; then
  61. pct unmount $CTID
  62. fi
  63. if $(pct status $CTID &>/dev/null); then
  64. if [ "$(pct status $CTID | awk '{print $2}')" == "running" ]; then
  65. pct stop $CTID
  66. fi
  67. pct destroy $CTID
  68. elif [ "$(pvesm list $STORAGE --vmid $CTID)" != "" ]; then
  69. pvesm free $ROOTFS
  70. fi
  71. }
  72. function cleanup() {
  73. popd >/dev/null
  74. rm -rf $TEMP_DIR
  75. }
  76. function load_module() {
  77. if ! $(lsmod | grep -Fq $1); then
  78. modprobe $1 &>/dev/null || \
  79. die "Failed to load '$1' module."
  80. fi
  81. MODULES_PATH=/etc/modules
  82. if ! $(grep -Fxq "$1" $MODULES_PATH); then
  83. echo "$1" >> $MODULES_PATH || \
  84. die "Failed to add '$1' module to load at boot."
  85. fi
  86. }
  87. TEMP_DIR=$(mktemp -d)
  88. pushd $TEMP_DIR >/dev/null
  89. wget -qL https://raw.githubusercontent.com/tteck/Proxmox/main/setup/vault_setup.sh
  90. load_module overlay
  91. echo -e "${RD} Expect 30+ minute install time. ${CL} \n"
  92. while read -r line; do
  93. TAG=$(echo $line | awk '{print $1}')
  94. TYPE=$(echo $line | awk '{printf "%-10s", $2}')
  95. FREE=$(echo $line | numfmt --field 4-6 --from-unit=K --to=iec --format %.2f | awk '{printf( "%9sB", $6)}')
  96. ITEM=" Type: $TYPE Free: $FREE "
  97. OFFSET=2
  98. if [[ $((${#ITEM} + $OFFSET)) -gt ${MSG_MAX_LENGTH:-} ]]; then
  99. MSG_MAX_LENGTH=$((${#ITEM} + $OFFSET))
  100. fi
  101. STORAGE_MENU+=( "$TAG" "$ITEM" "OFF" )
  102. done < <(pvesm status -content rootdir | awk 'NR>1')
  103. if [ $((${#STORAGE_MENU[@]}/3)) -eq 0 ]; then
  104. warn "'Container' needs to be selected for at least one storage location."
  105. die "Unable to detect valid storage location."
  106. elif [ $((${#STORAGE_MENU[@]}/3)) -eq 1 ]; then
  107. STORAGE=${STORAGE_MENU[0]}
  108. else
  109. while [ -z "${STORAGE:+x}" ]; do
  110. STORAGE=$(whiptail --title "Storage Pools" --radiolist \
  111. "Which storage pool you would like to use for the container?\n\n" \
  112. 16 $(($MSG_MAX_LENGTH + 23)) 6 \
  113. "${STORAGE_MENU[@]}" 3>&1 1>&2 2>&3) || exit
  114. done
  115. fi
  116. info "Using '$STORAGE' for storage location."
  117. CTID=$(pvesh get /cluster/nextid)
  118. info "Container ID is $CTID."
  119. echo -e "${CHECKMARK} \e[1;92m Updating LXC Template List... \e[0m"
  120. pveam update >/dev/null
  121. echo -e "${CHECKMARK} \e[1;92m Downloading LXC Template... \e[0m"
  122. OSTYPE=debian
  123. OSVERSION=${OSTYPE}-11
  124. mapfile -t TEMPLATES < <(pveam available -section system | sed -n "s/.*\($OSVERSION.*\)/\1/p" | sort -t - -k 2 -V)
  125. TEMPLATE="${TEMPLATES[-1]}"
  126. pveam download local $TEMPLATE >/dev/null ||
  127. die "A problem occured while downloading the LXC template."
  128. STORAGE_TYPE=$(pvesm status -storage $STORAGE | awk 'NR>1 {print $2}')
  129. case $STORAGE_TYPE in
  130. dir|nfs)
  131. DISK_EXT=".raw"
  132. DISK_REF="$CTID/"
  133. ;;
  134. zfspool)
  135. DISK_PREFIX="subvol"
  136. DISK_FORMAT="subvol"
  137. ;;
  138. esac
  139. DISK=${DISK_PREFIX:-vm}-${CTID}-disk-0${DISK_EXT-}
  140. ROOTFS=${STORAGE}:${DISK_REF-}${DISK}
  141. echo -e "${CHECKMARK} \e[1;92m Creating LXC Container... \e[0m"
  142. DISK_SIZE=8G
  143. pvesm alloc $STORAGE $CTID $DISK $DISK_SIZE --format ${DISK_FORMAT:-raw} >/dev/null
  144. if [ "$STORAGE_TYPE" == "zfspool" ]; then
  145. warn "Some containers may not work properly due to ZFS not supporting 'fallocate'."
  146. else
  147. mkfs.ext4 $(pvesm path $ROOTFS) &>/dev/null
  148. fi
  149. ARCH=$(dpkg --print-architecture)
  150. HOSTNAME=vaultwarden
  151. TEMPLATE_STRING="local:vztmpl/${TEMPLATE}"
  152. pct create $CTID $TEMPLATE_STRING -arch $ARCH -features nesting=1 \
  153. -hostname $HOSTNAME -net0 name=eth0,bridge=vmbr0,ip=dhcp -onboot 1 -cores 4 -memory 4096\
  154. -ostype $OSTYPE -rootfs $ROOTFS,size=$DISK_SIZE -storage $STORAGE >/dev/null
  155. MOUNT=$(pct mount $CTID | cut -d"'" -f 2)
  156. ln -fs $(readlink /etc/localtime) ${MOUNT}/etc/localtime
  157. pct unmount $CTID && unset MOUNT
  158. echo -e "${CHECKMARK} \e[1;92m Starting LXC Container... \e[0m"
  159. pct start $CTID
  160. pct push $CTID vault_setup.sh /vault_setup.sh -perms 755
  161. pct exec $CTID /vault_setup.sh
  162. IP=$(pct exec $CTID ip a s dev eth0 | sed -n '/inet / s/\// /p' | awk '{print $2}')
  163. info "Successfully created a Vaultwarden LXC Container to $CTID"
  164. echo -e "\e[1;92m Vaultwarden should be reachable by going to the following URL.
  165. http://${IP}:8000
  166. \e[0m"