Add validate_repo script and begin 'mangle' toolkit

This commit is contained in:
Neil Hanlon 2021-07-06 13:06:40 -04:00
parent a7ec11e33a
commit 091e3d1d08
Signed by untrusted user: neil
GPG Key ID: 705BC21EC3C70F34
3 changed files with 65 additions and 0 deletions

1
mangle/README.md Normal file
View File

@ -0,0 +1 @@
# Mirrormanager Mangling tools

8
mangle/common Normal file
View File

@ -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

56
mangle/validate_repos Executable file
View File

@ -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