mirror of
https://github.com/oSoWoSo/DistroHopper.git
synced 2024-08-14 22:46:53 +00:00
whitelines
This commit is contained in:
parent
f702581806
commit
3f2bc926c4
1 changed files with 112 additions and 28 deletions
140
quickget
140
quickget
|
@ -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}"
|
||||||
|
|
Loading…
Reference in a new issue