Simplify pihole -v (#5517)
This commit is contained in:
commit
13676c40ca
|
@ -8,6 +8,10 @@
|
||||||
# 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.
|
||||||
|
|
||||||
|
# Ignore warning about `local` being undefinded in POSIX
|
||||||
|
# shellcheck disable=SC3043
|
||||||
|
# https://github.com/koalaman/shellcheck/wiki/SC3043#exceptions
|
||||||
|
|
||||||
# Source the versions file poupulated by updatechecker.sh
|
# Source the versions file poupulated by updatechecker.sh
|
||||||
cachedVersions="/etc/pihole/versions"
|
cachedVersions="/etc/pihole/versions"
|
||||||
|
|
||||||
|
@ -21,118 +25,34 @@ else
|
||||||
. "$cachedVersions"
|
. "$cachedVersions"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
getLocalVersion() {
|
main() {
|
||||||
case ${1} in
|
local details
|
||||||
"Pi-hole" ) echo "${CORE_VERSION:=N/A}";;
|
details=false
|
||||||
"web" ) echo "${WEB_VERSION:=N/A}";;
|
|
||||||
"FTL" ) echo "${FTL_VERSION:=N/A}";;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
getLocalHash() {
|
# Automatically show detailed information if
|
||||||
case ${1} in
|
# at least one of the components is not on master branch
|
||||||
"Pi-hole" ) echo "${CORE_HASH:=N/A}";;
|
if [ ! "${CORE_BRANCH}" = "master" ] || [ ! "${WEB_BRANCH}" = "master" ] || [ ! "${FTL_BRANCH}" = "master" ] ; then
|
||||||
"web" ) echo "${WEB_HASH:=N/A}";;
|
details=true
|
||||||
"FTL" ) echo "${FTL_HASH:=N/A}";;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
getRemoteHash(){
|
|
||||||
case ${1} in
|
|
||||||
"Pi-hole" ) echo "${GITHUB_CORE_HASH:=N/A}";;
|
|
||||||
"web" ) echo "${GITHUB_WEB_HASH:=N/A}";;
|
|
||||||
"FTL" ) echo "${GITHUB_FTL_HASH:=N/A}";;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
getRemoteVersion(){
|
|
||||||
case ${1} in
|
|
||||||
"Pi-hole" ) echo "${GITHUB_CORE_VERSION:=N/A}";;
|
|
||||||
"web" ) echo "${GITHUB_WEB_VERSION:=N/A}";;
|
|
||||||
"FTL" ) echo "${GITHUB_FTL_VERSION:=N/A}";;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
getLocalBranch(){
|
|
||||||
case ${1} in
|
|
||||||
"Pi-hole" ) echo "${CORE_BRANCH:=N/A}";;
|
|
||||||
"web" ) echo "${WEB_BRANCH:=N/A}";;
|
|
||||||
"FTL" ) echo "${FTL_BRANCH:=N/A}";;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
versionOutput() {
|
|
||||||
|
|
||||||
[ "$2" = "-c" ] || [ "$2" = "--current" ] || [ -z "$2" ] && current=$(getLocalVersion "${1}") && branch=$(getLocalBranch "${1}")
|
|
||||||
[ "$2" = "-l" ] || [ "$2" = "--latest" ] || [ -z "$2" ] && latest=$(getRemoteVersion "${1}")
|
|
||||||
if [ "$2" = "--hash" ]; then
|
|
||||||
[ "$3" = "-c" ] || [ "$3" = "--current" ] || [ -z "$3" ] && curHash=$(getLocalHash "${1}") && branch=$(getLocalBranch "${1}")
|
|
||||||
[ "$3" = "-l" ] || [ "$3" = "--latest" ] || [ -z "$3" ] && latHash=$(getRemoteHash "${1}") && branch=$(getLocalBranch "${1}")
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# We do not want to show the branch name when we are on master,
|
if [ "${details}" = true ]; then
|
||||||
# blank out the variable in this case
|
echo "Core"
|
||||||
if [ "$branch" = "master" ]; then
|
echo " Version is ${CORE_VERSION:=N/A} (Latest: ${GITHUB_CORE_VERSION:=N/A})"
|
||||||
branch=""
|
echo " Branch is ${CORE_BRANCH:=N/A}"
|
||||||
|
echo " Hash is ${CORE_HASH:=N/A} (Latest: ${GITHUB_CORE_HASH:=N/A})"
|
||||||
|
echo "Web"
|
||||||
|
echo " Version is ${WEB_VERSION:=N/A} (Latest: ${GITHUB_WEB_VERSION:=N/A})"
|
||||||
|
echo " Branch is ${WEB_BRANCH:=N/A}"
|
||||||
|
echo " Hash is ${WEB_HASH:=N/A} (Latest: ${GITHUB_WEB_HASH:=N/A})"
|
||||||
|
echo "FTL"
|
||||||
|
echo " Version is ${FTL_VERSION:=N/A} (Latest: ${GITHUB_FTL_VERSION:=N/A})"
|
||||||
|
echo " Branch is ${FTL_BRANCH:=N/A}"
|
||||||
|
echo " Hash is ${FTL_HASH:=N/A} (Latest: ${GITHUB_FTL_HASH:=N/A})"
|
||||||
else
|
else
|
||||||
branch="$branch "
|
echo "Core version is ${CORE_VERSION:=N/A} (Latest: ${GITHUB_CORE_VERSION:=N/A})"
|
||||||
|
echo "Web version is ${WEB_VERSION:=N/A} (Latest: ${GITHUB_WEB_VERSION:=N/A})"
|
||||||
|
echo "FTL version is ${FTL_VERSION:=N/A} (Latest: ${GITHUB_FTL_VERSION:=N/A})"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -n "$current" ] && [ -n "$latest" ]; then
|
|
||||||
output="${1} version is $branch$current (Latest: $latest)"
|
|
||||||
elif [ -n "$current" ] && [ -z "$latest" ]; then
|
|
||||||
output="Current ${1} version is $branch$current"
|
|
||||||
elif [ -z "$current" ] && [ -n "$latest" ]; then
|
|
||||||
output="Latest ${1} version is $latest"
|
|
||||||
elif [ -n "$curHash" ] && [ -n "$latHash" ]; then
|
|
||||||
output="Local ${1} hash is $curHash (Remote: $latHash)"
|
|
||||||
elif [ -n "$curHash" ] && [ -z "$latHash" ]; then
|
|
||||||
output="Current local ${1} hash is $curHash"
|
|
||||||
elif [ -z "$curHash" ] && [ -n "$latHash" ]; then
|
|
||||||
output="Latest remote ${1} hash is $latHash"
|
|
||||||
elif [ -z "$curHash" ] && [ -z "$latHash" ]; then
|
|
||||||
output="Hashes for ${1} not available"
|
|
||||||
else
|
|
||||||
errorOutput
|
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
[ -n "$output" ] && echo " $output"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
errorOutput() {
|
main
|
||||||
echo " Invalid Option! Try 'pihole -v --help' for more information."
|
|
||||||
exit 1
|
|
||||||
}
|
|
||||||
|
|
||||||
defaultOutput() {
|
|
||||||
versionOutput "Pi-hole" "$@"
|
|
||||||
versionOutput "web" "$@"
|
|
||||||
versionOutput "FTL" "$@"
|
|
||||||
}
|
|
||||||
|
|
||||||
helpFunc() {
|
|
||||||
echo "Usage: pihole -v [repo | option] [option]
|
|
||||||
Example: 'pihole -v -p -l'
|
|
||||||
Show Pi-hole, Web Console & FTL versions
|
|
||||||
|
|
||||||
Repositories:
|
|
||||||
-p, --pihole Only retrieve info regarding Pi-hole repository
|
|
||||||
-w, --web Only retrieve info regarding web repository
|
|
||||||
-f, --ftl Only retrieve info regarding FTL repository
|
|
||||||
|
|
||||||
Options:
|
|
||||||
-c, --current Return the current version
|
|
||||||
-l, --latest Return the latest version
|
|
||||||
--hash Return the GitHub hash from your local repositories
|
|
||||||
-h, --help Show this help dialog"
|
|
||||||
exit 0
|
|
||||||
}
|
|
||||||
|
|
||||||
case "${1}" in
|
|
||||||
"-p" | "--pihole" ) shift; versionOutput "Pi-hole" "$@";;
|
|
||||||
"-w" | "--web" ) shift; versionOutput "web" "$@";;
|
|
||||||
"-f" | "--ftl" ) shift; versionOutput "FTL" "$@";;
|
|
||||||
"-h" | "--help" ) helpFunc;;
|
|
||||||
* ) defaultOutput "$@";;
|
|
||||||
esac
|
|
||||||
|
|
|
@ -34,10 +34,6 @@ _pihole() {
|
||||||
opts_update="--check-only"
|
opts_update="--check-only"
|
||||||
COMPREPLY=( $(compgen -W "${opts_update}" -- ${cur}) )
|
COMPREPLY=( $(compgen -W "${opts_update}" -- ${cur}) )
|
||||||
;;
|
;;
|
||||||
"version")
|
|
||||||
opts_version="\--web \--current \--ftl \--hash \--latest \--pihole"
|
|
||||||
COMPREPLY=( $(compgen -W "${opts_version}" -- ${cur}) )
|
|
||||||
;;
|
|
||||||
"core"|"admin"|"ftl")
|
"core"|"admin"|"ftl")
|
||||||
if [[ "$prev2" == "checkout" ]]; then
|
if [[ "$prev2" == "checkout" ]]; then
|
||||||
opts_checkout="master dev"
|
opts_checkout="master dev"
|
||||||
|
|
6
pihole
6
pihole
|
@ -140,8 +140,7 @@ uninstallFunc() {
|
||||||
}
|
}
|
||||||
|
|
||||||
versionFunc() {
|
versionFunc() {
|
||||||
shift
|
exec "${PI_HOLE_SCRIPT_DIR}"/version.sh
|
||||||
exec "${PI_HOLE_SCRIPT_DIR}"/version.sh "$@"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
restartDNS() {
|
restartDNS() {
|
||||||
|
@ -508,7 +507,6 @@ Options:
|
||||||
-up, updatePihole Update Pi-hole subsystems
|
-up, updatePihole Update Pi-hole subsystems
|
||||||
Add '--check-only' to exit script before update is performed.
|
Add '--check-only' to exit script before update is performed.
|
||||||
-v, version Show installed versions of Pi-hole, Web Interface & FTL
|
-v, version Show installed versions of Pi-hole, Web Interface & FTL
|
||||||
Add '-h' for more info on version usage
|
|
||||||
uninstall Uninstall Pi-hole from your system
|
uninstall Uninstall Pi-hole from your system
|
||||||
status Display the running status of Pi-hole subsystems
|
status Display the running status of Pi-hole subsystems
|
||||||
enable Enable Pi-hole subsystems
|
enable Enable Pi-hole subsystems
|
||||||
|
@ -531,7 +529,7 @@ fi
|
||||||
need_root=1
|
need_root=1
|
||||||
case "${1}" in
|
case "${1}" in
|
||||||
"-h" | "help" | "--help" ) helpFunc;;
|
"-h" | "help" | "--help" ) helpFunc;;
|
||||||
"-v" | "version" ) versionFunc "$@";;
|
"-v" | "version" ) versionFunc;;
|
||||||
"-c" | "chronometer" ) chronometerFunc "$@";;
|
"-c" | "chronometer" ) chronometerFunc "$@";;
|
||||||
"-q" | "query" ) queryFunc "$@";;
|
"-q" | "query" ) queryFunc "$@";;
|
||||||
"status" ) statusFunc "$2";;
|
"status" ) statusFunc "$2";;
|
||||||
|
|
Loading…
Reference in New Issue