whitelines

This commit is contained in:
zenobit 2023-03-14 06:27:18 +01:00
parent f702581806
commit 3f2bc926c4

140
quickget
View file

@ -91,11 +91,13 @@ function validate_release() {
local DISPLAY_NAME="" local DISPLAY_NAME=""
local RELEASE_GENERATOR="" local RELEASE_GENERATOR=""
local RELEASES="" local RELEASES=""
DISPLAY_NAME="$(pretty_name "${OS}")" DISPLAY_NAME="$(pretty_name "${OS}")"
case ${OS} in case ${OS} in
*ubuntu*) RELEASE_GENERATOR="releases_ubuntu";; *ubuntu*) RELEASE_GENERATOR="releases_ubuntu";;
*) RELEASE_GENERATOR="${1}";; *) RELEASE_GENERATOR="${1}";;
esac esac
RELEASES=$(${RELEASE_GENERATOR}) RELEASES=$(${RELEASE_GENERATOR})
if [[ "${RELEASES}" != *"${RELEASE}"* ]]; then if [[ "${RELEASES}" != *"${RELEASE}"* ]]; then
echo -e "ERROR! ${DISPLAY_NAME} ${RELEASE} is not a supported release.\n" echo -e "ERROR! ${DISPLAY_NAME} ${RELEASE} is not a supported release.\n"
@ -121,15 +123,18 @@ function list_csv() {
local RELEASE local RELEASE
local SVG local SVG
local HAS_ZSYNC=0 local HAS_ZSYNC=0
# Check if zsync is available # Check if zsync is available
if command -v zsync &>/dev/null; then if command -v zsync &>/dev/null; then
HAS_ZSYNC=1 HAS_ZSYNC=1
fi fi
if command -v aria2c &>/dev/null; then if command -v aria2c &>/dev/null; then
DL="aria2c" DL="aria2c"
elif command -v wget &>/dev/null; then elif command -v wget &>/dev/null; then
DL="wget" DL="wget"
fi fi
echo "Display Name,OS,Release,Option,Downloader,PNG,SVG" echo "Display Name,OS,Release,Option,Downloader,PNG,SVG"
for OS in $(os_support); do for OS in $(os_support); do
DISPLAY_NAME="$(pretty_name "${OS}")" DISPLAY_NAME="$(pretty_name "${OS}")"
@ -140,6 +145,7 @@ function list_csv() {
fi fi
PNG="https://quickemu-project.github.io/quickemu-icons/png/${FUNC}/${FUNC}-quickemu-white-pinkbg.png" PNG="https://quickemu-project.github.io/quickemu-icons/png/${FUNC}/${FUNC}-quickemu-white-pinkbg.png"
SVG="https://quickemu-project.github.io/quickemu-icons/svg/${FUNC}/${FUNC}-quickemu-white-pinkbg.svg" SVG="https://quickemu-project.github.io/quickemu-icons/svg/${FUNC}/${FUNC}-quickemu-white-pinkbg.svg"
for RELEASE in $("releases_${FUNC}"); do for RELEASE in $("releases_${FUNC}"); do
if [ "${OS}" == "ubuntu" ] && [ "${RELEASE}" == "canary" ] && [ ${HAS_ZSYNC} -eq 1 ]; then if [ "${OS}" == "ubuntu" ] && [ "${RELEASE}" == "canary" ] && [ ${HAS_ZSYNC} -eq 1 ]; then
DOWNLOADER="zsync" DOWNLOADER="zsync"
@ -148,6 +154,7 @@ function list_csv() {
else else
DOWNLOADER="${DL}" DOWNLOADER="${DL}"
fi fi
# If the OS has an editions_() function, use it. # If the OS has an editions_() function, use it.
if [[ $(type -t "editions_${OS}") == function ]]; then if [[ $(type -t "editions_${OS}") == function ]]; then
for OPTION in $(editions_"${OS}"); do for OPTION in $(editions_"${OS}"); do
@ -234,11 +241,7 @@ function os_support() {
} }
function releases_agarimos() { function releases_agarimos() {
echo latest echo 20230305 20230303 20230225 20230216
}
function editions_agarimos() {
echo plasma gnome xfce
} }
function releases_alma() { function releases_alma() {
@ -277,12 +280,9 @@ function editions_arcolinux() {
echo large small echo large small
} }
function releases_batocera() {
echo 32 33 34
}
function releases_blendos() { function releases_blendos() {
curl -s https://api.github.com/repos/blend-os/blendOS/releases |grep tag_name | grep -o -E '[[:digit:]]+\.[[:digit:]]+' curl -s https://api.github.com/repos/blend-os/blendOS/releases |grep tag_name | grep -o -E '[[:digit:]]+\.[[:digit:]]+'
} }
function releases_cachyos() { function releases_cachyos() {
@ -312,6 +312,7 @@ function editions_cereus() {
function releases_debian() { function releases_debian() {
DEBCURRENT=$(wget -q https://cdimage.debian.org/debian-cd/ -O- |grep '\.[0-9]/'|cut -d\> -f9|cut -d\/ -f1) DEBCURRENT=$(wget -q https://cdimage.debian.org/debian-cd/ -O- |grep '\.[0-9]/'|cut -d\> -f9|cut -d\/ -f1)
local DEBOLD=$(wget -q https://cdimage.debian.org/cdimage/archive/ -O- |grep -e '>[1-9][0-9]\.'|grep -v 'live' | cut -d\> -f9|cut -d\/ -f1 ) local DEBOLD=$(wget -q https://cdimage.debian.org/cdimage/archive/ -O- |grep -e '>[1-9][0-9]\.'|grep -v 'live' | cut -d\> -f9|cut -d\/ -f1 )
echo ${DEBOLD} ${DEBCURRENT} echo ${DEBOLD} ${DEBCURRENT}
} }
@ -400,10 +401,6 @@ function editions_fvoid() {
echo lxqt echo lxqt
} }
function releases_gabeeos() {
echo latest
}
function releases_garuda() { function releases_garuda() {
echo latest echo latest
} }
@ -597,6 +594,7 @@ function releases_truenas-scale() {
function releases_ubuntu() { function releases_ubuntu() {
local LTS_SUPPORT="14.04 16.04 18.04 20.04 22.04" local LTS_SUPPORT="14.04 16.04 18.04 20.04 22.04"
local INTERIM_SUPPORT="22.10" local INTERIM_SUPPORT="22.10"
case "${OS}" in case "${OS}" in
kubuntu|lubuntu|ubuntukylin|\ kubuntu|lubuntu|ubuntukylin|\
ubuntu-mate|ubuntustudio|xubuntu) ubuntu-mate|ubuntustudio|xubuntu)
@ -611,12 +609,15 @@ function releases_ubuntu() {
INTERIM_SUPPORT="${INTERIM_SUPPORT}" INTERIM_SUPPORT="${INTERIM_SUPPORT}"
;; ;;
esac esac
INTERIM_SUPPORT="${INTERIM_SUPPORT/22.10 /}" INTERIM_SUPPORT="${INTERIM_SUPPORT/22.10 /}"
if [ "${OS}" == "ubuntu-unity" ]; then if [ "${OS}" == "ubuntu-unity" ]; then
echo ${INTERIM_SUPPORT} \ echo ${INTERIM_SUPPORT} \
daily-live \ daily-live \
daily-canary \ daily-canary \
; ;
else else
echo ${LTS_SUPPORT} \ echo ${LTS_SUPPORT} \
${INTERIM_SUPPORT} \ ${INTERIM_SUPPORT} \
@ -696,6 +697,7 @@ function check_hash() {
local hash_algo="" local hash_algo=""
iso="${VM_PATH}/${1}" iso="${VM_PATH}/${1}"
hash="${2}" hash="${2}"
# Guess the hash algorithm by the hash length # Guess the hash algorithm by the hash length
case ${#hash} in case ${#hash} in
32) hash_algo=md5sum;; 32) hash_algo=md5sum;;
@ -705,6 +707,7 @@ function check_hash() {
*) echo "WARNING! Can't guess hash algorithm, not checking ${iso} hash." *) echo "WARNING! Can't guess hash algorithm, not checking ${iso} hash."
return;; return;;
esac esac
echo -n "Checking ${iso} with ${hash_algo}... " echo -n "Checking ${iso} with ${hash_algo}... "
if ! echo "${hash} ${iso}" | ${hash_algo} --check --status; then if ! echo "${hash} ${iso}" | ${hash_algo} --check --status; then
echo "ERROR!" echo "ERROR!"
@ -719,15 +722,18 @@ function web_get() {
local DIR="${2}" local DIR="${2}"
local FILE="" local FILE=""
local URL="${1}" local URL="${1}"
if [ -n "${3}" ]; then if [ -n "${3}" ]; then
FILE="${3}" FILE="${3}"
else else
FILE="${URL##*/}" FILE="${URL##*/}"
fi fi
if ! mkdir -p "${DIR}" 2>/dev/null; then if ! mkdir -p "${DIR}" 2>/dev/null; then
echo "ERROR! Unable to create directory ${DIR}" echo "ERROR! Unable to create directory ${DIR}"
exit 1 exit 1
fi fi
if command -v aria2c &>/dev/null; then if command -v aria2c &>/dev/null; then
if ! aria2c --stderr -x16 --continue=true --summary-interval=0 --download-result=hide --console-log-level=error "${URL}" -o "${DIR}/${FILE}"; then if ! aria2c --stderr -x16 --continue=true --summary-interval=0 --download-result=hide --console-log-level=error "${URL}" -o "${DIR}/${FILE}"; then
echo #Necessary as aria2c in suppressed mode does not have new lines echo #Necessary as aria2c in suppressed mode does not have new lines
@ -755,15 +761,18 @@ function zsync_get() {
else else
OUT="${FILE}" OUT="${FILE}"
fi fi
if ! mkdir -p "${DIR}" 2>/dev/null; then if ! mkdir -p "${DIR}" 2>/dev/null; then
echo "ERROR! Unable to create directory ${DIR}" echo "ERROR! Unable to create directory ${DIR}"
exit 1 exit 1
fi fi
# Only force http for zsync - not earlier because we might fall through here # Only force http for zsync - not earlier because we might fall through here
if ! zsync "${URL/https/http}.zsync" -i "${DIR}/${OUT}" -o "${DIR}/${OUT}" 2>/dev/null; then if ! zsync "${URL/https/http}.zsync" -i "${DIR}/${OUT}" -o "${DIR}/${OUT}" 2>/dev/null; then
echo "ERROR! Failed to download ${URL/https/http}.zsync" echo "ERROR! Failed to download ${URL/https/http}.zsync"
exit 1 exit 1
fi fi
if [ -e "${DIR}/${OUT}.zs-old" ]; then if [ -e "${DIR}/${OUT}.zs-old" ]; then
rm "${DIR}/${OUT}.zs-old" rm "${DIR}/${OUT}.zs-old"
fi fi
@ -784,6 +793,7 @@ function make_vm_config() {
local IMAGE_TYPE="" local IMAGE_TYPE=""
local GUEST="" local GUEST=""
local SEC_BOOT="" local SEC_BOOT=""
IMAGE_FILE="${1}" IMAGE_FILE="${1}"
ISO_FILE="${2}" ISO_FILE="${2}"
case "${OS}" in case "${OS}" in
@ -821,11 +831,13 @@ function make_vm_config() {
GUEST="linux" GUEST="linux"
IMAGE_TYPE="iso";; IMAGE_TYPE="iso";;
esac esac
if [ -n "${EDITION}" ]; then if [ -n "${EDITION}" ]; then
CONF_FILE="${OS}-${RELEASE}-${EDITION}.conf" CONF_FILE="${OS}-${RELEASE}-${EDITION}.conf"
else else
CONF_FILE="${OS}-${RELEASE}.conf" CONF_FILE="${OS}-${RELEASE}.conf"
fi fi
if [ ! -e "${CONF_FILE}" ]; then if [ ! -e "${CONF_FILE}" ]; then
echo "Making ${CONF_FILE}" echo "Making ${CONF_FILE}"
cat << EOF > "${CONF_FILE}" cat << EOF > "${CONF_FILE}"
@ -839,6 +851,7 @@ EOF
if [ -n "${ISO_FILE}" ]; then if [ -n "${ISO_FILE}" ]; then
echo "fixed_iso=\"${VM_PATH}/${ISO_FILE}\"" >> "${CONF_FILE}" echo "fixed_iso=\"${VM_PATH}/${ISO_FILE}\"" >> "${CONF_FILE}"
fi fi
# OS specific tweaks # OS specific tweaks
case ${OS} in case ${OS} in
alma|centos-stream|endless|oraclelinux|popos|rockylinux) alma|centos-stream|endless|oraclelinux|popos|rockylinux)
@ -904,20 +917,25 @@ function get_agarimos() {
local HASH="" local HASH=""
local ISO="" local ISO=""
local URL="" local URL=""
case ${EDITION} in case ${RELEASE} in
gnome) 20230305)
URL="https://sourceforge.net/projects/agarimos/files/Gnome" URL="https://sourceforge.net/projects/agarimos/files/Gnome"
ISO="AgarimOS-Gnome-Catppuccin-Live-x86_64-6.1.15_1-20230312.iso" ISO="AgarimOS-Gnome-Catppuccin-Live-x86_64-6.1.14_1-20230305.iso"
;; ;;
plasma) 20230303)
URL="https://sourceforge.net/projects/agarimos/files/Plasma" URL="https://sourceforge.net/projects/agarimos/files/Plasma"
ISO="AgarimOS-Plasma-Dracula-Live-x86_64-6.1.15_1-20230311.iso" ISO="AgarimOS-Plasma-Dracula-Live-x86_64-6.1.14_1-20230303.iso"
;; ;;
xfce) 20230225)
URL="https://sourceforge.net/projects/agarimos/files/XFCE4" URL="https://sourceforge.net/projects/agarimos/files/XFCE4"
ISO="AgarimOS-XFCE4-Catppuccin-Live-x86_64-6.1.15_1-20230311.iso" ISO="AgarimOS-XFCE4-Catppuccin-Live-x86_64-6.1.12_1-20230216.iso"
;;
20230216)
URL="https://sourceforge.net/projects/agarimos/files/XFCE4"
ISO="AgarimOS-XFCE4-Catppuccin-Live-6.1.13_1-20230225.iso"
;; ;;
esac esac
HASH=$(wget -q -O- "${URL}/${ISO}.sha256" | cut -d' ' -f1) HASH=$(wget -q -O- "${URL}/${ISO}.sha256" | cut -d' ' -f1)
echo "${URL}/${ISO} ${HASH}" echo "${URL}/${ISO} ${HASH}"
} }
@ -936,6 +954,7 @@ function get_alpine() {
local ISO="" local ISO=""
local URL="" local URL=""
local VERSION="" local VERSION=""
case ${RELEASE} in case ${RELEASE} in
latest) URL="https://dl-cdn.alpinelinux.org/alpine/latest-stable/releases/x86_64";; latest) URL="https://dl-cdn.alpinelinux.org/alpine/latest-stable/releases/x86_64";;
*) URL="https://dl-cdn.alpinelinux.org/alpine/v${RELEASE}/releases/x86_64";; *) URL="https://dl-cdn.alpinelinux.org/alpine/v${RELEASE}/releases/x86_64";;
@ -953,6 +972,7 @@ function get_android() {
local JSON_ALL="" local JSON_ALL=""
local JSON_REL="" local JSON_REL=""
local URL="https://mirrors.gigenet.com/OSDN/android-x86" local URL="https://mirrors.gigenet.com/OSDN/android-x86"
JSON_ALL=$(wget -q -O- "https://www.fosshub.com/Android-x86-old.html" | grep "var settings =" | cut -d'=' -f2-) JSON_ALL=$(wget -q -O- "https://www.fosshub.com/Android-x86-old.html" | grep "var settings =" | cut -d'=' -f2-)
JSON_REL=$(echo "${JSON_ALL}" | jq --arg ver "${OS}-${EDITION}-${RELEASE}" 'first(.pool.f[] | select((.n | startswith($ver)) and (.n | endswith(".iso"))))') JSON_REL=$(echo "${JSON_ALL}" | jq --arg ver "${OS}-${EDITION}-${RELEASE}" 'first(.pool.f[] | select((.n | startswith($ver)) and (.n | endswith(".iso"))))')
ISO=$(echo "${JSON_REL}" | jq -r .n) ISO=$(echo "${JSON_REL}" | jq -r .n)
@ -980,6 +1000,7 @@ function get_archcraft() {
local HASH="" local HASH=""
local URL="" local URL=""
local TMPURL="" local TMPURL=""
TMPURL=$(wget -q -S -O- --max-redirect=0 "https://sourceforge.net/projects/archcraft/files/latest/download" 2>&1 | grep -i Location | cut -d' ' -f4) TMPURL=$(wget -q -S -O- --max-redirect=0 "https://sourceforge.net/projects/archcraft/files/latest/download" 2>&1 | grep -i Location | cut -d' ' -f4)
URL=${TMPURL%\?*} URL=${TMPURL%\?*}
echo "${URL} ${HASH}" echo "${URL} ${HASH}"
@ -994,20 +1015,20 @@ function get_arcolinux() {
echo "${URL}/${ISO} ${HASH}" echo "${URL}/${ISO} ${HASH}"
} }
function get_batocera() {
local HASH=""
local URL="https://mirrors.o2switch.fr/batocera/x86_64/stable/last"
local ISO="$(curl -sl ${URL}/ | grep -e 'batocera.*img.gz'|cut -d\" -f2)"
local CURRENT_RELEASE=$(echo "${ISO}"| cut -d\- -f3)
}
function get_blendos() { function get_blendos() {
local HASH="" local HASH=""
local URL="$(curl -s https://api.github.com/repos/blend-os/blendOS/releases |grep 'browser_download_url'|grep ${RELEASE} | grep -o '\"http.*\.iso\"'| cut -d\" -f 2| head -1)" local URL="$(curl -s https://api.github.com/repos/blend-os/blendOS/releases |grep 'browser_download_url'|grep ${RELEASE} | grep -o '\"http.*\.iso\"'| cut -d\" -f 2| head -1)"
HASH=$(curl -s "${URL}.sha256sum" | cut -d' ' -f1) HASH=$(curl -s "${URL}.sha256sum" | cut -d' ' -f1)
echo "${URL} ${HASH}" echo "${URL} ${HASH}"
}
function get_batocera() {
local HASH=""
local URL="https://mirrors.o2switch.fr/batocera/x86_64/stable/last"
local ISO="$(curl -sl ${URL}/ | grep -e 'batocera.*img.gz'|cut -d\" -f2)"
local CURRENT_RELEASE=$(echo "${ISO}"| cut -d\- -f3)
case ${RELEASE} in case ${RELEASE} in
"${CURRENT_RELEASE}") #Current release ${CURRENT_RELEASE}) #Current release
URL+="" URL+=""
;; ;;
*) *)
@ -1041,6 +1062,7 @@ function get_centos-stream() {
HASH=$(wget -q -O- ${URL}/${ISO}.SHA256SUM | grep "SHA256 (${ISO}" | cut -d' ' -f4) HASH=$(wget -q -O- ${URL}/${ISO}.SHA256SUM | grep "SHA256 (${ISO}" | cut -d' ' -f4)
;; ;;
esac esac
echo "${URL}/${ISO} ${HASH}" echo "${URL}/${ISO} ${HASH}"
} }
@ -1073,16 +1095,19 @@ function get_debian() {
local HASH="" local HASH=""
local ISO="debian-live-${RELEASE}-amd64-${EDITION}.iso" local ISO="debian-live-${RELEASE}-amd64-${EDITION}.iso"
local URL="" local URL=""
DEBCURRENT=$(wget -q https://cdimage.debian.org/debian-cd/ -O- |grep '\.[0-9]/'|cut -d\> -f9|cut -d\/ -f1) DEBCURRENT=$(wget -q https://cdimage.debian.org/debian-cd/ -O- |grep '\.[0-9]/'|cut -d\> -f9|cut -d\/ -f1)
case ${RELEASE} in case ${RELEASE} in
"${DEBCURRENT}") URL="https://cdimage.debian.org/debian-cd/${RELEASE}-live/amd64/iso-hybrid";; "${DEBCURRENT}") URL="https://cdimage.debian.org/debian-cd/${RELEASE}-live/amd64/iso-hybrid";;
*) URL="https://cdimage.debian.org/cdimage/archive/${RELEASE}-live/amd64/iso-hybrid/";; *) URL="https://cdimage.debian.org/cdimage/archive/${RELEASE}-live/amd64/iso-hybrid/";;
esac esac
if [ "${EDITION}" == "netinst" ]; then if [ "${EDITION}" == "netinst" ]; then
URL="${URL/-live/}" URL="${URL/-live/}"
URL="${URL/hybrid/cd}" URL="${URL/hybrid/cd}"
ISO="${ISO/-live/}" ISO="${ISO/-live/}"
fi fi
HASH=$(wget -q -O- "${URL}/SHA512SUMS" | grep "${ISO}" | cut -d' ' -f1) HASH=$(wget -q -O- "${URL}/SHA512SUMS" | grep "${ISO}" | cut -d' ' -f1)
echo "${URL}/${ISO} ${HASH}" echo "${URL}/${ISO} ${HASH}"
} }
@ -1093,6 +1118,7 @@ function get_deepin() {
local ISO="deepin-desktop-community-${RELEASE}-amd64.iso" local ISO="deepin-desktop-community-${RELEASE}-amd64.iso"
# deepin-desktop-community-20.3-amd64.iso # deepin-desktop-community-20.3-amd64.iso
local URL="https://cdimage.deepin.com/releases/"${RELEASE} local URL="https://cdimage.deepin.com/releases/"${RELEASE}
# fix iso name # fix iso name
if [[ "${RELEASE}" == *"20" ]] ; then if [[ "${RELEASE}" == *"20" ]] ; then
EDITION="1003" EDITION="1003"
@ -1101,7 +1127,9 @@ function get_deepin() {
EDITION="1010" EDITION="1010"
ISO="deepin-desktop-community-${EDITION}-amd64.iso" ISO="deepin-desktop-community-${EDITION}-amd64.iso"
fi fi
HASH=$(wget -q -O- "${URL}/SHA256SUMS" | grep "${ISO}" | cut -d' ' -f1) HASH=$(wget -q -O- "${URL}/SHA256SUMS" | grep "${ISO}" | cut -d' ' -f1)
#echo "${URL}/${ISO} ${HASH}" #echo "${URL}/${ISO} ${HASH}"
web_get "${URL}/${ISO}" "${VM_PATH}" web_get "${URL}/${ISO}" "${VM_PATH}"
check_hash "${ISO}" "${HASH}" check_hash "${ISO}" "${HASH}"
@ -1112,6 +1140,7 @@ function get_devuan() {
local HASH="" local HASH=""
local ISO="" local ISO=""
local URL="https://files.devuan.org/devuan_${RELEASE}/desktop-live" local URL="https://files.devuan.org/devuan_${RELEASE}/desktop-live"
case ${RELEASE} in case ${RELEASE} in
beowulf) ISO="devuan_${RELEASE}_3.1.1_amd64_desktop-live.iso";; beowulf) ISO="devuan_${RELEASE}_3.1.1_amd64_desktop-live.iso";;
chimaera) ISO="devuan_${RELEASE}_4.0.2_amd64_desktop-live.iso";; chimaera) ISO="devuan_${RELEASE}_4.0.2_amd64_desktop-live.iso";;
@ -1160,6 +1189,7 @@ function get_dragonflybsd() {
local HASH="" local HASH=""
local ISO="dfly-x86_64-${RELEASE}_REL.iso" local ISO="dfly-x86_64-${RELEASE}_REL.iso"
local URL="http://mirror-master.dragonflybsd.org/iso-images" local URL="http://mirror-master.dragonflybsd.org/iso-images"
HASH=$(wget -q -O- "${URL}/md5.txt" | grep "(${ISO})" | cut -d' ' -f4) HASH=$(wget -q -O- "${URL}/md5.txt" | grep "(${ISO})" | cut -d' ' -f4)
echo "${URL}/${ISO} ${HASH}" echo "${URL}/${ISO} ${HASH}"
} }
@ -1183,6 +1213,7 @@ function get_endeavouros() {
# Endeavour release names are Capitalized and our $RELEASE is forced to lowercase so we have to revert it # Endeavour release names are Capitalized and our $RELEASE is forced to lowercase so we have to revert it
local ISO="EndeavourOS_${RELEASE@u}.iso" local ISO="EndeavourOS_${RELEASE@u}.iso"
local URL="https://github.com/endeavouros-team/ISO/releases/download/1-EndeavourOS-ISO-releases-archive" local URL="https://github.com/endeavouros-team/ISO/releases/download/1-EndeavourOS-ISO-releases-archive"
HASH=$(wget -q -O- "${URL}/${ISO}.sha512sum" | cut -d' ' -f1) HASH=$(wget -q -O- "${URL}/${ISO}.sha512sum" | cut -d' ' -f1)
echo "${URL}/${ISO} ${HASH}" echo "${URL}/${ISO} ${HASH}"
} }
@ -1222,10 +1253,12 @@ function get_fedora() {
local JSON="" local JSON=""
local URL="" local URL=""
local VARIANT="" local VARIANT=""
case ${EDITION} in case ${EDITION} in
Server|Silverblue|Workstation) VARIANT="${EDITION}";; Server|Silverblue|Workstation) VARIANT="${EDITION}";;
*) VARIANT="Spins";; *) VARIANT="Spins";;
esac esac
JSON=$(wget -q -O- "https://getfedora.org/releases.json" | jq '.[] | select(.variant=="'${VARIANT}'" and .subvariant=="'"${EDITION}"'" and .arch=="x86_64" and .version=="'"${RELEASE}"'")') JSON=$(wget -q -O- "https://getfedora.org/releases.json" | jq '.[] | select(.variant=="'${VARIANT}'" and .subvariant=="'"${EDITION}"'" and .arch=="x86_64" and .version=="'"${RELEASE}"'")')
URL=$(echo "${JSON}" | jq -r '.link' | head -n1) URL=$(echo "${JSON}" | jq -r '.link' | head -n1)
HASH=$(echo "${JSON}" | jq -r '.sha256' | head -n1) HASH=$(echo "${JSON}" | jq -r '.sha256' | head -n1)
@ -1237,6 +1270,7 @@ function get_freebsd() {
local HASH="" local HASH=""
local ISO="FreeBSD-${RELEASE}-RELEASE-amd64-${EDITION}.iso" local ISO="FreeBSD-${RELEASE}-RELEASE-amd64-${EDITION}.iso"
local URL="https://download.freebsd.org/ftp/releases/amd64/amd64/ISO-IMAGES/${RELEASE}" local URL="https://download.freebsd.org/ftp/releases/amd64/amd64/ISO-IMAGES/${RELEASE}"
HASH=$(wget -q -O- "${URL}/CHECKSUM.SHA256-FreeBSD-${RELEASE}-RELEASE-amd64" | grep "${ISO}" | grep -v ".xz" | cut -d' ' -f4) HASH=$(wget -q -O- "${URL}/CHECKSUM.SHA256-FreeBSD-${RELEASE}-RELEASE-amd64" | grep "${ISO}" | grep -v ".xz" | cut -d' ' -f4)
echo "${URL}/${ISO} ${HASH}" echo "${URL}/${ISO} ${HASH}"
} }
@ -1245,6 +1279,7 @@ function get_freedos() {
local HASH="" local HASH=""
local ISO="" local ISO=""
local URL="http://www.ibiblio.org/pub/micro/pc-stuff/freedos/files/distributions/${RELEASE}/official" local URL="http://www.ibiblio.org/pub/micro/pc-stuff/freedos/files/distributions/${RELEASE}/official"
case ${RELEASE} in case ${RELEASE} in
1.2) 1.2)
ISO="FD12CD.iso" ISO="FD12CD.iso"
@ -1255,6 +1290,7 @@ function get_freedos() {
HASH=$(wget -q -O- "${URL}/verify.txt" | grep -A 8 "sha256sum" | grep "${ISO}" | cut -d' ' -f1) HASH=$(wget -q -O- "${URL}/verify.txt" | grep -A 8 "sha256sum" | grep "${ISO}" | cut -d' ' -f1)
;; ;;
esac esac
echo "${URL}/${ISO} ${HASH}" echo "${URL}/${ISO} ${HASH}"
} }
@ -1262,6 +1298,7 @@ function get_fvoid() {
local HASH="" local HASH=""
local URL="" local URL=""
local TMPURL="" local TMPURL=""
TMPURL=$(wget -q -S -O- --max-redirect=0 "https://sourceforge.net/projects/f-void/files/latest/download" 2>&1 | grep -i Location | cut -d' ' -f4) TMPURL=$(wget -q -S -O- --max-redirect=0 "https://sourceforge.net/projects/f-void/files/latest/download" 2>&1 | grep -i Location | cut -d' ' -f4)
URL=${TMPURL%\?*} URL=${TMPURL%\?*}
echo "${URL} ${HASH}" echo "${URL} ${HASH}"
@ -1282,7 +1319,9 @@ function get_garuda() {
local HASH="" local HASH=""
local ISO="" local ISO=""
local URL="https://mirrors.fossho.st/garuda/iso/latest/garuda/" local URL="https://mirrors.fossho.st/garuda/iso/latest/garuda/"
ISO=${EDITION}/latest.iso ISO=${EDITION}/latest.iso
HASH="$(wget -q -O- "${URL}/${ISO}.sha256" | cut -d' ' -f1)" HASH="$(wget -q -O- "${URL}/${ISO}.sha256" | cut -d' ' -f1)"
echo "${URL}/${ISO} ${HASH}" echo "${URL}/${ISO} ${HASH}"
} }
@ -1291,6 +1330,7 @@ function get_gentoo() {
local HASH="" local HASH=""
local ISO="" local ISO=""
local URL="https://mirror.bytemark.co.uk/gentoo/releases/amd64/autobuilds/" local URL="https://mirror.bytemark.co.uk/gentoo/releases/amd64/autobuilds/"
ISO=$(wget -q -O- "${URL}/${RELEASE}-iso.txt" | grep install | cut -d' ' -f1) ISO=$(wget -q -O- "${URL}/${RELEASE}-iso.txt" | grep install | cut -d' ' -f1)
HASH=$( wget -q -O- "${URL}/${ISO}.DIGESTS" | grep iso | grep -v CONTENTS | cut -d' ' -f1) HASH=$( wget -q -O- "${URL}/${ISO}.DIGESTS" | grep iso | grep -v CONTENTS | cut -d' ' -f1)
echo "${URL}/${ISO} ${HASH}" echo "${URL}/${ISO} ${HASH}"
@ -1301,6 +1341,7 @@ function get_ghostbsd() {
local ISO="" local ISO=""
local URL="https://download.ghostbsd.org/releases/amd64/${RELEASE}" local URL="https://download.ghostbsd.org/releases/amd64/${RELEASE}"
local HASH="" local HASH=""
case ${EDITION} in case ${EDITION} in
mate) ISO="GhostBSD-${RELEASE}.iso";; mate) ISO="GhostBSD-${RELEASE}.iso";;
xfce) ISO="GhostBSD-${RELEASE}-XFCE.iso";; xfce) ISO="GhostBSD-${RELEASE}-XFCE.iso";;
@ -1316,6 +1357,7 @@ function get_haiku() {
local URL="http://mirror.rit.edu/haiku/${RELEASE}" # NY, USA local URL="http://mirror.rit.edu/haiku/${RELEASE}" # NY, USA
# local URL="https://mirrors.tnonline.net/haiku/haiku-release/${RELEASE}" # Sweden # local URL="https://mirrors.tnonline.net/haiku/haiku-release/${RELEASE}" # Sweden
# local URL="https://mirror.aarnet.edu.au/pub/haiku/${RELEASE}" # Aus # local URL="https://mirror.aarnet.edu.au/pub/haiku/${RELEASE}" # Aus
HASH=$(wget -q -O- "${URL}/${ISO}.sha256" | grep "${ISO}" | cut -d' ' -f4) HASH=$(wget -q -O- "${URL}/${ISO}.sha256" | grep "${ISO}" | cut -d' ' -f4)
echo "${URL}/${ISO} ${HASH}" echo "${URL}/${ISO} ${HASH}"
} }
@ -1324,6 +1366,7 @@ function get_kali() {
local HASH="" local HASH=""
local ISO="" local ISO=""
local URL="https://cdimage.kali.org/${RELEASE}" local URL="https://cdimage.kali.org/${RELEASE}"
ISO=$(wget -q -O- "${URL}/?C=M;O=D" | grep -o ">kali-linux-.*-installer-amd64.iso" | head -n 1 | cut -c 2-) ISO=$(wget -q -O- "${URL}/?C=M;O=D" | grep -o ">kali-linux-.*-installer-amd64.iso" | head -n 1 | cut -c 2-)
HASH=$(wget -q -O- "${URL}/SHA256SUMS" | grep -v torrent | grep "${ISO}" | cut -d' ' -f1) HASH=$(wget -q -O- "${URL}/SHA256SUMS" | grep -v torrent | grep "${ISO}" | cut -d' ' -f1)
echo "${URL}/${ISO} ${HASH}" echo "${URL}/${ISO} ${HASH}"
@ -1333,6 +1376,7 @@ function get_kdeneon() {
local HASH="" local HASH=""
local ISO="" local ISO=""
local URL="https://files.kde.org/neon/images/${RELEASE}/current" local URL="https://files.kde.org/neon/images/${RELEASE}/current"
ISO=$(wget -q -O- "${URL}/neon-${RELEASE}-current.sha256sum" | cut -d' ' -f3-) ISO=$(wget -q -O- "${URL}/neon-${RELEASE}-current.sha256sum" | cut -d' ' -f3-)
HASH=$(wget -q -O- "${URL}/neon-${RELEASE}-current.sha256sum" | cut -d' ' -f1) HASH=$(wget -q -O- "${URL}/neon-${RELEASE}-current.sha256sum" | cut -d' ' -f1)
echo "${URL}/${ISO} ${HASH}" echo "${URL}/${ISO} ${HASH}"
@ -1350,6 +1394,7 @@ function get_linuxmint() {
local HASH="" local HASH=""
local ISO="linuxmint-${RELEASE}-${EDITION}-64bit.iso" local ISO="linuxmint-${RELEASE}-${EDITION}-64bit.iso"
local URL="https://mirror.bytemark.co.uk/linuxmint/stable/${RELEASE}" local URL="https://mirror.bytemark.co.uk/linuxmint/stable/${RELEASE}"
HASH=$(wget -q -O- "${URL}/sha256sum.txt" | grep "${ISO}" | cut -d' ' -f1) HASH=$(wget -q -O- "${URL}/sha256sum.txt" | grep "${ISO}" | cut -d' ' -f1)
echo "${URL}/${ISO} ${HASH}" echo "${URL}/${ISO} ${HASH}"
} }
@ -1359,6 +1404,7 @@ function get_lmde() {
local HASH="" local HASH=""
local ISO="lmde-${RELEASE}-${EDITION}-64bit.iso" local ISO="lmde-${RELEASE}-${EDITION}-64bit.iso"
local URL="https://mirror.bytemark.co.uk/linuxmint/debian" local URL="https://mirror.bytemark.co.uk/linuxmint/debian"
HASH=$(wget -q -O- "${URL}/sha256sum.txt" | grep "${ISO}" | cut -d' ' -f1) HASH=$(wget -q -O- "${URL}/sha256sum.txt" | grep "${ISO}" | cut -d' ' -f1)
echo "${URL}/${ISO} ${HASH}" echo "${URL}/${ISO} ${HASH}"
} }
@ -1375,10 +1421,12 @@ function get_manjaro() {
local ISO="" local ISO=""
local MANIFESTURL="" local MANIFESTURL=""
local URL="" local URL=""
case ${RELEASE} in case ${RELEASE} in
gnome|kde|xfce) MANIFESTURL="https://gitlab.manjaro.org/webpage/manjaro-homepage/-/raw/master/site/content/downloads/official/${RELEASE}.md";; gnome|kde|xfce) MANIFESTURL="https://gitlab.manjaro.org/webpage/manjaro-homepage/-/raw/master/site/content/downloads/official/${RELEASE}.md";;
budgie|cinnamon|deepin|i3|mate) MANIFESTURL="https://gitlab.manjaro.org/webpage/manjaro-homepage/-/raw/master/site/content/downloads/community/${RELEASE}.md";; budgie|cinnamon|deepin|i3|mate) MANIFESTURL="https://gitlab.manjaro.org/webpage/manjaro-homepage/-/raw/master/site/content/downloads/community/${RELEASE}.md";;
esac esac
URL="$(wget -qO- "${MANIFESTURL}" | grep "Download_x64 =" | cut -d'"' -f2)" URL="$(wget -qO- "${MANIFESTURL}" | grep "Download_x64 =" | cut -d'"' -f2)"
HASH=$(wget -qO- "${MANIFESTURL}" | grep "Download_x64_Checksum =" | cut -d'"' -f2) HASH=$(wget -qO- "${MANIFESTURL}" | grep "Download_x64_Checksum =" | cut -d'"' -f2)
echo "${URL} ${HASH}" echo "${URL} ${HASH}"
@ -1389,6 +1437,7 @@ function get_mxlinux() {
local HASH="" local HASH=""
local ISO="" local ISO=""
local URL="https://sourceforge.net/projects/mx-linux/files/Final/${EDITION}" local URL="https://sourceforge.net/projects/mx-linux/files/Final/${EDITION}"
case ${EDITION} in case ${EDITION} in
Xfce) ISO="MX-${RELEASE}_x64.iso";; Xfce) ISO="MX-${RELEASE}_x64.iso";;
KDE) ISO="MX-${RELEASE}_KDE_x64.iso";; KDE) ISO="MX-${RELEASE}_KDE_x64.iso";;
@ -1435,6 +1484,7 @@ function get_opensuse() {
local HASH="" local HASH=""
local ISO="" local ISO=""
local URL="" local URL=""
if [ "${RELEASE}" == "tumbleweed" ]; then if [ "${RELEASE}" == "tumbleweed" ]; then
ISO="openSUSE-Tumbleweed-DVD-x86_64-Current.iso" ISO="openSUSE-Tumbleweed-DVD-x86_64-Current.iso"
URL="https://download.opensuse.org/tumbleweed/iso" URL="https://download.opensuse.org/tumbleweed/iso"
@ -1458,6 +1508,7 @@ function get_oraclelinux() {
local VER_MAJ=${RELEASE::1} local VER_MAJ=${RELEASE::1}
local VER_MIN=${RELEASE:2:1} local VER_MIN=${RELEASE:2:1}
local URL="https://yum.oracle.com/ISOS/OracleLinux/OL${VER_MAJ}/u${VER_MIN}/x86_64/" local URL="https://yum.oracle.com/ISOS/OracleLinux/OL${VER_MAJ}/u${VER_MIN}/x86_64/"
case ${VER_MAJ} in case ${VER_MAJ} in
7) ISO="OracleLinux-R${VER_MAJ}-U${VER_MIN}-Server-x86_64-dvd.iso";; 7) ISO="OracleLinux-R${VER_MAJ}-U${VER_MIN}-Server-x86_64-dvd.iso";;
*) ISO="OracleLinux-R${VER_MAJ}-U${VER_MIN}-x86_64-dvd.iso";; *) ISO="OracleLinux-R${VER_MAJ}-U${VER_MIN}-x86_64-dvd.iso";;
@ -1480,6 +1531,7 @@ function get_reactos() {
local HASH="" local HASH=""
local URL="" local URL=""
local TMPURL="" local TMPURL=""
TMPURL=$(wget -q -S -O- --max-redirect=0 "https://sourceforge.net/projects/reactos/files/latest/download" 2>&1 | grep -i Location | cut -d' ' -f4) TMPURL=$(wget -q -S -O- --max-redirect=0 "https://sourceforge.net/projects/reactos/files/latest/download" 2>&1 | grep -i Location | cut -d' ' -f4)
URL=${TMPURL%\?*} URL=${TMPURL%\?*}
echo "${URL} ${HASH}" echo "${URL} ${HASH}"
@ -1496,6 +1548,7 @@ function get_rockylinux() {
local HASH="" local HASH=""
local ISO="Rocky-${RELEASE}-x86_64-${EDITION}.iso" local ISO="Rocky-${RELEASE}-x86_64-${EDITION}.iso"
local URL="" local URL=""
case ${RELEASE} in case ${RELEASE} in
9.1) URL="https://download.rockylinux.org/pub/rocky/${RELEASE}/isos/x86_64";; 9.1) URL="https://download.rockylinux.org/pub/rocky/${RELEASE}/isos/x86_64";;
*) URL="http://dl.rockylinux.org/vault/rocky/${RELEASE}/isos/x86_64/";; *) URL="http://dl.rockylinux.org/vault/rocky/${RELEASE}/isos/x86_64/";;
@ -1527,6 +1580,7 @@ function get_slitaz() {
local HASH="" local HASH=""
local ISO="slitaz-rolling-${RELEASE}" local ISO="slitaz-rolling-${RELEASE}"
local URL="http://mirror.slitaz.org/iso/rolling" local URL="http://mirror.slitaz.org/iso/rolling"
case ${RELEASE} in case ${RELEASE} in
preferred) ISO="slitaz-rolling";; preferred) ISO="slitaz-rolling";;
*) ISO="slitaz-rolling-${RELEASE}";; *) ISO="slitaz-rolling-${RELEASE}";;
@ -1540,6 +1594,7 @@ function get_solus() {
local HASH="" local HASH=""
local ISO="Solus-${RELEASE}-${EDITION}.iso" local ISO="Solus-${RELEASE}-${EDITION}.iso"
local URL="https://mirrors.rit.edu/solus/images/${RELEASE}" local URL="https://mirrors.rit.edu/solus/images/${RELEASE}"
HASH=$(wget -q -O- "${URL}/${ISO}.sha256sum" | cut -d' ' -f1) HASH=$(wget -q -O- "${URL}/${ISO}.sha256sum" | cut -d' ' -f1)
echo "${URL}/${ISO} ${HASH}" echo "${URL}/${ISO} ${HASH}"
} }
@ -1549,6 +1604,7 @@ function get_steamos() {
local DATE="20221211" local DATE="20221211"
local ISO="HoloISO_${RELEASE}_OfflineInstaller-${DATE}_1636-x86_64.iso" local ISO="HoloISO_${RELEASE}_OfflineInstaller-${DATE}_1636-x86_64.iso"
local URL="http://holoiso.itsvixano.me" local URL="http://holoiso.itsvixano.me"
HASH=$(wget -q -O- "${URL}/${ISO}.sha256sum" | cut -d' ' -f1) HASH=$(wget -q -O- "${URL}/${ISO}.sha256sum" | cut -d' ' -f1)
echo "${URL}/${ISO} ${HASH}" echo "${URL}/${ISO} ${HASH}"
} }
@ -1558,6 +1614,7 @@ function get_tails() {
local JSON="" local JSON=""
local HASH="" local HASH=""
local URL="" local URL=""
JSON="$(wget -q -O- "https://tails.boum.org/install/v2/Tails/amd64/${RELEASE}/latest.json")" JSON="$(wget -q -O- "https://tails.boum.org/install/v2/Tails/amd64/${RELEASE}/latest.json")"
URL=$(echo "${JSON}" | jq -r '.installations[0]."installation-paths"[]|select(.type=="iso")|."target-files"[0].url') URL=$(echo "${JSON}" | jq -r '.installations[0]."installation-paths"[]|select(.type=="iso")|."target-files"[0].url')
HASH=$(echo "${JSON}" | jq -r '.installations[0]."installation-paths"[]|select(.type=="iso")|."target-files"[0].sha256') HASH=$(echo "${JSON}" | jq -r '.installations[0]."installation-paths"[]|select(.type=="iso")|."target-files"[0].sha256')
@ -1567,18 +1624,23 @@ function get_tails() {
function get_truenas-scale() { function get_truenas-scale() {
local ISO="" local ISO=""
local URL="" local URL=""
local DLINFO="https://www.truenas.com/download-truenas-scale/" local DLINFO="https://www.truenas.com/download-truenas-scale/"
URL=$(wget -q ${DLINFO} -O- | grep -o "\"https://.*${RELEASE}.*\.iso\""|cut -d\" -f2) URL=$(wget -q ${DLINFO} -O- | grep -o "\"https://.*${RELEASE}.*\.iso\""|cut -d\" -f2)
HASH=$(wget -q ${URL}.sha256 -O- | cut -d' ' -f1 ) HASH=$(wget -q ${URL}.sha256 -O- | cut -d' ' -f1 )
echo "${URL} ${HASH}" echo "${URL} ${HASH}"
} }
function get_truenas-core() { function get_truenas-core() {
local ISO="" local ISO=""
local URL="" local URL=""
local DLINFO="https://www.truenas.com/download-truenas-core/" local DLINFO="https://www.truenas.com/download-truenas-core/"
URL=$(wget -q ${DLINFO} -O- | grep -o "\"https://.*${RELEASE}.*\.iso\""|cut -d\" -f2) URL=$(wget -q ${DLINFO} -O- | grep -o "\"https://.*${RELEASE}.*\.iso\""|cut -d\" -f2)
HASH=$(wget -q ${URL}.sha256 -O- | cut -d' ' -f1) HASH=$(wget -q ${URL}.sha256 -O- | cut -d' ' -f1)
echo "${URL} ${HASH}" echo "${URL} ${HASH}"
} }
@ -1586,6 +1648,7 @@ function get_ubuntu() {
local ISO="" local ISO=""
local HASH="" local HASH=""
local URL="" local URL=""
if [[ "${RELEASE}" == *"daily"* ]] && [ "${OS}" == "ubuntustudio" ]; then if [[ "${RELEASE}" == *"daily"* ]] && [ "${OS}" == "ubuntustudio" ]; then
# Ubuntu Studio daily-live images are in the dvd directory # Ubuntu Studio daily-live images are in the dvd directory
RELEASE="dvd" RELEASE="dvd"
@ -1593,11 +1656,13 @@ function get_ubuntu() {
# daily-canary is only available for Ubuntu, switch flavours to daily-live # daily-canary is only available for Ubuntu, switch flavours to daily-live
RELEASE="daily-live" RELEASE="daily-live"
fi fi
if [[ "${RELEASE}" == "eol-"* ]]; then if [[ "${RELEASE}" == "eol-"* ]]; then
URL="https://old-releases.ubuntu.com/releases/${RELEASE/eol-/}" URL="https://old-releases.ubuntu.com/releases/${RELEASE/eol-/}"
elif [[ "${RELEASE}" == "jammy-daily" ]]; then elif [[ "${RELEASE}" == "jammy-daily" ]]; then
URL="https://cdimage.ubuntu.com/${OS}/jammy/daily-live/current" URL="https://cdimage.ubuntu.com/${OS}/jammy/daily-live/current"
VM_PATH="${OS}-jammy-live" VM_PATH="${OS}-jammy-live"
elif [[ "${RELEASE}" == *"daily"* ]] || [ "${RELEASE}" == "dvd" ]; then elif [[ "${RELEASE}" == *"daily"* ]] || [ "${RELEASE}" == "dvd" ]; then
URL="https://cdimage.ubuntu.com/${OS}/${RELEASE}/current" URL="https://cdimage.ubuntu.com/${OS}/${RELEASE}/current"
VM_PATH="${OS}-daily-live" VM_PATH="${OS}-daily-live"
@ -1606,6 +1671,7 @@ function get_ubuntu() {
else else
URL="https://cdimage.ubuntu.com/${OS}/releases/${RELEASE}/release" URL="https://cdimage.ubuntu.com/${OS}/releases/${RELEASE}/release"
fi fi
if wget -q --spider "${URL}/SHA256SUMS"; then if wget -q --spider "${URL}/SHA256SUMS"; then
ISO=$(wget -q -O- "${URL}/SHA256SUMS" | grep 'desktop\|dvd\|install' | grep amd64 | grep iso | cut -d'*' -f2) ISO=$(wget -q -O- "${URL}/SHA256SUMS" | grep 'desktop\|dvd\|install' | grep amd64 | grep iso | cut -d'*' -f2)
HASH=$(wget -q -O- "${URL}/SHA256SUMS" | grep 'desktop\|dvd\|install' | grep amd64 | grep iso |cut -d' ' -f1) HASH=$(wget -q -O- "${URL}/SHA256SUMS" | grep 'desktop\|dvd\|install' | grep amd64 | grep iso |cut -d' ' -f1)
@ -1614,6 +1680,7 @@ function get_ubuntu() {
HASH=$(wget -q -O- "${URL}/MD5SUMS" | grep 'desktop\|dvd\|install' | grep amd64 | grep iso | cut -d' ' -f1) HASH=$(wget -q -O- "${URL}/MD5SUMS" | grep 'desktop\|dvd\|install' | grep amd64 | grep iso | cut -d' ' -f1)
fi fi
#echo "${URL}/${ISO} ${HASH}" #echo "${URL}/${ISO} ${HASH}"
if [[ "${RELEASE}" == *"daily"* ]] || [ "${RELEASE}" == "dvd" ]; then if [[ "${RELEASE}" == *"daily"* ]] || [ "${RELEASE}" == "dvd" ]; then
zsync_get "${URL}/${ISO}" "${VM_PATH}" "${OS}-devel.iso" zsync_get "${URL}/${ISO}" "${VM_PATH}" "${OS}-devel.iso"
make_vm_config "${OS}-devel.iso" make_vm_config "${OS}-devel.iso"
@ -1666,6 +1733,7 @@ function get_voidpup() {
local HASH="" local HASH=""
local URL="" local URL=""
local TMPURL="" local TMPURL=""
TMPURL=$(wget -q -S -O- --max-redirect=0 "https://sourceforge.net/projects/vpup/files/latest/download" 2>&1 | grep -i Location | cut -d' ' -f4) TMPURL=$(wget -q -S -O- --max-redirect=0 "https://sourceforge.net/projects/vpup/files/latest/download" 2>&1 | grep -i Location | cut -d' ' -f4)
URL=${TMPURL%\?*} URL=${TMPURL%\?*}
echo "${URL} ${HASH}" echo "${URL} ${HASH}"
@ -1689,6 +1757,7 @@ function get_xerolinux() {
local URL="" local URL=""
local ISO="xerolinux-2022.12-x86_64.iso" local ISO="xerolinux-2022.12-x86_64.iso"
local URL="https://sourceforge.net/projects/xerolinux/files/Releases" local URL="https://sourceforge.net/projects/xerolinux/files/Releases"
HASH=$(wget -q -O- "${URL}/${ISO}.sha256" | cut -d' ' -f1) HASH=$(wget -q -O- "${URL}/${ISO}.sha256" | cut -d' ' -f1)
echo "${URL}/${ISO} ${HASH}" echo "${URL}/${ISO} ${HASH}"
} }
@ -1698,6 +1767,7 @@ function get_zorin() {
local HASH="" local HASH=""
local ISO="" local ISO=""
local URL="" local URL=""
# Parse out the iso URL from the redirector # Parse out the iso URL from the redirector
URL=$(wget -q -S -O- --max-redirect=0 "https://zrn.co/${RELEASE}${EDITION}" 2>&1 | grep Location | cut -d' ' -f4) URL=$(wget -q -S -O- --max-redirect=0 "https://zrn.co/${RELEASE}${EDITION}" 2>&1 | grep Location | cut -d' ' -f4)
echo "${URL} ${HASH}" echo "${URL} ${HASH}"
@ -1709,13 +1779,16 @@ create_vm() {
local URL="${URL_HASH[0]}" local URL="${URL_HASH[0]}"
local HASH="${URL_HASH[1]}" local HASH="${URL_HASH[1]}"
local ISO="${URL##*/}" local ISO="${URL##*/}"
#echo "${URL}" #echo "${URL}"
#echo "${ISO}" #echo "${ISO}"
#echo "${HASH}" #echo "${HASH}"
web_get "${URL}" "${VM_PATH}" web_get "${URL}" "${VM_PATH}"
if [ -n "${HASH}" ]; then if [ -n "${HASH}" ]; then
check_hash "${ISO}" "${HASH}" check_hash "${ISO}" "${HASH}"
fi fi
if [ ${OS} == "freedos" ] && [[ $ISO =~ ".zip" ]]; then if [ ${OS} == "freedos" ] && [[ $ISO =~ ".zip" ]]; then
unzip ${VM_PATH}/${ISO} -d ${VM_PATH} unzip ${VM_PATH}/${ISO} -d ${VM_PATH}
ISO=$(ls ${VM_PATH} | grep -i '.iso') ISO=$(ls ${VM_PATH} | grep -i '.iso')
@ -1724,14 +1797,17 @@ create_vm() {
gzip -d "${VM_PATH}/${ISO}" gzip -d "${VM_PATH}/${ISO}"
ISO="${ISO/.gz/}" ISO="${ISO/.gz/}"
fi fi
if [ ${OS} == "dietpi" ] && [[ $ISO =~ ".7z" ]]; then if [ ${OS} == "dietpi" ] && [[ $ISO =~ ".7z" ]]; then
7zip x -o${VM_PATH} ${VM_PATH}/${ISO} 7zip x -o${VM_PATH} ${VM_PATH}/${ISO}
ISO=$(ls ${VM_PATH} | grep -i '.iso') ISO=$(ls ${VM_PATH} | grep -i '.iso')
fi fi
if [ ${OS} == "reactos" ] && [[ $ISO =~ ".zip" ]]; then if [ ${OS} == "reactos" ] && [[ $ISO =~ ".zip" ]]; then
unzip ${VM_PATH}/${ISO} -d ${VM_PATH} unzip ${VM_PATH}/${ISO} -d ${VM_PATH}
ISO=$(ls ${VM_PATH} | grep -i '.iso' | grep -v '.zip') ISO=$(ls ${VM_PATH} | grep -i '.iso' | grep -v '.zip')
fi fi
make_vm_config "${ISO}" make_vm_config "${ISO}"
} }
@ -1758,14 +1834,17 @@ else
os_support os_support
exit 1 exit 1
fi fi
if [[ ! $(os_support) =~ ${OS} ]]; then if [[ ! $(os_support) =~ ${OS} ]]; then
echo -e "ERROR! ${OS} is not a supported OS.\n" echo -e "ERROR! ${OS} is not a supported OS.\n"
os_support os_support
exit 1 exit 1
fi fi
if [ -n "${2}" ]; then if [ -n "${2}" ]; then
RELEASE="${2,,}" RELEASE="${2,,}"
VM_PATH="${OS}-${RELEASE}" VM_PATH="${OS}-${RELEASE}"
# If the OS has an editions_() function, use it. # If the OS has an editions_() function, use it.
if [[ $(type -t "editions_${OS}") == function ]]; then if [[ $(type -t "editions_${OS}") == function ]]; then
EDITIONS=($(editions_${OS})) EDITIONS=($(editions_${OS}))
@ -1780,6 +1859,7 @@ if [ -n "${2}" ]; then
exit 1 exit 1
fi fi
fi fi
# Handle odd missing fedora cominations # Handle odd missing fedora cominations
if [[ $OS == fedora ]] ; then if [[ $OS == fedora ]] ; then
if [[ ${RELEASE} = "33" && ${EDITION} = "i3" ]] || [[ ${RELEASE} = "34" && ${EDITION} = "Cinnamon" ]] ; then if [[ ${RELEASE} = "33" && ${EDITION} = "i3" ]] || [[ ${RELEASE} = "34" && ${EDITION} = "Cinnamon" ]] ; then
@ -1788,6 +1868,7 @@ if [ -n "${2}" ]; then
exit 1; exit 1;
fi fi
fi fi
# Handle odd missing dietpi cominations # Handle odd missing dietpi cominations
if [[ $OS == dietpi ]] ; then if [[ $OS == dietpi ]] ; then
if [[ ${RELEASE} = "uefi" && ${EDITION} = "bookworm" ]] || [[ ${RELEASE} = "uefi" && ${EDITION} = "bullseye" ]] ; then if [[ ${RELEASE} = "uefi" && ${EDITION} = "bookworm" ]] || [[ ${RELEASE} = "uefi" && ${EDITION} = "bullseye" ]] ; then
@ -1796,6 +1877,7 @@ if [ -n "${2}" ]; then
exit 1; exit 1;
fi fi
fi fi
# Handle void missing edition # Handle void missing edition
case "${RELEASE}-${EDITION}" in case "${RELEASE}-${EDITION}" in
"20170220-gnome"|"20170220-gnome-musl") "20170220-gnome"|"20170220-gnome-musl")
@ -1854,6 +1936,7 @@ if [ -n "${2}" ]; then
exit 1 exit 1
;; ;;
esac esac
VM_PATH="${OS}-${RELEASE}-${EDITION}" VM_PATH="${OS}-${RELEASE}-${EDITION}"
validate_release "releases_${OS}" validate_release "releases_${OS}"
create_vm "$("get_${OS}" "${EDITION}")" create_vm "$("get_${OS}" "${EDITION}")"
@ -1876,6 +1959,7 @@ else
echo -n " - Releases: " echo -n " - Releases: "
releases_ubuntu | sed -Ee 's/eol-\S+//g' # hide eol releases releases_ubuntu | sed -Ee 's/eol-\S+//g' # hide eol releases
;; ;;
*) *)
echo -n " - Releases: " echo -n " - Releases: "
releases_"${OS}" releases_"${OS}"