#!/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.." 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 CLOUDFLARED_CONF="/etc/default/cloudflared" CLOUDFLARED_SERVICE="/etc/systemd/system/cloudflared.service" 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 cat << EOF > $CLOUDFLARED_SERVICE [Unit] Description=cloudflared DNS over HTTPS proxy After=syslog.target network-online.target [Service] Type=simple User=cloudflared EnvironmentFile=/etc/default/cloudflared ExecStart=/usr/local/bin/cloudflared proxy-dns $CLOUDFLARED_OPTS Restart=on-failure RestartSec=10 KillMode=process [Install] WantedBy=multi-user.target EOF systemctl daemon-reload 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/*