Refactor Fedora support to add editions, including Fedora Spins

This also removes all hardcoding in ISO filenames.
This commit is contained in:
Martin Wimpress 2022-02-21 22:18:50 +00:00
parent dabdfa49cc
commit 36ea016fb3
No known key found for this signature in database
GPG key ID: 61DF940515E06DA3

View file

@ -285,8 +285,22 @@ function releases_fedora(){
35 35
} }
function editions_fedora() {
echo Workstation \
Cinnamon \
i3 \
KDE \
LXDE \
LXQt \
Mate \
Xfce \
Silverblue \
Server
}
function releases_freebsd(){ function releases_freebsd(){
echo 12.2 \ echo 12.2 \
12.3 \
13.0 13.0
} }
@ -886,25 +900,26 @@ function get_elementary() {
} }
function get_fedora() { function get_fedora() {
local FEDORA_RELEASE="" local EDITION=""
local FEDORA_VERSIONS=""
local HASH="" local HASH=""
local ISO="" local ISO=""
local JSON=""
local URL="" local URL=""
local VERSION_NUM="" local VARIANT=""
FEDORA_VERSIONS=$(wget -q -O- "https://getfedora.org/releases.json" | jq '.[] | select((.variant=="Workstation" or .variant=="Spins") and .arch=="x86_64")') if [ -n "${1}" ]; then
if [[ "${RELEASE}" == *"beta"* ]]; then EDITION="${1}"
VERSION_NUM=${RELEASE%"_beta"}
FEDORA_RELEASE=$(echo "${FEDORA_VERSIONS}" | jq -c '. | select(.version | contains("Beta"))' | jq '. | select(.variant=="Workstation")')
ISO="Fedora-Workstation-Live-x86_64-${VERSION_NUM}_Beta-1.2.iso"
else
FEDORA_RELEASE=$(echo "${FEDORA_VERSIONS}" | jq '. | select(.variant=="Workstation" and .version=="'${RELEASE}'")')
ISO="Fedora-Workstation-Live-x86_64-${RELEASE}-1.2.iso"
fi fi
URL=$(echo "${FEDORA_RELEASE}" | jq -r '.link') case ${EDITION} in
HASH=$(echo "${FEDORA_RELEASE}" | jq -r '.sha256') Server|Silverblue|Workstation) VARIANT="${EDITION}";;
*) VARIANT="Spins";;
esac
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)
ISO="${URL##*/}"
HASH=$(echo "${JSON}" | jq -r '.sha256' | head -n1)
web_get "${URL}" "${VM_PATH}" web_get "${URL}" "${VM_PATH}"
check_hash "${ISO}" "${HASH}" check_hash "${ISO}" "${HASH}"
make_vm_config "${ISO}" make_vm_config "${ISO}"