Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/pi-hole/pi-hole.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDL6ER <dl6er@dl6er.de>2017-03-08 15:16:40 +0300
committerDL6ER <dl6er@dl6er.de>2017-03-08 15:16:40 +0300
commit8a14a63d5d81a9bfbab049a6568596c55cfa692b (patch)
tree1dcc21500547869ab2b375ac908511d517b5ad3d
parente0e9ebbe74b8ba5361bc4a1657871ea190d66049 (diff)
Pi-hole checkout feature
-rw-r--r--advanced/Scripts/piholeCheckout.sh163
-rw-r--r--advanced/bash-completion/pihole2
-rwxr-xr-xpihole10
3 files changed, 172 insertions, 3 deletions
diff --git a/advanced/Scripts/piholeCheckout.sh b/advanced/Scripts/piholeCheckout.sh
new file mode 100644
index 00000000..7d1df415
--- /dev/null
+++ b/advanced/Scripts/piholeCheckout.sh
@@ -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
+}
diff --git a/advanced/bash-completion/pihole b/advanced/bash-completion/pihole
index 05baa820..fc8f2162 100644
--- a/advanced/bash-completion/pihole
+++ b/advanced/bash-completion/pihole
@@ -3,7 +3,7 @@ _pihole() {
COMPREPLY=()
cur="${COMP_WORDS[COMP_CWORD]}"
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}) )
return 0
diff --git a/pihole b/pihole
index 324c03c9..38c7160f 100755
--- a/pihole
+++ b/pihole
@@ -8,9 +8,8 @@
# This file is copyright under the latest version of the EUPL.
# 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"
# Must be root to use this tool
if [[ ! $EUID -eq 0 ]];then
@@ -280,6 +279,11 @@ tailFunc() {
exit 0
}
+piholeCheckoutFunc() {
+ source "${PI_HOLE_SCRIPT_DIR}"/piholeCheckout.sh
+ checkout "$@"
+}
+
helpFunc() {
cat << EOM
::: Control all PiHole specific functions!
@@ -313,6 +317,7 @@ helpFunc() {
::: Blocking can also be disabled only temporarily, e.g.,
::: 'pihole disable 5m' - will disable blocking for 5 minutes
::: restartdns Restart dnsmasq
+::: checkout Check out different branches
EOM
exit 0
}
@@ -343,5 +348,6 @@ case "${1}" in
"restartdns" ) restartDNS;;
"-a" | "admin" ) webpageFunc "$@";;
"-t" | "tail" ) tailFunc;;
+ "checkout" ) piholeCheckoutFunc "$@";;
* ) helpFunc;;
esac