89 lines
3.0 KiB
Bash
89 lines
3.0 KiB
Bash
#!/bin/bash -ex
|
|
# shellcheck disable=SC2034
|
|
|
|
mkdir -p /etc/pihole/
|
|
mkdir -p /var/run/pihole
|
|
|
|
CORE_LOCAL_REPO=/etc/.pihole
|
|
WEB_LOCAL_REPO=/var/www/html/admin
|
|
|
|
setupVars=/etc/pihole/setupVars.conf
|
|
|
|
detect_arch() {
|
|
DETECTED_ARCH=$(dpkg --print-architecture)
|
|
S6_ARCH=$DETECTED_ARCH
|
|
case $DETECTED_ARCH in
|
|
amd64)
|
|
S6_ARCH="x86_64";;
|
|
armel)
|
|
S6_ARCH="arm";;
|
|
armhf)
|
|
S6_ARCH="armhf";;
|
|
arm64)
|
|
S6_ARCH="aarch64";;
|
|
i386)
|
|
S6_ARCH="i686";;
|
|
esac
|
|
}
|
|
|
|
|
|
# Helps to have some additional tools in the dev image when debugging
|
|
if [[ "${PIHOLE_DOCKER_TAG}" = 'nightly' || "${PIHOLE_DOCKER_TAG}" = 'dev' ]]; then
|
|
apt-get update
|
|
apt-get install --no-install-recommends -y nano less
|
|
rm -rf /var/lib/apt/lists/*
|
|
fi
|
|
|
|
detect_arch
|
|
|
|
curl -L -s "https://github.com/just-containers/s6-overlay/releases/download/${S6_OVERLAY_VERSION}/s6-overlay-noarch.tar.xz" | tar Jxpf - -C /
|
|
curl -L -s "https://github.com/just-containers/s6-overlay/releases/download/${S6_OVERLAY_VERSION}/s6-overlay-${S6_ARCH}.tar.xz" | tar Jxpf - -C /
|
|
|
|
# Preseed variables to assist with using --unattended install
|
|
{
|
|
echo "PIHOLE_INTERFACE=eth0"
|
|
echo "IPV4_ADDRESS=0.0.0.0"
|
|
echo "IPV6_ADDRESS=0:0:0:0:0:0"
|
|
echo "PIHOLE_DNS_1=8.8.8.8"
|
|
echo "QUERY_LOGGING=true"
|
|
echo "INSTALL_WEB_SERVER=true"
|
|
echo "INSTALL_WEB_INTERFACE=true"
|
|
echo "LIGHTTPD_ENABLED=true"
|
|
}>> "${setupVars}"
|
|
source $setupVars
|
|
|
|
export USER=pihole
|
|
|
|
export PIHOLE_SKIP_OS_CHECK=true
|
|
|
|
# Run the installer in unattended mode using the preseeded variables above and --reconfigure so that local repos are not updated
|
|
curl -sSL https://install.pi-hole.net | bash -sex -- --unattended
|
|
|
|
# At this stage, if we are building a :nightly tag, then switch the Pi-hole install to dev versions
|
|
if [[ "${PIHOLE_DOCKER_TAG}" = 'nightly' ]]; then
|
|
yes | pihole checkout dev
|
|
fi
|
|
|
|
sed -i '/^WEBPASSWORD/d' /etc/pihole/setupVars.conf
|
|
|
|
# sed a new function into the `pihole` script just above the `helpFunc()` function for later use.
|
|
sed -i $'s/helpFunc() {/unsupportedFunc() {\\\n echo "Function not supported in Docker images"\\\n exit 0\\\n}\\\n\\\nhelpFunc() {/g' /usr/local/bin/pihole
|
|
|
|
# Replace a few of the `pihole` options with calls to `unsupportedFunc`:
|
|
# pihole -up / pihole updatePihole
|
|
sed -i $'s/)\s*updatePiholeFunc/) unsupportedFunc/g' /usr/local/bin/pihole
|
|
# pihole uninstall
|
|
sed -i $'s/)\s*uninstallFunc/) unsupportedFunc/g' /usr/local/bin/pihole
|
|
# pihole -r / pihole reconfigure
|
|
sed -i $'s/)\s*reconfigurePiholeFunc/) unsupportedFunc/g' /usr/local/bin/pihole
|
|
|
|
# Move macvendor.db to root dir and symlink it back into /etc/pihole. See https://github.com/pi-hole/docker-pi-hole/issues/1137
|
|
# If user goes on to bind monunt this directory to their host, then we can easily ensure macvendor.db is the latest
|
|
# (it is otherwise only updated when FTL is updated, which doesn't happen as part of the normal course of running this image)
|
|
mv /etc/pihole/macvendor.db /macvendor.db
|
|
ln -s /macvendor.db /etc/pihole/macvendor.db
|
|
|
|
if [ ! -f /.piholeFirstBoot ]; then
|
|
touch /.piholeFirstBoot
|
|
fi
|
|
echo 'Docker install successful' |