wireguard-install.sh 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. #!/usr/bin/env bash
  2. set -o errexit
  3. set -o errtrace
  4. set -o nounset
  5. set -o pipefail
  6. shopt -s expand_aliases
  7. alias die='EXIT=$? LINE=$LINENO error_exit'
  8. trap die ERR
  9. trap 'die "Script interrupted."' INT
  10. function error_exit() {
  11. trap - ERR
  12. local DEFAULT='Unknown failure occured.'
  13. local REASON="\e[97m${1:-$DEFAULT}\e[39m"
  14. local FLAG="\e[91m[ERROR:LXC] \e[93m$EXIT@$LINE"
  15. msg "$FLAG $REASON"
  16. exit $EXIT
  17. }
  18. function msg() {
  19. local TEXT="$1"
  20. echo -e "$TEXT"
  21. }
  22. CROSS='\033[1;31m\xE2\x9D\x8C\033[0m'
  23. RD=`echo "\033[01;31m"`
  24. BL=`echo "\033[36m"`
  25. CM='\xE2\x9C\x94\033'
  26. GN=`echo "\033[1;92m"`
  27. CL=`echo "\033[m"`
  28. RETRY_NUM=5
  29. RETRY_EVERY=3
  30. NUM=$RETRY_NUM
  31. echo -en "${GN} Setting up Container OS... "
  32. sed -i "/$LANG/ s/\(^# \)//" /etc/locale.gen
  33. locale-gen >/dev/null
  34. while [ "$(hostname -I)" = "" ]; do
  35. 1>&2 echo -en "${CROSS}${RD} No Network! "
  36. sleep $RETRY_EVERY
  37. ((NUM--))
  38. if [ $NUM -eq 0 ]
  39. then
  40. 1>&2 echo -e "${CROSS}${RD} No Network After $RETRY_NUM Tries${CL}"
  41. exit 1
  42. fi
  43. done
  44. echo -e "${CM}${CL} \r"
  45. echo -en "${GN} Network Connected: ${BL}$(hostname -I)${CL} "
  46. echo -e "${CM}${CL} \r"
  47. OPTIONS_PATH='/options.conf'
  48. cat >$OPTIONS_PATH <<'EOF'
  49. IPv4dev=eth0
  50. install_user=root
  51. VPN=wireguard
  52. pivpnNET=10.6.0.0
  53. subnetClass=24
  54. ALLOWED_IPS="0.0.0.0/0, ::0/0"
  55. pivpnMTU=1420
  56. pivpnPORT=51820
  57. pivpnDNS1=1.1.1.1
  58. pivpnDNS2=8.8.8.8
  59. pivpnHOST=
  60. pivpnPERSISTENTKEEPALIVE=25
  61. UNATTUPG=1
  62. EOF
  63. echo -en "${GN} Updating Container OS... "
  64. apt update &>/dev/null
  65. apt-get -qqy upgrade &>/dev/null
  66. echo -e "${CM}${CL} \r"
  67. echo -en "${GN} Installing Dependencies... "
  68. apt-get install -y curl &>/dev/null
  69. apt-get install -y sudo &>/dev/null
  70. echo -e "${CM}${CL} \r"
  71. echo -en "${GN} Installing WireGuard (using pivpn.io)... "
  72. curl -s -L https://install.pivpn.io > install.sh
  73. chmod +x install.sh
  74. ./install.sh --unattended options.conf &>/dev/null
  75. echo -e "${CM}${CL} \r"
  76. PASS=$(grep -w "root" /etc/shadow | cut -b6);
  77. if [[ $PASS != $ ]]; then
  78. echo -en "${GN} Customizing Container... "
  79. rm /etc/motd
  80. rm /etc/update-motd.d/10-uname
  81. touch ~/.hushlogin
  82. GETTY_OVERRIDE="/etc/systemd/system/container-getty@1.service.d/override.conf"
  83. mkdir -p $(dirname $GETTY_OVERRIDE)
  84. cat << EOF > $GETTY_OVERRIDE
  85. [Service]
  86. ExecStart=
  87. ExecStart=-/sbin/agetty --autologin root --noclear --keep-baud tty%I 115200,38400,9600 \$TERM
  88. EOF
  89. systemctl daemon-reload
  90. systemctl restart $(basename $(dirname $GETTY_OVERRIDE) | sed 's/\.d//')
  91. echo -e "${CM}${CL} \r"
  92. fi
  93. echo -en "${GN} Cleanup... "
  94. apt-get autoremove >/dev/null
  95. apt-get autoclean >/dev/null
  96. rm -rf /var/{cache,log}/* /var/lib/apt/lists/*
  97. echo -e "${CM}${CL} \n"