|
|
|
@ -8,67 +8,98 @@
|
|
|
|
|
# This file is copyright under the latest version of the EUPL.
|
|
|
|
|
# Please see LICENSE file for your rights under this license.
|
|
|
|
|
|
|
|
|
|
# Variables
|
|
|
|
|
DEFAULT="-1"
|
|
|
|
|
PHGITDIR="/etc/.pihole/"
|
|
|
|
|
WEBGITDIR="/var/www/html/admin/"
|
|
|
|
|
|
|
|
|
|
getLocalVersion() {
|
|
|
|
|
# Get the tagged version of the local repository
|
|
|
|
|
local directory="${1}"
|
|
|
|
|
local version
|
|
|
|
|
|
|
|
|
|
# Flags:
|
|
|
|
|
latest=false
|
|
|
|
|
current=false
|
|
|
|
|
cd "${directory}" || { echo "${DEFAULT}"; return 1; }
|
|
|
|
|
version=$(git describe --tags --always || \
|
|
|
|
|
echo "${DEFAULT}")
|
|
|
|
|
if [[ "${version}" =~ ^v ]]; then
|
|
|
|
|
echo "${version}"
|
|
|
|
|
elif [[ "${version}" == "${DEFAULT}" ]]; then
|
|
|
|
|
echo "ERROR"
|
|
|
|
|
return 1
|
|
|
|
|
else
|
|
|
|
|
echo "Untagged"
|
|
|
|
|
fi
|
|
|
|
|
return 0
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
DEFAULT="-1"
|
|
|
|
|
getLocalHash() {
|
|
|
|
|
# Get the short hash of the local repository
|
|
|
|
|
local directory="${1}"
|
|
|
|
|
local hash
|
|
|
|
|
|
|
|
|
|
normalOutput() {
|
|
|
|
|
piholeVersion=$(cd /etc/.pihole/ && git describe --tags --abbrev=0)
|
|
|
|
|
webVersion=$(cd /var/www/html/admin/ && git describe --tags --abbrev=0)
|
|
|
|
|
cd "${directory}" || { echo "${DEFAULT}"; return 1; }
|
|
|
|
|
hash=$(git rev-parse --short HEAD || \
|
|
|
|
|
echo "${DEFAULT}")
|
|
|
|
|
if [[ "${hash}" == "${DEFAULT}" ]]; then
|
|
|
|
|
echo "ERROR"
|
|
|
|
|
return 1
|
|
|
|
|
else
|
|
|
|
|
echo "${hash}"
|
|
|
|
|
fi
|
|
|
|
|
return 0
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
piholeVersionLatest=$(curl -s https://api.github.com/repos/pi-hole/pi-hole/releases/latest | grep -Po '"tag_name":.*?[^\\]",' | perl -pe 's/"tag_name": "//; s/^"//; s/",$//')
|
|
|
|
|
webVersionLatest=$(curl -s https://api.github.com/repos/pi-hole/AdminLTE/releases/latest | grep -Po '"tag_name":.*?[^\\]",' | perl -pe 's/"tag_name": "//; s/^"//; s/",$//')
|
|
|
|
|
getRemoteVersion(){
|
|
|
|
|
# Get the version from the remote origin
|
|
|
|
|
local daemon="${1}"
|
|
|
|
|
local version
|
|
|
|
|
|
|
|
|
|
echo "::: Pi-hole version is ${piholeVersion} (Latest version is ${piholeVersionLatest:-${DEFAULT}})"
|
|
|
|
|
echo "::: Web-Admin version is ${webVersion} (Latest version is ${webVersionLatest:-${DEFAULT}})"
|
|
|
|
|
version=$(curl --silent --fail https://api.github.com/repos/pi-hole/${daemon}/releases/latest | \
|
|
|
|
|
awk -F: '$1 ~/tag_name/ { print $2 }' | \
|
|
|
|
|
tr -cd '[[:alnum:]]._-')
|
|
|
|
|
if [[ "${version}" =~ ^v ]]; then
|
|
|
|
|
echo "${version}"
|
|
|
|
|
else
|
|
|
|
|
echo "ERROR"
|
|
|
|
|
return 1
|
|
|
|
|
fi
|
|
|
|
|
return 0
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#PHHASHLATEST=$(curl -s https://api.github.com/repos/pi-hole/pi-hole/commits/master | \
|
|
|
|
|
# grep sha | \
|
|
|
|
|
# head -n1 | \
|
|
|
|
|
# awk -F ' ' '{ print $2 }' | \
|
|
|
|
|
# tr -cd '[[:alnum:]]._-')
|
|
|
|
|
|
|
|
|
|
#WEBHASHLATEST=$(curl -s https://api.github.com/repos/pi-hole/AdminLTE/commits/master | \
|
|
|
|
|
# grep sha | \
|
|
|
|
|
# head -n1 | \
|
|
|
|
|
# awk -F ' ' '{ print $2 }' | \
|
|
|
|
|
# tr -cd '[[:alnum:]]._-')
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
normalOutput() {
|
|
|
|
|
echo "::: Pi-hole version is $(getLocalVersion "${PHGITDIR}") (Latest version is $(getRemoteVersion pi-hole))"
|
|
|
|
|
echo "::: Web-Admin version is $(getLocalVersion "${WEBGITDIR}") (Latest version is $(getRemoteVersion AdminLTE))"
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
webOutput() {
|
|
|
|
|
for var in "$@"; do
|
|
|
|
|
case "${var}" in
|
|
|
|
|
"-l" | "--latest" ) latest=true;;
|
|
|
|
|
"-c" | "--current" ) current=true;;
|
|
|
|
|
* ) echo "::: Invalid Option!"; exit 1;
|
|
|
|
|
esac
|
|
|
|
|
done
|
|
|
|
|
|
|
|
|
|
if [[ "${latest}" == true && "${current}" == false ]]; then
|
|
|
|
|
webVersionLatest=$(curl -s https://api.github.com/repos/pi-hole/AdminLTE/releases/latest | grep -Po '"tag_name":.*?[^\\]",' | perl -pe 's/"tag_name": "//; s/^"//; s/",$//')
|
|
|
|
|
echo "${webVersionLatest:--1}"
|
|
|
|
|
elif [[ "${latest}" == false && "${current}" == true ]]; then
|
|
|
|
|
webVersion=$(cd /var/www/html/admin/ && git describe --tags --abbrev=0)
|
|
|
|
|
echo "${webVersion}"
|
|
|
|
|
else
|
|
|
|
|
webVersion=$(cd /var/www/html/admin/ && git describe --tags --abbrev=0)
|
|
|
|
|
webVersionLatest=$(curl -s https://api.github.com/repos/pi-hole/AdminLTE/releases/latest | grep -Po '"tag_name":.*?[^\\]",' | perl -pe 's/"tag_name": "//; s/^"//; s/",$//')
|
|
|
|
|
echo "::: Web-Admin version is ${webVersion} (Latest version is ${webVersionLatest:-${DEFAULT}})"
|
|
|
|
|
fi
|
|
|
|
|
case "${1}" in
|
|
|
|
|
"-l" | "--latest" ) echo $(getRemoteVersion AdminLTE);;
|
|
|
|
|
"-c" | "--current" ) echo $(getLocalVersion "${WEBGITDIR}");;
|
|
|
|
|
"-h" | "--hash" ) echo $(getLocalHash "${WEBGITDIR}");;
|
|
|
|
|
* ) echo "::: Invalid Option!"; exit 1;
|
|
|
|
|
esac
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
coreOutput() {
|
|
|
|
|
for var in "$@"; do
|
|
|
|
|
case "${var}" in
|
|
|
|
|
"-l" | "--latest" ) latest=true;;
|
|
|
|
|
"-c" | "--current" ) current=true;;
|
|
|
|
|
* ) echo "::: Invalid Option!"; exit 1;
|
|
|
|
|
esac
|
|
|
|
|
done
|
|
|
|
|
|
|
|
|
|
if [[ "${latest}" == true && "${current}" == false ]]; then
|
|
|
|
|
piholeVersionLatest=$(curl -s https://api.github.com/repos/pi-hole/pi-hole/releases/latest | grep -Po '"tag_name":.*?[^\\]",' | perl -pe 's/"tag_name": "//; s/^"//; s/",$//')
|
|
|
|
|
echo "${piholeVersionLatest:--1}"
|
|
|
|
|
elif [[ "${latest}" == false && "${current}" == true ]]; then
|
|
|
|
|
piholeVersion=$(cd /etc/.pihole/ && git describe --tags --abbrev=0)
|
|
|
|
|
echo "${piholeVersion}"
|
|
|
|
|
else
|
|
|
|
|
piholeVersion=$(cd /etc/.pihole/ && git describe --tags --abbrev=0)
|
|
|
|
|
piholeVersionLatest=$(curl -s https://api.github.com/repos/pi-hole/pi-hole/releases/latest | grep -Po '"tag_name":.*?[^\\]",' | perl -pe 's/"tag_name": "//; s/^"//; s/",$//')
|
|
|
|
|
echo "::: Pi-hole version is ${piholeVersion} (Latest version is ${piholeVersionLatest:-${DEFAULT}})"
|
|
|
|
|
fi
|
|
|
|
|
case "${1}" in
|
|
|
|
|
"-l" | "--latest" ) echo $(getRemoteVersion pi-hole);;
|
|
|
|
|
"-c" | "--current" ) echo $(getLocalVersion "${PHGITDIR}");;
|
|
|
|
|
"-h" | "--hash" ) echo $(getLocalHash "${PHGITDIR}");;
|
|
|
|
|
* ) echo "::: Invalid Option!"; exit 1;
|
|
|
|
|
esac
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
helpFunc() {
|
|
|
|
@ -93,10 +124,8 @@ if [[ $# = 0 ]]; then
|
|
|
|
|
normalOutput
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
for var in "$@"; do
|
|
|
|
|
case "${var}" in
|
|
|
|
|
"-a" | "--admin" ) shift; webOutput "$@";;
|
|
|
|
|
"-p" | "--pihole" ) shift; coreOutput "$@" ;;
|
|
|
|
|
"-h" | "--help" ) helpFunc;;
|
|
|
|
|
esac
|
|
|
|
|
done
|
|
|
|
|
case "${1}" in
|
|
|
|
|
"-a" | "--admin" ) shift; webOutput "$@";;
|
|
|
|
|
"-p" | "--pihole" ) shift; coreOutput "$@" ;;
|
|
|
|
|
"-h" | "--help" ) helpFunc;;
|
|
|
|
|
esac
|
|
|
|
|