From 091e3d1d0887654d987106e3f6e9ab53e0409c0f Mon Sep 17 00:00:00 2001 From: Neil Hanlon Date: Tue, 6 Jul 2021 13:06:40 -0400 Subject: [PATCH] Add validate_repo script and begin 'mangle' toolkit --- mangle/README.md | 1 + mangle/common | 8 +++++++ mangle/validate_repos | 56 +++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 65 insertions(+) create mode 100644 mangle/README.md create mode 100644 mangle/common create mode 100755 mangle/validate_repos diff --git a/mangle/README.md b/mangle/README.md new file mode 100644 index 0000000..6711deb --- /dev/null +++ b/mangle/README.md @@ -0,0 +1 @@ +# Mirrormanager Mangling tools diff --git a/mangle/common b/mangle/common new file mode 100644 index 0000000..c6c28e8 --- /dev/null +++ b/mangle/common @@ -0,0 +1,8 @@ +# vim: set syntax=bash + +# To be sourced by scripts as needed + +# The mirrorlist url +MIRRORLIST_BASE="http://mirrors.rockylinux.org/mirrorlist" + +MIRROR_DISPLAY_COUNT=1 diff --git a/mangle/validate_repos b/mangle/validate_repos new file mode 100755 index 0000000..ecfd90e --- /dev/null +++ b/mangle/validate_repos @@ -0,0 +1,56 @@ +#!/usr/bin/env bash + +# Source mangle vars +source $(dirname "$0")/common +# Source sync / migrate vars for repository information +source $(dirname "$0")/../sync/common + +# How many +ARG1=${1} +NUM=$(( ${ARG1:-${MIRROR_DISPLAY_COUNT}} + 2)) + +print_result () { + if [[ "${result}" =~ "invalid repo or arch" ]]; then + printf "# repo = %s arch = %s\n" "${_repo}" "${arch}" + printf "# FAIL: invalid repo or arch\n\n" + else + printf "%s\n# number of mirrors returned: %s\n\n" "$( echo "$result" | head -${NUM})" "$(( $(echo "$result" | wc -l) - 2 ))" + fi +} + +cleanup_repo () { + # plus is actually 'rockyplus'. Others may as well(?) + if [[ "${repo}" =~ ^(plus)$ ]]; then + repo="rocky${repo}" + elif [[ "${repo}" =~ ^(nfv)$ ]]; then + repo="${repo^^}" + else + repo="${repo}" + fi + return 0 +} + +for repo in "${ALL_REPOS[@]}"; do + + # Business logic must be done, sometimes... + cleanup_repo "${repo}" + + # Print a nice header + printf "================\n${repo}\n================\n" + for arch in "${ARCHES[@]}" "source"; do + if [[ "${arch}" == "source" ]]; then + _repo="${repo}-8-source" + else + _repo="${repo}-8" + fi + + result=$(curl -s "${MIRRORLIST_BASE}?repo=${_repo}&arch=${arch}&time&country=global") + print_result + + if [[ "${arch}" =~ ^(x86_|aarch)64$ ]]; then + result=$(curl -s "${MIRRORLIST_BASE}?repo=${_repo}-debug&arch=${arch}&time&country=global") + print_result + fi + done + echo +done