Pi-hole checkout feature
This commit is contained in:
parent
e0e9ebbe74
commit
8a14a63d5d
|
@ -0,0 +1,163 @@
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
# Pi-hole: A black hole for Internet advertisements
|
||||||
|
# (c) 2017 Pi-hole, LLC (https://pi-hole.net)
|
||||||
|
# Network-wide ad blocking via your own hardware.
|
||||||
|
#
|
||||||
|
# Checkout other branches than master
|
||||||
|
#
|
||||||
|
# This file is copyright under the latest version of the EUPL.
|
||||||
|
# Please see LICENSE file for your rights under this license.
|
||||||
|
|
||||||
|
readonly WEB_INTERFACE_GIT_URL="https://github.com/pi-hole/AdminLTE.git"
|
||||||
|
readonly WEB_INTERFACE_DIR="/var/www/html/admin"
|
||||||
|
readonly PI_HOLE_GIT_URL="https://github.com/pi-hole/pi-hole.git"
|
||||||
|
readonly PI_HOLE_FILES_DIR="/etc/.pihole"
|
||||||
|
|
||||||
|
is_repo() {
|
||||||
|
# Use git to check if directory is currently under VCS, return the value
|
||||||
|
local directory="${1}"
|
||||||
|
local curdir
|
||||||
|
local rc
|
||||||
|
|
||||||
|
curdir="${PWD}"
|
||||||
|
cd "${directory}" || return 1
|
||||||
|
# Capture any possible output
|
||||||
|
git status --short &> /dev/null
|
||||||
|
rc=$?
|
||||||
|
cd "${curdir}" || return 1
|
||||||
|
return $rc
|
||||||
|
}
|
||||||
|
|
||||||
|
fully_fetch_repo() {
|
||||||
|
# Add upstream branches to shallow clone
|
||||||
|
local directory="${1}"
|
||||||
|
local curdir
|
||||||
|
local rc
|
||||||
|
|
||||||
|
curdir="${PWD}"
|
||||||
|
cd "${directory}" || return 1
|
||||||
|
git remote set-branches origin '*' || return 1
|
||||||
|
git fetch --quiet || return 1
|
||||||
|
cd "${curdir}" || return 1
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
get_available_branches(){
|
||||||
|
# Return available branches
|
||||||
|
local directory="${1}"
|
||||||
|
local curdir
|
||||||
|
|
||||||
|
curdir="${PWD}"
|
||||||
|
cd "${directory}" || return 1
|
||||||
|
# Get reachable remote branches
|
||||||
|
git remote show origin | grep 'tracked' | sed 's/tracked//;s/ //g'
|
||||||
|
cd "${curdir}" || return 1
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
checkout_pull_branch() {
|
||||||
|
# Check out specified branch
|
||||||
|
local directory="${1}"
|
||||||
|
local branch="${2}"
|
||||||
|
local curdir
|
||||||
|
|
||||||
|
curdir="${PWD}"
|
||||||
|
cd "${directory}" || return 1
|
||||||
|
git checkout "${branch}"
|
||||||
|
git pull
|
||||||
|
cd "${curdir}" || return 1
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
warning1() {
|
||||||
|
echo "::: Note that changing the branch is a severe change of your Pi-hole system."
|
||||||
|
echo "::: This is not supported unless one of the developers explicitly asks you to do this!"
|
||||||
|
read -r -p "::: Have you read and understood this? [y/N] " response
|
||||||
|
case ${response} in
|
||||||
|
[yY][eE][sS]|[yY])
|
||||||
|
echo "::: Continuing."
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "::: Aborting."
|
||||||
|
return 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
checkout()
|
||||||
|
{
|
||||||
|
local corebranches
|
||||||
|
local webbranches
|
||||||
|
|
||||||
|
# Avoid globbing
|
||||||
|
set -f
|
||||||
|
|
||||||
|
#This is unlikely
|
||||||
|
if ! is_repo "${PI_HOLE_FILES_DIR}" || ! is_repo "${WEB_INTERFACE_DIR}" ; then
|
||||||
|
echo "::: Critical Error: One or more Pi-Hole repos are missing from your system!"
|
||||||
|
echo "::: Please re-run the install script from https://github.com/pi-hole/pi-hole"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ! warning1 ; then
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo -n "::: Fetching remote branches for Pi-hole core from ${PI_HOLE_GIT_URL} ... "
|
||||||
|
if ! fully_fetch_repo "${PI_HOLE_FILES_DIR}" ; then
|
||||||
|
echo "::: Fetching all branches for Pi-hole core repo failed!"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
corebranches=($(get_available_branches "${PI_HOLE_FILES_DIR}"))
|
||||||
|
echo " done!"
|
||||||
|
echo "::: ${#corebranches[@]} branches available"
|
||||||
|
echo ":::"
|
||||||
|
|
||||||
|
echo -n "::: Fetching remote branches for the web interface from ${WEB_INTERFACE_GIT_URL} ... "
|
||||||
|
if ! fully_fetch_repo "${WEB_INTERFACE_DIR}" ; then
|
||||||
|
echo "::: Fetching all branches for Pi-hole web interface repo failed!"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
webbranches=($(get_available_branches "${WEB_INTERFACE_DIR}"))
|
||||||
|
echo " done!"
|
||||||
|
echo "::: ${#webbranches[@]} branches available"
|
||||||
|
echo ":::"
|
||||||
|
|
||||||
|
if [[ "${2}" == "dev" ]] ; then
|
||||||
|
# Shortcut to check out development version
|
||||||
|
echo "::: Shortcut \"dev\" detected - checking out development / devel branches ..."
|
||||||
|
echo "::: Pi-hole core"
|
||||||
|
checkout_pull_branch "${PI_HOLE_FILES_DIR}" "development"
|
||||||
|
echo "::: Web interface"
|
||||||
|
checkout_pull_branch "${WEB_INTERFACE_DIR}" "devel"
|
||||||
|
echo "::: done!"
|
||||||
|
elif [[ "${2}" == "core" ]] ; then
|
||||||
|
# Have to user chosing the branch he wants
|
||||||
|
if ! (for e in "${corebranches[@]}"; do [[ "$e" == "${3}" ]] && exit 0; done); then
|
||||||
|
echo "::: Requested branch \"${3}\" is not available!"
|
||||||
|
echo "::: Available branches for core are:"
|
||||||
|
for e in "${corebranches[@]}"; do echo "::: $e"; done
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
checkout_pull_branch "${PI_HOLE_FILES_DIR}" "${3}"
|
||||||
|
elif [[ "${2}" == "web" ]] ; then
|
||||||
|
# Have to user chosing the branch he wants
|
||||||
|
if ! (for e in "${webbranches[@]}"; do [[ "$e" == "${3}" ]] && exit 0; done); then
|
||||||
|
echo "::: Requested branch \"${3}\" is not available!"
|
||||||
|
echo "::: Available branches for web are:"
|
||||||
|
for e in "${webbranches[@]}"; do echo "::: $e"; done
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
checkout_pull_branch "${WEB_INTERFACE_DIR}" "${3}"
|
||||||
|
else
|
||||||
|
echo "::: Requested option \"${2}\" is not available!"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Force updating everything
|
||||||
|
echo "::: Running installer to upgrade your installation"
|
||||||
|
/etc/.pihole/automated\ install/basic-install.sh --unattended || echo "Unable to complete update, contact Pi-hole" && exit 1
|
||||||
|
|
||||||
|
exit 0
|
||||||
|
}
|
|
@ -3,7 +3,7 @@ _pihole() {
|
||||||
COMPREPLY=()
|
COMPREPLY=()
|
||||||
cur="${COMP_WORDS[COMP_CWORD]}"
|
cur="${COMP_WORDS[COMP_CWORD]}"
|
||||||
prev="${COMP_WORDS[COMP_CWORD-1]}"
|
prev="${COMP_WORDS[COMP_CWORD-1]}"
|
||||||
opts="admin blacklist chronometer debug disable enable flush help logging query reconfigure restartdns setupLCD status tail uninstall updateGravity updatePihole version whitelist"
|
opts="admin blacklist chronometer debug disable enable flush help logging query reconfigure restartdns setupLCD status tail uninstall updateGravity updatePihole version whitelist checkout"
|
||||||
|
|
||||||
COMPREPLY=( $(compgen -W "${opts}" -- ${cur}) )
|
COMPREPLY=( $(compgen -W "${opts}" -- ${cur}) )
|
||||||
return 0
|
return 0
|
||||||
|
|
10
pihole
10
pihole
|
@ -8,9 +8,8 @@
|
||||||
# This file is copyright under the latest version of the EUPL.
|
# This file is copyright under the latest version of the EUPL.
|
||||||
# Please see LICENSE file for your rights under this license.
|
# Please see LICENSE file for your rights under this license.
|
||||||
|
|
||||||
|
readonly PI_HOLE_SCRIPT_DIR="/opt/pihole"
|
||||||
|
|
||||||
|
|
||||||
PI_HOLE_SCRIPT_DIR="/opt/pihole"
|
|
||||||
readonly wildcardlist="/etc/dnsmasq.d/03-pihole-wildcard.conf"
|
readonly wildcardlist="/etc/dnsmasq.d/03-pihole-wildcard.conf"
|
||||||
# Must be root to use this tool
|
# Must be root to use this tool
|
||||||
if [[ ! $EUID -eq 0 ]];then
|
if [[ ! $EUID -eq 0 ]];then
|
||||||
|
@ -280,6 +279,11 @@ tailFunc() {
|
||||||
exit 0
|
exit 0
|
||||||
}
|
}
|
||||||
|
|
||||||
|
piholeCheckoutFunc() {
|
||||||
|
source "${PI_HOLE_SCRIPT_DIR}"/piholeCheckout.sh
|
||||||
|
checkout "$@"
|
||||||
|
}
|
||||||
|
|
||||||
helpFunc() {
|
helpFunc() {
|
||||||
cat << EOM
|
cat << EOM
|
||||||
::: Control all PiHole specific functions!
|
::: Control all PiHole specific functions!
|
||||||
|
@ -313,6 +317,7 @@ helpFunc() {
|
||||||
::: Blocking can also be disabled only temporarily, e.g.,
|
::: Blocking can also be disabled only temporarily, e.g.,
|
||||||
::: 'pihole disable 5m' - will disable blocking for 5 minutes
|
::: 'pihole disable 5m' - will disable blocking for 5 minutes
|
||||||
::: restartdns Restart dnsmasq
|
::: restartdns Restart dnsmasq
|
||||||
|
::: checkout Check out different branches
|
||||||
EOM
|
EOM
|
||||||
exit 0
|
exit 0
|
||||||
}
|
}
|
||||||
|
@ -343,5 +348,6 @@ case "${1}" in
|
||||||
"restartdns" ) restartDNS;;
|
"restartdns" ) restartDNS;;
|
||||||
"-a" | "admin" ) webpageFunc "$@";;
|
"-a" | "admin" ) webpageFunc "$@";;
|
||||||
"-t" | "tail" ) tailFunc;;
|
"-t" | "tail" ) tailFunc;;
|
||||||
|
"checkout" ) piholeCheckoutFunc "$@";;
|
||||||
* ) helpFunc;;
|
* ) helpFunc;;
|
||||||
esac
|
esac
|
||||||
|
|
Loading…
Reference in New Issue