2022-01-16 18:39:46 +00:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
|
|
|
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 'die "Script interrupted."' INT
|
|
|
|
|
|
|
|
function error_exit() {
|
|
|
|
trap - ERR
|
|
|
|
local DEFAULT='Unknown failure occured.'
|
|
|
|
local REASON="\e[97m${1:-$DEFAULT}\e[39m"
|
|
|
|
local FLAG="\e[91m[ERROR:LXC] \e[93m$EXIT@$LINE"
|
|
|
|
msg "$FLAG $REASON"
|
|
|
|
exit $EXIT
|
|
|
|
}
|
|
|
|
function msg() {
|
|
|
|
local TEXT="$1"
|
|
|
|
echo -e "$TEXT"
|
|
|
|
}
|
|
|
|
|
|
|
|
msg "Setting up LXC OS..."
|
|
|
|
sed -i "/$LANG/ s/\(^# \)//" /etc/locale.gen
|
|
|
|
locale-gen >/dev/null
|
|
|
|
apt-get -y purge openssh-{client,server} >/dev/null
|
|
|
|
apt-get autoremove >/dev/null
|
|
|
|
|
|
|
|
# Update container OS
|
|
|
|
msg "Updating container OS..."
|
|
|
|
apt update &>/dev/null
|
|
|
|
apt-get -qqy upgrade &>/dev/null
|
|
|
|
|
|
|
|
msg "Installing Prerequisites..."
|
|
|
|
apt-get -qqy install \
|
|
|
|
curl \
|
|
|
|
sudo &>/dev/null
|
|
|
|
|
|
|
|
msg "Installing cloudflared.."
|
2022-01-16 18:50:26 +00:00
|
|
|
wget https://github.com/cloudflare/cloudflared/releases/latest/download/cloudflared-linux-amd64.deb &>/dev/null
|
|
|
|
sudo apt-get install ./cloudflared-linux-amd64.deb &>/dev/null
|
|
|
|
sudo useradd -s /usr/sbin/nologin -r -M cloudflared &>/dev/null
|
2022-01-16 21:55:36 +00:00
|
|
|
rm cloudflared-linux-amd64.deb
|
2022-01-16 18:39:46 +00:00
|
|
|
|
2022-01-16 19:05:52 +00:00
|
|
|
CLOUDFLARED_CONF="/etc/default/cloudflared"
|
2022-01-16 18:39:46 +00:00
|
|
|
cat << EOF > $CLOUDFLARED_CONF
|
|
|
|
# Commandline args for cloudflared, using Cloudflare DNS
|
|
|
|
CLOUDFLARED_OPTS=--port 5053 --upstream https://1.1.1.1/dns-query --upstream https://1.0.0.1/dns-query
|
|
|
|
EOF
|
|
|
|
|
|
|
|
chown cloudflared:cloudflared /etc/default/cloudflared
|
|
|
|
chown cloudflared:cloudflared /usr/local/bin/cloudflared
|
|
|
|
|
2022-01-20 19:41:38 +00:00
|
|
|
wget -O /etc/systemd/system/cloudflared.service https://raw.githubusercontent.com/StevenSeifried/proxmox-scripts/main/systemd_files/cloudflared.service &>/dev/null
|
2022-01-16 18:39:46 +00:00
|
|
|
|
2022-01-16 18:50:26 +00:00
|
|
|
systemctl daemon-reload
|
|
|
|
|
2022-01-16 18:39:46 +00:00
|
|
|
msg "Installing Pi-hole.."
|
|
|
|
curl -sSL https://install.pi-hole.net | bash
|
|
|
|
|
|
|
|
msg "Enable and start cloudflared..."
|
|
|
|
systemctl enable --now cloudflared
|
|
|
|
|
|
|
|
msg "Customizing LXC..."
|
|
|
|
rm /etc/motd
|
|
|
|
rm /etc/update-motd.d/10-uname
|
|
|
|
touch ~/.hushlogin
|
|
|
|
GETTY_OVERRIDE="/etc/systemd/system/container-getty@1.service.d/override.conf"
|
|
|
|
mkdir -p $(dirname $GETTY_OVERRIDE)
|
|
|
|
cat << EOF > $GETTY_OVERRIDE
|
|
|
|
[Service]
|
|
|
|
ExecStart=
|
|
|
|
ExecStart=-/sbin/agetty --autologin root --noclear --keep-baud tty%I 115200,38400,9600 \$TERM
|
|
|
|
EOF
|
|
|
|
systemctl daemon-reload
|
|
|
|
systemctl restart $(basename $(dirname $GETTY_OVERRIDE) | sed 's/\.d//')
|
|
|
|
|
|
|
|
msg "Cleanup..."
|
|
|
|
rm -rf /pihole_cloudflared_setup.sh /var/{cache,log}/* /var/lib/apt/lists/*
|