From 4ce673b9272fd17f734a20041090e8e1898db0db Mon Sep 17 00:00:00 2001 From: ipitio <21136719+ipitio@users.noreply.github.com> Date: Tue, 5 Mar 2024 05:47:22 -0500 Subject: [PATCH] refactor download (#90) * refactor download --- advanced/Scripts/speedtestmod/mod.sh | 117 +++++++++------------------ advanced/Scripts/webpage.sh | 11 ++- 2 files changed, 45 insertions(+), 83 deletions(-) diff --git a/advanced/Scripts/speedtestmod/mod.sh b/advanced/Scripts/speedtestmod/mod.sh index 849e777ef4..b59544d255 100755 --- a/advanced/Scripts/speedtestmod/mod.sh +++ b/advanced/Scripts/speedtestmod/mod.sh @@ -17,39 +17,6 @@ help() { echo "If no option is specified, the latest version of the Mod will be (re)installed." } -setTags() { - local path=${1:-} - local name=${2:-} - local url=${3:-} - local branch="${4:-master}" - - if [ ! -z "$path" ]; then - cd "$path" - git fetch origin $branch:refs/remotes/origin/$branch -q - if [[ "$url" != *"arevindh"* ]]; then - git tag -l | xargs git tag -d >/dev/null 2>&1 - fi - git fetch --tags -f -q - latestTag=$(git ls-remote --tags "$url" | awk -F/ '{print $3}' | grep -v '\^{}' | sort -V | tail -n1) - fi - - if [[ "$url" != *"arevindh"* ]] && [ ! -z "$name" ]; then - local localTag=$(pihole -v | grep "$name" | cut -d ' ' -f 6) - - if [ "$localTag" == "HEAD" ]; then - localTag=$(pihole -v | grep "$name" | cut -d ' ' -f 7) - fi - - if [[ "$localTag" == *.* ]] && [[ "$localTag" < "$latestTag" ]]; then - latestTag=$localTag - - if [ -f "$(git rev-parse --git-dir)"/shallow ]; then - git fetch --unshallow - fi - fi - fi -} - download() { local path=$1 local name=$2 @@ -58,62 +25,52 @@ download() { local branch="${5:-master}" local dest=$path/$name - if [ ! -d "$dest" ]; then # replicate - cd "$path" - rm -rf "$name" - git clone --depth=1 -b "$branch" "$url" "$name" - git config --global --add safe.directory "$dest" - setTags "$name" "$src" "$url" "$branch" + if [ ! -d "$dest" ]; then + git clone --depth=1 -b "$branch" "$url" "$dest" elif [ ! -d "$dest/.git" ]; then mv -f "$dest" "$dest.old" download "$@" - else # replace - git config --global --add safe.directory "$dest" - cd "$dest" - - if [ ! -z "$src" ]; then - if [ "$url" != "old" ]; then - git remote -v | grep -q "old" || git remote rename origin old - git remote -v | grep -q "origin" && git remote remove origin - git remote add -t "$branch" origin "$url" - elif [ -d .git/refs/remotes/old ]; then - git remote remove origin - git remote rename old origin - git clean -ffdx - fi - fi - - setTags "$dest" "$src" "$url" "$branch" - git reset --hard origin/"$branch" - git checkout -B "$branch" - - if git rev-parse --verify "$branch" >/dev/null 2>&1; then - git branch -u "origin/$branch" "$branch" - else - git checkout --track "origin/$branch" - fi + return fi - if [ "$branch" == "master" ] && [[ "$url" != *"ipitio"* ]]; then - if [[ "$url" == *"arevindh"* ]]; then - if ! last_tag_before_current=$(git describe --tags --abbrev=0 HEAD 2>/dev/null); then - last_tag_before_current=$latestTag - fi - else - # Get last tag before/at $latestTag installed - last_tag_before_current=$(git tag -l | grep '^v' | grep -v 'vDev' | sort -V | awk -v latestTag="$latestTag" '$1 <= latestTag' | tail -n1) + cd "$dest" + git config --global --add safe.directory "$dest" + + if [ "$url" != "old" ]; then + git remote -v | grep -q "old" || git remote rename origin old + git remote -v | grep -q "origin" && git remote remove origin + git remote add -t "$branch" origin "$url" + elif [ -d .git/refs/remotes/old ]; then + git remote remove origin + git remote rename old origin + git clean -ffdx + fi - # If no such tag is found, fall back to $latestTag - if [ -z "$last_tag_before_current" ]; then - last_tag_before_current=$latestTag - fi + git fetch origin $branch:refs/remotes/origin/$branch -q + git reset --hard origin/"$branch" + git checkout -B "$branch" + git rev-parse --verify "$branch" >/dev/null 2>&1 && git branch -u "origin/$branch" "$branch" || git checkout --track "origin/$branch" + git tag -l | xargs git tag -d >/dev/null 2>&1 + git fetch --tags -f -q + [ "$url" == "old" ] || latestTag=$(git ls-remote --tags "$url" | awk -F/ '{print $3}' | grep -v '\^{}' | sort -V | tail -n1) + [[ "${latestTag:-}" == *.* ]] || latestTag=$(git describe --tags $(git rev-list --tags --max-count=1)) + + if [[ "$url" != *"arevindh"* ]] && [ ! -z "$src" ] && [[ "$url" != *"ipitio"* ]] && ! git remote -v | grep -q "old.*ipitio"; then + local localVersion=$(pihole -v | grep "$src" | cut -d ' ' -f 6) + [ "$localVersion" != "HEAD" ] || localVersion=$(pihole -v | grep "$src" | cut -d ' ' -f 7) + + # if the local version is less than the latest tag then use the tag before it + if [[ "$localVersion" == *.* ]] && [[ "$localVersion" < "$latestTag" ]]; then + [ "$url" == "old" ] || latestTag=$(git ls-remote --tags "$url" | awk -F/ '{print $3}' | grep -v '\^{}' | sort -V | awk -v lv="$localVersion" '$1 < lv {print $1}' | tail -n1) + [[ "$latestTag" == *.* ]] || latestTag=$(git tag -l | grep -v '\^{}' | sort -V | awk -v lv="$localVersion" '$1 < lv {print $1}' | tail -n1) + [ ! -f "$(git rev-parse --git-dir)"/shallow ] || git fetch --unshallow fi + fi - # Check if HEAD is already at this tag, if not, check out the tag - if [ "$(git rev-parse HEAD)" != "$(git rev-parse $last_tag_before_current 2>/dev/null)" ]; then - git -c advice.detachedHead=false checkout "$last_tag_before_current" - fi + if [ "$branch" == "master" ] && [[ "$url" != *"ipitio"* ]] && [ "$(git rev-parse HEAD)" != "$(git rev-parse $latestTag 2>/dev/null)" ]; then + git -c advice.detachedHead=false checkout "$latestTag" fi + cd .. } diff --git a/advanced/Scripts/webpage.sh b/advanced/Scripts/webpage.sh index f9ec218d51..20dcec8039 100755 --- a/advanced/Scripts/webpage.sh +++ b/advanced/Scripts/webpage.sh @@ -623,13 +623,18 @@ schedule=\$(grep "SPEEDTESTSCHEDULE" "$setupVars" | cut -f2 -d"=") SKIP_MOD=true source /opt/pihole/speedtestmod/mod.sh -# if schedule is set and interval is "nan", get latest release and set the speedtest interval to the schedule +# if "pihole -v" includes "N/A", update the mod +if [[ "\$(/usr/local/bin/pihole -v)" == *"N/A"* ]]; then + download /etc/pihole speedtest https://github.com/arevindh/pihole-speedtest + pihole updatechecker +fi + +# if schedule is set and interval is "nan", set the speedtest interval to the schedule if [[ "\$interval_seconds" == "nan" ]]; then if [[ "\${schedule-}" =~ ^([0-9]+(\.[0-9]*)?|\.[0-9]+)$ ]]; then /usr/local/bin/pihole -a -s "\$schedule" fi - download /etc/pihole speedtest https://github.com/arevindh/pihole-speedtest - pihole updatechecker + exit 0 fi