diff --git a/TODO/all b/TODO/all index 791d3c9..d9f7782 100644 --- a/TODO/all +++ b/TODO/all @@ -1,3 +1,8 @@ +agarimos latest plasma +agarimos latest xfce4 +agarimos latest cinnamon +agarimos latest lxqt-kwin +agarimos latest gnome alma 9 boot alma 9 minimal alma 9 dvd @@ -40,6 +45,14 @@ android 8.1 x86_64 android 8.1 x86 android 7.1 x86_64 android 7.1 x86 +antix 23.2 net-sysv +antix 23.2 core-sysv +antix 23.2 base-sysv +antix 23.2 full-sysv +antix 23.2 net-runit +antix 23.2 core-runit +antix 23.2 base-runit +antix 23.2 full-runit antix 23.1 net-sysv antix 23.1 core-sysv antix 23.1 base-sysv @@ -88,6 +101,9 @@ archlinux latest net-runit archlinux latest core-runit archlinux latest base-runit archlinux latest full-runit +arco v25.03.05 net +arco v25.03.05 plasma +arco v25.03.05 pro arco v25.02.04 net arco v25.02.04 plasma arco v25.02.04 pro @@ -100,9 +116,6 @@ arco v25.01.01 pro arco v24.12.02 net arco v24.12.02 plasma arco v24.12.02 pro -arco v24.11.01 net -arco v24.11.01 plasma -arco v24.11.01 pro artixlinux 20240823 base-dinit artixlinux 20240823 base-openrc artixlinux 20240823 base-runit @@ -359,6 +372,12 @@ centos-stream 10 boot centos-stream 10 dvd1 centos-stream 9 boot centos-stream 9 dvd1 +cereus latest base +cereus latest musl-base +cereus latest lxqt +cereus latest musl-lxqt +cereus latest xfce +cereus latest musl-xfce chimeralinux latest base chimeralinux latest gnome crunchbang++ 12.0 base @@ -441,213 +460,106 @@ devuan beowulf lxqt devuan beowulf mate devuan beowulf xfce devuan beowulf netinst -dragonflybsd 6.4.0 standard -dragonflybsd 6.4.0 cinnamon -dragonflybsd 6.4.0 gnome -dragonflybsd 6.4.0 kde -dragonflybsd 6.4.0 lxde -dragonflybsd 6.4.0 lxqt -dragonflybsd 6.4.0 mate -dragonflybsd 6.4.0 xfce -dragonflybsd 6.4.0 netinst -dragonflybsd 6.2.2 standard -dragonflybsd 6.2.2 cinnamon -dragonflybsd 6.2.2 gnome -dragonflybsd 6.2.2 kde -dragonflybsd 6.2.2 lxde -dragonflybsd 6.2.2 lxqt -dragonflybsd 6.2.2 mate -dragonflybsd 6.2.2 xfce -dragonflybsd 6.2.2 netinst -dragonflybsd 6.2.1 standard -dragonflybsd 6.2.1 cinnamon -dragonflybsd 6.2.1 gnome -dragonflybsd 6.2.1 kde -dragonflybsd 6.2.1 lxde -dragonflybsd 6.2.1 lxqt -dragonflybsd 6.2.1 mate -dragonflybsd 6.2.1 xfce -dragonflybsd 6.2.1 netinst -dragonflybsd 6.0.1 standard -dragonflybsd 6.0.1 cinnamon -dragonflybsd 6.0.1 gnome -dragonflybsd 6.0.1 kde -dragonflybsd 6.0.1 lxde -dragonflybsd 6.0.1 lxqt -dragonflybsd 6.0.1 mate -dragonflybsd 6.0.1 xfce -dragonflybsd 6.0.1 netinst -dragonflybsd 6.0.0 standard -dragonflybsd 6.0.0 cinnamon -dragonflybsd 6.0.0 gnome -dragonflybsd 6.0.0 kde -dragonflybsd 6.0.0 lxde -dragonflybsd 6.0.0 lxqt -dragonflybsd 6.0.0 mate -dragonflybsd 6.0.0 xfce -dragonflybsd 6.0.0 netinst -dragonflybsd 5.8.3 standard -dragonflybsd 5.8.3 cinnamon -dragonflybsd 5.8.3 gnome -dragonflybsd 5.8.3 kde -dragonflybsd 5.8.3 lxde -dragonflybsd 5.8.3 lxqt -dragonflybsd 5.8.3 mate -dragonflybsd 5.8.3 xfce -dragonflybsd 5.8.3 netinst -dragonflybsd 5.8.2 standard -dragonflybsd 5.8.2 cinnamon -dragonflybsd 5.8.2 gnome -dragonflybsd 5.8.2 kde -dragonflybsd 5.8.2 lxde -dragonflybsd 5.8.2 lxqt -dragonflybsd 5.8.2 mate -dragonflybsd 5.8.2 xfce -dragonflybsd 5.8.2 netinst -dragonflybsd 5.8.1 standard -dragonflybsd 5.8.1 cinnamon -dragonflybsd 5.8.1 gnome -dragonflybsd 5.8.1 kde -dragonflybsd 5.8.1 lxde -dragonflybsd 5.8.1 lxqt -dragonflybsd 5.8.1 mate -dragonflybsd 5.8.1 xfce -dragonflybsd 5.8.1 netinst -dragonflybsd 5.6.3 standard -dragonflybsd 5.6.3 cinnamon -dragonflybsd 5.6.3 gnome -dragonflybsd 5.6.3 kde -dragonflybsd 5.6.3 lxde -dragonflybsd 5.6.3 lxqt -dragonflybsd 5.6.3 mate -dragonflybsd 5.6.3 xfce -dragonflybsd 5.6.3 netinst -dragonflybsd 5.8.0 standard -dragonflybsd 5.8.0 cinnamon -dragonflybsd 5.8.0 gnome -dragonflybsd 5.8.0 kde -dragonflybsd 5.8.0 lxde -dragonflybsd 5.8.0 lxqt -dragonflybsd 5.8.0 mate -dragonflybsd 5.8.0 xfce -dragonflybsd 5.8.0 netinst -dragonflybsd 5.6.2 standard -dragonflybsd 5.6.2 cinnamon -dragonflybsd 5.6.2 gnome -dragonflybsd 5.6.2 kde -dragonflybsd 5.6.2 lxde -dragonflybsd 5.6.2 lxqt -dragonflybsd 5.6.2 mate -dragonflybsd 5.6.2 xfce -dragonflybsd 5.6.2 netinst -dragonflybsd 5.6.1 standard -dragonflybsd 5.6.1 cinnamon -dragonflybsd 5.6.1 gnome -dragonflybsd 5.6.1 kde -dragonflybsd 5.6.1 lxde -dragonflybsd 5.6.1 lxqt -dragonflybsd 5.6.1 mate -dragonflybsd 5.6.1 xfce -dragonflybsd 5.6.1 netinst -dragonflybsd 5.6.0 standard -dragonflybsd 5.6.0 cinnamon -dragonflybsd 5.6.0 gnome -dragonflybsd 5.6.0 kde -dragonflybsd 5.6.0 lxde -dragonflybsd 5.6.0 lxqt -dragonflybsd 5.6.0 mate -dragonflybsd 5.6.0 xfce -dragonflybsd 5.6.0 netinst -dragonflybsd 5.4.3 standard -dragonflybsd 5.4.3 cinnamon -dragonflybsd 5.4.3 gnome -dragonflybsd 5.4.3 kde -dragonflybsd 5.4.3 lxde -dragonflybsd 5.4.3 lxqt -dragonflybsd 5.4.3 mate -dragonflybsd 5.4.3 xfce -dragonflybsd 5.4.3 netinst -dragonflybsd 5.4.2 standard -dragonflybsd 5.4.2 cinnamon -dragonflybsd 5.4.2 gnome -dragonflybsd 5.4.2 kde -dragonflybsd 5.4.2 lxde -dragonflybsd 5.4.2 lxqt -dragonflybsd 5.4.2 mate -dragonflybsd 5.4.2 xfce -dragonflybsd 5.4.2 netinst -dragonflybsd 5.4.1 standard -dragonflybsd 5.4.1 cinnamon -dragonflybsd 5.4.1 gnome -dragonflybsd 5.4.1 kde -dragonflybsd 5.4.1 lxde -dragonflybsd 5.4.1 lxqt -dragonflybsd 5.4.1 mate -dragonflybsd 5.4.1 xfce -dragonflybsd 5.4.1 netinst -dragonflybsd 5.4.0 standard -dragonflybsd 5.4.0 cinnamon -dragonflybsd 5.4.0 gnome -dragonflybsd 5.4.0 kde -dragonflybsd 5.4.0 lxde -dragonflybsd 5.4.0 lxqt -dragonflybsd 5.4.0 mate -dragonflybsd 5.4.0 xfce -dragonflybsd 5.4.0 netinst -dragonflybsd 5.2.2 standard -dragonflybsd 5.2.2 cinnamon -dragonflybsd 5.2.2 gnome -dragonflybsd 5.2.2 kde -dragonflybsd 5.2.2 lxde -dragonflybsd 5.2.2 lxqt -dragonflybsd 5.2.2 mate -dragonflybsd 5.2.2 xfce -dragonflybsd 5.2.2 netinst -dragonflybsd 5.2.1 standard -dragonflybsd 5.2.1 cinnamon -dragonflybsd 5.2.1 gnome -dragonflybsd 5.2.1 kde -dragonflybsd 5.2.1 lxde -dragonflybsd 5.2.1 lxqt -dragonflybsd 5.2.1 mate -dragonflybsd 5.2.1 xfce -dragonflybsd 5.2.1 netinst -dragonflybsd 5.2.0 standard -dragonflybsd 5.2.0 cinnamon -dragonflybsd 5.2.0 gnome -dragonflybsd 5.2.0 kde -dragonflybsd 5.2.0 lxde -dragonflybsd 5.2.0 lxqt -dragonflybsd 5.2.0 mate -dragonflybsd 5.2.0 xfce -dragonflybsd 5.2.0 netinst -dragonflybsd 5.0.2 standard -dragonflybsd 5.0.2 cinnamon -dragonflybsd 5.0.2 gnome -dragonflybsd 5.0.2 kde -dragonflybsd 5.0.2 lxde -dragonflybsd 5.0.2 lxqt -dragonflybsd 5.0.2 mate -dragonflybsd 5.0.2 xfce -dragonflybsd 5.0.2 netinst -dragonflybsd 5.0.1 standard -dragonflybsd 5.0.1 cinnamon -dragonflybsd 5.0.1 gnome -dragonflybsd 5.0.1 kde -dragonflybsd 5.0.1 lxde -dragonflybsd 5.0.1 lxqt -dragonflybsd 5.0.1 mate -dragonflybsd 5.0.1 xfce -dragonflybsd 5.0.1 netinst -dragonflybsd 5.0.0 standard -dragonflybsd 5.0.0 cinnamon -dragonflybsd 5.0.0 gnome -dragonflybsd 5.0.0 kde -dragonflybsd 5.0.0 lxde -dragonflybsd 5.0.0 lxqt -dragonflybsd 5.0.0 mate -dragonflybsd 5.0.0 xfce -dragonflybsd 5.0.0 netinst +dietpi bios bookworm +dietpi bios bookworm-installer +dietpi bios bullseye +dietpi bios bullseye-installer +dietpi uefi bookworm +dietpi uefi bookworm-installer +dietpi uefi bullseye +dietpi uefi bullseye-installer +dragonflybsd 6.4.0 bookworm +dragonflybsd 6.4.0 bookworm-installer +dragonflybsd 6.4.0 bullseye +dragonflybsd 6.4.0 bullseye-installer +dragonflybsd 6.2.2 bookworm +dragonflybsd 6.2.2 bookworm-installer +dragonflybsd 6.2.2 bullseye +dragonflybsd 6.2.2 bullseye-installer +dragonflybsd 6.2.1 bookworm +dragonflybsd 6.2.1 bookworm-installer +dragonflybsd 6.2.1 bullseye +dragonflybsd 6.2.1 bullseye-installer +dragonflybsd 6.0.1 bookworm +dragonflybsd 6.0.1 bookworm-installer +dragonflybsd 6.0.1 bullseye +dragonflybsd 6.0.1 bullseye-installer +dragonflybsd 6.0.0 bookworm +dragonflybsd 6.0.0 bookworm-installer +dragonflybsd 6.0.0 bullseye +dragonflybsd 6.0.0 bullseye-installer +dragonflybsd 5.8.3 bookworm +dragonflybsd 5.8.3 bookworm-installer +dragonflybsd 5.8.3 bullseye +dragonflybsd 5.8.3 bullseye-installer +dragonflybsd 5.8.2 bookworm +dragonflybsd 5.8.2 bookworm-installer +dragonflybsd 5.8.2 bullseye +dragonflybsd 5.8.2 bullseye-installer +dragonflybsd 5.8.1 bookworm +dragonflybsd 5.8.1 bookworm-installer +dragonflybsd 5.8.1 bullseye +dragonflybsd 5.8.1 bullseye-installer +dragonflybsd 5.6.3 bookworm +dragonflybsd 5.6.3 bookworm-installer +dragonflybsd 5.6.3 bullseye +dragonflybsd 5.6.3 bullseye-installer +dragonflybsd 5.8.0 bookworm +dragonflybsd 5.8.0 bookworm-installer +dragonflybsd 5.8.0 bullseye +dragonflybsd 5.8.0 bullseye-installer +dragonflybsd 5.6.2 bookworm +dragonflybsd 5.6.2 bookworm-installer +dragonflybsd 5.6.2 bullseye +dragonflybsd 5.6.2 bullseye-installer +dragonflybsd 5.6.1 bookworm +dragonflybsd 5.6.1 bookworm-installer +dragonflybsd 5.6.1 bullseye +dragonflybsd 5.6.1 bullseye-installer +dragonflybsd 5.6.0 bookworm +dragonflybsd 5.6.0 bookworm-installer +dragonflybsd 5.6.0 bullseye +dragonflybsd 5.6.0 bullseye-installer +dragonflybsd 5.4.3 bookworm +dragonflybsd 5.4.3 bookworm-installer +dragonflybsd 5.4.3 bullseye +dragonflybsd 5.4.3 bullseye-installer +dragonflybsd 5.4.2 bookworm +dragonflybsd 5.4.2 bookworm-installer +dragonflybsd 5.4.2 bullseye +dragonflybsd 5.4.2 bullseye-installer +dragonflybsd 5.4.1 bookworm +dragonflybsd 5.4.1 bookworm-installer +dragonflybsd 5.4.1 bullseye +dragonflybsd 5.4.1 bullseye-installer +dragonflybsd 5.4.0 bookworm +dragonflybsd 5.4.0 bookworm-installer +dragonflybsd 5.4.0 bullseye +dragonflybsd 5.4.0 bullseye-installer +dragonflybsd 5.2.2 bookworm +dragonflybsd 5.2.2 bookworm-installer +dragonflybsd 5.2.2 bullseye +dragonflybsd 5.2.2 bullseye-installer +dragonflybsd 5.2.1 bookworm +dragonflybsd 5.2.1 bookworm-installer +dragonflybsd 5.2.1 bullseye +dragonflybsd 5.2.1 bullseye-installer +dragonflybsd 5.2.0 bookworm +dragonflybsd 5.2.0 bookworm-installer +dragonflybsd 5.2.0 bullseye +dragonflybsd 5.2.0 bullseye-installer +dragonflybsd 5.0.2 bookworm +dragonflybsd 5.0.2 bookworm-installer +dragonflybsd 5.0.2 bullseye +dragonflybsd 5.0.2 bullseye-installer +dragonflybsd 5.0.1 bookworm +dragonflybsd 5.0.1 bookworm-installer +dragonflybsd 5.0.1 bullseye +dragonflybsd 5.0.1 bullseye-installer +dragonflybsd 5.0.0 bookworm +dragonflybsd 5.0.0 bookworm-installer +dragonflybsd 5.0.0 bullseye +dragonflybsd 5.0.0 bullseye-installer dsl 2024.rc7 lz4 dsl 2024.rc7 cdrom easyos 5.8.5 lz4 @@ -732,6 +644,12 @@ freedos 1.3 disc1 freedos 1.3 dvd1 freedos 1.2 disc1 freedos 1.2 dvd1 +fvoid latest disc1 +fvoid latest dvd1 +gabeeos release Openbox +gabeeos release Qtile +gabeeos beta Openbox +gabeeos beta Qtile garuda latest cinnamon garuda latest dr460nized garuda latest dr460nized-gaming @@ -747,14 +665,16 @@ garuda latest wayfire garuda latest xfce gentoo latest minimal gentoo latest livegui +ghostbsd 25.01-R14.2p1 mate +ghostbsd 25.01-R14.2p1 xfce ghostbsd 24.10.1 mate ghostbsd 24.10.1 xfce ghostbsd 24.07.3 mate ghostbsd 24.07.3 xfce -ghostbsd 24.07.2 mate -ghostbsd 24.07.2 xfce gnomeos nightly mate gnomeos nightly xfce +gnomeos 48.beta mate +gnomeos 48.beta xfce gnomeos 48.alpha mate gnomeos 48.alpha xfce gnomeos 47.rc mate @@ -833,6 +753,8 @@ kdeneon unstable x86_64 kdeneon unstable x86_gcc2h kdeneon developer x86_64 kdeneon developer x86_gcc2h +kodachi latest x86_64 +kodachi latest x86_gcc2h kolibrios latest en_US kolibrios latest ru_RU kolibrios latest it_IT @@ -878,19 +800,48 @@ linuxmint 20.2 cinnamon linuxmint 20.2 mate linuxmint 20.2 xfce lmde 6 cinnamon -maboxlinux latest cinnamon +loc-os latest lxde +loc-os latest xfce +loc-os latest kde +maboxlinux latest lxde +maboxlinux latest xfce +maboxlinux latest kde macos mojave: http://oscdn.apple.com/content/downloads/04/36/041-94410/ge73si0bd3fdsdkfibykjgrlcfuzy1q9yx/RecoveryImage/BaseSystem.dmg -macos mojave cinnamon +macos mojave lxde +macos mojave: http://oscdn.apple.com/content/downloads/04/36/041-94410/ge73si0bd3fdsdkfibykjgrlcfuzy1q9yx/RecoveryImage/BaseSystem.dmg +macos mojave xfce +macos mojave: http://oscdn.apple.com/content/downloads/04/36/041-94410/ge73si0bd3fdsdkfibykjgrlcfuzy1q9yx/RecoveryImage/BaseSystem.dmg +macos mojave kde macos catalina: http://oscdn.apple.com/content/downloads/59/10/001-43312/oifium3yx72dhc4po3r65zfwblslmce191/RecoveryImage/BaseSystem.dmg -macos catalina cinnamon +macos catalina lxde +macos catalina: http://oscdn.apple.com/content/downloads/59/10/001-43312/oifium3yx72dhc4po3r65zfwblslmce191/RecoveryImage/BaseSystem.dmg +macos catalina xfce +macos catalina: http://oscdn.apple.com/content/downloads/59/10/001-43312/oifium3yx72dhc4po3r65zfwblslmce191/RecoveryImage/BaseSystem.dmg +macos catalina kde macos big-sur: http://oscdn.apple.com/content/downloads/41/28/071-71279/5djpevqmc2w0ti2c4n1m8mkz7fm791t1ic/RecoveryImage/BaseSystem.dmg -macos big-sur cinnamon +macos big-sur lxde +macos big-sur: http://oscdn.apple.com/content/downloads/41/28/071-71279/5djpevqmc2w0ti2c4n1m8mkz7fm791t1ic/RecoveryImage/BaseSystem.dmg +macos big-sur xfce +macos big-sur: http://oscdn.apple.com/content/downloads/41/28/071-71279/5djpevqmc2w0ti2c4n1m8mkz7fm791t1ic/RecoveryImage/BaseSystem.dmg +macos big-sur kde macos monterey: http://oscdn.apple.com/content/downloads/59/11/012-51692/z29q5x5plswit63bvyxmubthavua9gbxic/RecoveryImage/BaseSystem.dmg -macos monterey cinnamon +macos monterey lxde +macos monterey: http://oscdn.apple.com/content/downloads/59/11/012-51692/z29q5x5plswit63bvyxmubthavua9gbxic/RecoveryImage/BaseSystem.dmg +macos monterey xfce +macos monterey: http://oscdn.apple.com/content/downloads/59/11/012-51692/z29q5x5plswit63bvyxmubthavua9gbxic/RecoveryImage/BaseSystem.dmg +macos monterey kde macos ventura: http://oscdn.apple.com/content/downloads/60/43/042-01871/sbembiob0hs1o92jfofalts02ux0x8rsra/RecoveryImage/BaseSystem.dmg -macos ventura cinnamon +macos ventura lxde +macos ventura: http://oscdn.apple.com/content/downloads/60/43/042-01871/sbembiob0hs1o92jfofalts02ux0x8rsra/RecoveryImage/BaseSystem.dmg +macos ventura xfce +macos ventura: http://oscdn.apple.com/content/downloads/60/43/042-01871/sbembiob0hs1o92jfofalts02ux0x8rsra/RecoveryImage/BaseSystem.dmg +macos ventura kde macos sonoma: http://oscdn.apple.com/content/downloads/40/46/072-70660/yk1lzbgsbfcjusj5jd80j7jnlljq60qc8m/RecoveryImage/BaseSystem.dmg -macos sonoma cinnamon +macos sonoma lxde +macos sonoma: http://oscdn.apple.com/content/downloads/40/46/072-70660/yk1lzbgsbfcjusj5jd80j7jnlljq60qc8m/RecoveryImage/BaseSystem.dmg +macos sonoma xfce +macos sonoma: http://oscdn.apple.com/content/downloads/40/46/072-70660/yk1lzbgsbfcjusj5jd80j7jnlljq60qc8m/RecoveryImage/BaseSystem.dmg +macos sonoma kde mageia 9 Plasma mageia 9 GNOME mageia 9 Xfce @@ -909,6 +860,11 @@ manjaro i3 full manjaro i3 minimal manjaro sway full manjaro sway minimal +miyo 2022 Kwin +miyo 2022 Deboot-Ceres +miyo 2022 JWM +miyo 2022 Openbox +miyo 2022 MATE mxlinux 23.5 Xfce mxlinux 23.5 KDE mxlinux 23.5 Fluxbox @@ -933,15 +889,15 @@ nitrux latest Fluxbox nixos unstable minimal nixos unstable plasma nixos unstable gnome -nixos 24.11 minimal -nixos 24.11 plasma -nixos 24.11 gnome nixos 24.05 minimal nixos 24.05 plasma nixos 24.05 gnome -nwg-shell 2025.01.01 minimal -nwg-shell 2025.01.01 plasma -nwg-shell 2025.01.01 gnome +nixos 23.05 minimal +nixos 23.05 plasma +nixos 23.05 gnome +nwg-shell 2025.02.23 minimal +nwg-shell 2025.02.23 plasma +nwg-shell 2025.02.23 gnome openbsd 7.6 minimal openbsd 7.6 plasma openbsd 7.6 gnome @@ -1056,15 +1012,69 @@ oraclelinux 7.8 minimal oraclelinux 7.7 gui oraclelinux 7.7 text oraclelinux 7.7 minimal -parrotsec 6.3 home -parrotsec 6.3 htb -parrotsec 6.3 security +parrotsec 6.3.2 home +parrotsec 6.3.2 htb +parrotsec 6.3.2 security parrotsec 6.2 home parrotsec 6.2 htb parrotsec 6.2 security parrotsec 6.1 home parrotsec 6.1 htb parrotsec 6.1 security +pbpuppy ghtest BookwormPup64 +pbpuppy ghtest S15Pup64 +pbpuppy ghtest VoidPup64 +pbpuppy ghtest BookwormPup64 +pbpuppy ghtest S15Pup64 +pbpuppy ghtest VoidPup64 +pbpuppy ghtest BookwormPup64 +pbpuppy ghtest VoidPup64 +pbpuppy ghtest S15Pup64 +pbpuppy 250301 BookwormPup64 +pbpuppy 250301 S15Pup64 +pbpuppy 250301 VoidPup64 +pbpuppy 250301 BookwormPup64 +pbpuppy 250301 S15Pup64 +pbpuppy 250301 VoidPup64 +pbpuppy 250301 BookwormPup64 +pbpuppy 250301 VoidPup64 +pbpuppy 250301 S15Pup64 +pbpuppy ghtest BookwormPup64 +pbpuppy ghtest S15Pup64 +pbpuppy ghtest VoidPup64 +pbpuppy ghtest BookwormPup64 +pbpuppy ghtest S15Pup64 +pbpuppy ghtest VoidPup64 +pbpuppy ghtest BookwormPup64 +pbpuppy ghtest VoidPup64 +pbpuppy ghtest S15Pup64 +pbpuppy 250201 BookwormPup64 +pbpuppy 250201 S15Pup64 +pbpuppy 250201 VoidPup64 +pbpuppy 250201 BookwormPup64 +pbpuppy 250201 S15Pup64 +pbpuppy 250201 VoidPup64 +pbpuppy 250201 BookwormPup64 +pbpuppy 250201 VoidPup64 +pbpuppy 250201 S15Pup64 +pbpuppy ghtest BookwormPup64 +pbpuppy ghtest S15Pup64 +pbpuppy ghtest VoidPup64 +pbpuppy ghtest BookwormPup64 +pbpuppy ghtest S15Pup64 +pbpuppy ghtest VoidPup64 +pbpuppy ghtest BookwormPup64 +pbpuppy ghtest VoidPup64 +pbpuppy ghtest S15Pup64 +pbpuppy 250101 BookwormPup64 +pbpuppy 250101 S15Pup64 +pbpuppy 250101 VoidPup64 +pbpuppy 250101 BookwormPup64 +pbpuppy 250101 S15Pup64 +pbpuppy 250101 VoidPup64 +pbpuppy 250101 BookwormPup64 +pbpuppy 250101 VoidPup64 +pbpuppy 250101 S15Pup64 peppermint latest devuan-xfce peppermint latest devuan-gnome peppermint latest debian-xfce @@ -1095,45 +1105,45 @@ rebornos latest gnome rebornos latest plasma rhino 2025.1 gnome rhino 2025.1 plasma -rockulinux 9.5 minimal -rockulinux 9.5 dvd -rockulinux 9.5 boot -rockulinux 9.4 minimal -rockulinux 9.4 dvd -rockulinux 9.4 boot -rockulinux 9.3 minimal -rockulinux 9.3 dvd -rockulinux 9.3 boot -rockulinux 9.2 minimal -rockulinux 9.2 dvd -rockulinux 9.2 boot -rockulinux 9.1 minimal -rockulinux 9.1 dvd -rockulinux 9.1 boot -rockulinux 9.0 minimal -rockulinux 9.0 dvd -rockulinux 9.0 boot -rockulinux 8.9 minimal -rockulinux 8.9 dvd -rockulinux 8.9 boot -rockulinux 8.8 minimal -rockulinux 8.8 dvd -rockulinux 8.8 boot -rockulinux 8.7 minimal -rockulinux 8.7 dvd -rockulinux 8.7 boot -rockulinux 8.6 minimal -rockulinux 8.6 dvd -rockulinux 8.6 boot -rockulinux 8.5 minimal -rockulinux 8.5 dvd -rockulinux 8.5 boot -rockulinux 8.4 minimal -rockulinux 8.4 dvd -rockulinux 8.4 boot -rockulinux 8.3 minimal -rockulinux 8.3 dvd -rockulinux 8.3 boot +rockylinux 9.5 minimal +rockylinux 9.5 dvd +rockylinux 9.5 boot +rockylinux 9.4 minimal +rockylinux 9.4 dvd +rockylinux 9.4 boot +rockylinux 9.3 minimal +rockylinux 9.3 dvd +rockylinux 9.3 boot +rockylinux 9.2 minimal +rockylinux 9.2 dvd +rockylinux 9.2 boot +rockylinux 9.1 minimal +rockylinux 9.1 dvd +rockylinux 9.1 boot +rockylinux 9.0 minimal +rockylinux 9.0 dvd +rockylinux 9.0 boot +rockylinux 8.9 minimal +rockylinux 8.9 dvd +rockylinux 8.9 boot +rockylinux 8.8 minimal +rockylinux 8.8 dvd +rockylinux 8.8 boot +rockylinux 8.7 minimal +rockylinux 8.7 dvd +rockylinux 8.7 boot +rockylinux 8.6 minimal +rockylinux 8.6 dvd +rockylinux 8.6 boot +rockylinux 8.5 minimal +rockylinux 8.5 dvd +rockylinux 8.5 boot +rockylinux 8.4 minimal +rockylinux 8.4 dvd +rockylinux 8.4 boot +rockylinux 8.3 minimal +rockylinux 8.3 dvd +rockylinux 8.3 boot siduction latest kde siduction latest lxqt siduction latest nox @@ -1178,12 +1188,6 @@ slitaz loram debian slitaz loram slackware slitaz preinit debian slitaz preinit slackware -sparkylinux 7.6 kde -sparkylinux 7.6 lxqt -sparkylinux 7.6 mate -sparkylinux 7.6 minimalcli -sparkylinux 7.6 minimalgui -sparkylinux 7.6 xfce spirallinux latest Plasma spirallinux latest XFCE spirallinux latest Mate @@ -1338,6 +1342,82 @@ vanillaos 2.0 mate vanillaos 2.0 lxde vanillaos 2.0 kde vanillaos 2.0 sugar +ventoy 1.1.05 mate +ventoy 1.1.05 lxde +ventoy 1.1.05 kde +ventoy 1.1.05 sugar +ventoy 1.1.04 mate +ventoy 1.1.04 lxde +ventoy 1.1.04 kde +ventoy 1.1.04 sugar +ventoy 1.1.02 mate +ventoy 1.1.02 lxde +ventoy 1.1.02 kde +ventoy 1.1.02 sugar +ventoy 1.1.01 mate +ventoy 1.1.01 lxde +ventoy 1.1.01 kde +ventoy 1.1.01 sugar +ventoy 1.1.00 mate +ventoy 1.1.00 lxde +ventoy 1.1.00 kde +ventoy 1.1.00 sugar +ventoy 1.0.99 mate +ventoy 1.0.99 lxde +ventoy 1.0.99 kde +ventoy 1.0.99 sugar +ventoy 1.0.98 mate +ventoy 1.0.98 lxde +ventoy 1.0.98 kde +ventoy 1.0.98 sugar +ventoy 1.0.97 mate +ventoy 1.0.97 lxde +ventoy 1.0.97 kde +ventoy 1.0.97 sugar +ventoy 1.0.96 mate +ventoy 1.0.96 lxde +ventoy 1.0.96 kde +ventoy 1.0.96 sugar +ventoy 1.0.95 mate +ventoy 1.0.95 lxde +ventoy 1.0.95 kde +ventoy 1.0.95 sugar +ventoy 1.0.94 mate +ventoy 1.0.94 lxde +ventoy 1.0.94 kde +ventoy 1.0.94 sugar +ventoy 1.0.93 mate +ventoy 1.0.93 lxde +ventoy 1.0.93 kde +ventoy 1.0.93 sugar +ventoy 1.0.91 mate +ventoy 1.0.91 lxde +ventoy 1.0.91 kde +ventoy 1.0.91 sugar +ventoy 1.0.90 mate +ventoy 1.0.90 lxde +ventoy 1.0.90 kde +ventoy 1.0.90 sugar +ventoy 1.0.89 mate +ventoy 1.0.89 lxde +ventoy 1.0.89 kde +ventoy 1.0.89 sugar +ventoy 1.0.88 mate +ventoy 1.0.88 lxde +ventoy 1.0.88 kde +ventoy 1.0.88 sugar +ventoy 1.0.87 mate +ventoy 1.0.87 lxde +ventoy 1.0.87 kde +ventoy 1.0.87 sugar +ventoy 1.0.86 mate +ventoy 1.0.86 lxde +ventoy 1.0.86 kde +ventoy 1.0.86 sugar +ventoy 1.0.85 mate +ventoy 1.0.85 lxde +ventoy 1.0.85 kde +ventoy 1.0.85 sugar void 20250202 glibc void 20250202 musl void 20250202 xfce-glibc @@ -1380,296 +1460,3 @@ zorin 17 education64 zorin 16 core64 zorin 16 lite64 zorin 16 education64 -rockylinux 9.5 minimal: https://dl.rockylinux.org/vault/rocky/9.5/isos/x86_64/Rocky-9.5-x86_64-minimal.iso -rockylinux 9.5 dvd: https://dl.rockylinux.org/vault/rocky/9.5/isos/x86_64/Rocky-9.5-x86_64-dvd.iso -rockylinux 9.5 boot: https://dl.rockylinux.org/vault/rocky/9.5/isos/x86_64/Rocky-9.5-x86_64-boot.iso -rockylinux 9.4 minimal: https://dl.rockylinux.org/vault/rocky/9.4/isos/x86_64/Rocky-9.4-x86_64-minimal.iso -rockylinux 9.4 dvd: https://dl.rockylinux.org/vault/rocky/9.4/isos/x86_64/Rocky-9.4-x86_64-dvd.iso -rockylinux 9.4 boot: https://dl.rockylinux.org/vault/rocky/9.4/isos/x86_64/Rocky-9.4-x86_64-boot.iso -rockylinux 9.3 minimal: https://dl.rockylinux.org/vault/rocky/9.3/isos/x86_64/Rocky-9.3-x86_64-minimal.iso -rockylinux 9.3 dvd: https://dl.rockylinux.org/vault/rocky/9.3/isos/x86_64/Rocky-9.3-x86_64-dvd.iso -rockylinux 9.3 boot: https://dl.rockylinux.org/vault/rocky/9.3/isos/x86_64/Rocky-9.3-x86_64-boot.iso -rockylinux 9.2 minimal: https://dl.rockylinux.org/vault/rocky/9.2/isos/x86_64/Rocky-9.2-x86_64-minimal.iso -rockylinux 9.2 dvd: https://dl.rockylinux.org/vault/rocky/9.2/isos/x86_64/Rocky-9.2-x86_64-dvd.iso -rockylinux 9.2 boot: https://dl.rockylinux.org/vault/rocky/9.2/isos/x86_64/Rocky-9.2-x86_64-boot.iso -rockylinux 9.1 minimal: https://dl.rockylinux.org/vault/rocky/9.1/isos/x86_64/Rocky-9.1-x86_64-minimal.iso -rockylinux 9.1 dvd: https://dl.rockylinux.org/vault/rocky/9.1/isos/x86_64/Rocky-9.1-x86_64-dvd.iso -rockylinux 9.1 boot: https://dl.rockylinux.org/vault/rocky/9.1/isos/x86_64/Rocky-9.1-x86_64-boot.iso -rockylinux 9.0 minimal: https://dl.rockylinux.org/vault/rocky/9.0/isos/x86_64/Rocky-9.0-x86_64-minimal.iso -rockylinux 9.0 dvd: https://dl.rockylinux.org/vault/rocky/9.0/isos/x86_64/Rocky-9.0-x86_64-dvd.iso -rockylinux 9.0 boot: https://dl.rockylinux.org/vault/rocky/9.0/isos/x86_64/Rocky-9.0-x86_64-boot.iso -rockylinux 8.9 minimal: https://dl.rockylinux.org/vault/rocky/8.9/isos/x86_64/Rocky-8.9-x86_64-minimal.iso -rockylinux 8.9 dvd: https://dl.rockylinux.org/vault/rocky/8.9/isos/x86_64/Rocky-8.9-x86_64-dvd1.iso -rockylinux 8.9 boot: https://dl.rockylinux.org/vault/rocky/8.9/isos/x86_64/Rocky-8.9-x86_64-boot.iso -rockylinux 8.8 minimal: https://dl.rockylinux.org/vault/rocky/8.8/isos/x86_64/Rocky-8.8-x86_64-minimal.iso -rockylinux 8.8 dvd: https://dl.rockylinux.org/vault/rocky/8.8/isos/x86_64/Rocky-8.8-x86_64-dvd1.iso -rockylinux 8.8 boot: https://dl.rockylinux.org/vault/rocky/8.8/isos/x86_64/Rocky-8.8-x86_64-boot.iso -rockylinux 8.7 minimal: https://dl.rockylinux.org/vault/rocky/8.7/isos/x86_64/Rocky-8.7-x86_64-minimal.iso -rockylinux 8.7 dvd: https://dl.rockylinux.org/vault/rocky/8.7/isos/x86_64/Rocky-8.7-x86_64-dvd1.iso -rockylinux 8.7 boot: https://dl.rockylinux.org/vault/rocky/8.7/isos/x86_64/Rocky-8.7-x86_64-boot.iso -rockylinux 8.6 minimal: https://dl.rockylinux.org/vault/rocky/8.6/isos/x86_64/Rocky-8.6-x86_64-minimal.iso -rockylinux 8.6 dvd: https://dl.rockylinux.org/vault/rocky/8.6/isos/x86_64/Rocky-8.6-x86_64-dvd1.iso -rockylinux 8.6 boot: https://dl.rockylinux.org/vault/rocky/8.6/isos/x86_64/Rocky-8.6-x86_64-boot.iso -rockylinux 8.5 minimal: https://dl.rockylinux.org/vault/rocky/8.5/isos/x86_64/Rocky-8.5-x86_64-minimal.iso -rockylinux 8.5 dvd: https://dl.rockylinux.org/vault/rocky/8.5/isos/x86_64/Rocky-8.5-x86_64-dvd1.iso -rockylinux 8.5 boot: https://dl.rockylinux.org/vault/rocky/8.5/isos/x86_64/Rocky-8.5-x86_64-boot.iso -rockylinux 8.4 minimal: https://dl.rockylinux.org/vault/rocky/8.4/isos/x86_64/Rocky-8.4-x86_64-minimal.iso -rockylinux 8.4 dvd: https://dl.rockylinux.org/vault/rocky/8.4/isos/x86_64/Rocky-8.4-x86_64-dvd1.iso -rockylinux 8.4 boot: https://dl.rockylinux.org/vault/rocky/8.4/isos/x86_64/Rocky-8.4-x86_64-boot.iso -rockylinux 8.3 minimal: https://dl.rockylinux.org/vault/rocky/8.3/isos/x86_64/Rocky-8.3-x86_64-minimal.iso -rockylinux 8.3 dvd: https://dl.rockylinux.org/vault/rocky/8.3/isos/x86_64/Rocky-8.3-x86_64-dvd1.iso -rockylinux 8.3 boot: https://dl.rockylinux.org/vault/rocky/8.3/isos/x86_64/Rocky-8.3-x86_64-boot.iso -antix 23.1 net-sysv: /-net_x64-net.iso -antix 23.1 core-sysv: /-net_x64-net.iso/_x64-core.iso -antix 23.1 base-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso -antix 23.1 full-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso -antix 23.1 net-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso -antix 23.1 core-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso -antix 23.1 base-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso -antix 23.1 full-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso -antix 23 net-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso -antix 23 core-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso -antix 23 base-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso -antix 23 full-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso -antix 23 net-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso -antix 23 core-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso -antix 23 base-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso -antix 23 full-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso -antix 22 net-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso -antix 22 core-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso -antix 22 base-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso -antix 22 full-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso -antix 22 net-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-22/-runit-net_x64-net.iso -antix 22 core-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-22/-runit-net_x64-net.iso/runit-antiX-22/-runit_x64-core.iso -antix 22 base-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-22/-runit-net_x64-net.iso/runit-antiX-22/-runit_x64-core.iso/runit-antiX-22/-runit_x64-base.iso -antix 22 full-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-22/-runit-net_x64-net.iso/runit-antiX-22/-runit_x64-core.iso/runit-antiX-22/-runit_x64-base.iso/runit-antiX-22/-runit_x64-full.iso -antix 21 net-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-22/-runit-net_x64-net.iso/runit-antiX-22/-runit_x64-core.iso/runit-antiX-22/-runit_x64-base.iso/runit-antiX-22/-runit_x64-full.iso/-net_x64-net.iso -antix 21 core-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-22/-runit-net_x64-net.iso/runit-antiX-22/-runit_x64-core.iso/runit-antiX-22/-runit_x64-base.iso/runit-antiX-22/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso -antix 21 base-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-22/-runit-net_x64-net.iso/runit-antiX-22/-runit_x64-core.iso/runit-antiX-22/-runit_x64-base.iso/runit-antiX-22/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso -antix 21 full-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-22/-runit-net_x64-net.iso/runit-antiX-22/-runit_x64-core.iso/runit-antiX-22/-runit_x64-base.iso/runit-antiX-22/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso -antix 21 net-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-22/-runit-net_x64-net.iso/runit-antiX-22/-runit_x64-core.iso/runit-antiX-22/-runit_x64-base.iso/runit-antiX-22/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-bullseye/-runit-net_x64-net.iso -antix 21 core-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-22/-runit-net_x64-net.iso/runit-antiX-22/-runit_x64-core.iso/runit-antiX-22/-runit_x64-base.iso/runit-antiX-22/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-bullseye/-runit-net_x64-net.iso/runit-bullseye/-runit_x64-core.iso -antix 21 base-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-22/-runit-net_x64-net.iso/runit-antiX-22/-runit_x64-core.iso/runit-antiX-22/-runit_x64-base.iso/runit-antiX-22/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-bullseye/-runit-net_x64-net.iso/runit-bullseye/-runit_x64-core.iso/runit-bullseye/-runit_x64-base.iso -antix 21 full-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-22/-runit-net_x64-net.iso/runit-antiX-22/-runit_x64-core.iso/runit-antiX-22/-runit_x64-base.iso/runit-antiX-22/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-bullseye/-runit-net_x64-net.iso/runit-bullseye/-runit_x64-core.iso/runit-bullseye/-runit_x64-base.iso/runit-bullseye/-runit_x64-full.iso -kdeneon user: https://files.kde.org/neon/images/user/current/neon-user-20250202-0745.iso -kdeneon testing: https://files.kde.org/neon/images/testing/current/neon-testing-20250128-0430.iso -kdeneon unstable: https://files.kde.org/neon/images/unstable/current/neon-unstable-20250202-1147.iso -kdeneon developer: https://files.kde.org/neon/images/developer/current/neon-unstable-developer-20250203-0038.iso -parrotsec 6.3 home: https://download.parrot.sh/parrot/iso/6.3/Parrot-home-6.3_amd64.iso -parrotsec 6.3 htb: https://download.parrot.sh/parrot/iso/6.3/Parrot-htb-6.3_amd64.iso -parrotsec 6.3 security: https://download.parrot.sh/parrot/iso/6.3/Parrot-security-6.3_amd64.iso -parrotsec 6.2 home: https://download.parrot.sh/parrot/iso/6.2/Parrot-home-6.2_amd64.iso -parrotsec 6.2 htb: https://download.parrot.sh/parrot/iso/6.2/Parrot-htb-6.2_amd64.iso -parrotsec 6.2 security: https://download.parrot.sh/parrot/iso/6.2/Parrot-security-6.2_amd64.iso -parrotsec 6.1 home: https://download.parrot.sh/parrot/iso/6.1/Parrot-home-6.1_amd64.iso -parrotsec 6.1 htb: https://download.parrot.sh/parrot/iso/6.1/Parrot-htb-6.1_amd64.iso -parrotsec 6.1 security: https://download.parrot.sh/parrot/iso/6.1/Parrot-security-6.1_amd64.iso -parrotsec 6.3.2 home: https://download.parrot.sh/parrot/iso/6.3.2/Parrot-home-6.3.2_amd64.iso -parrotsec 6.3.2 htb: https://download.parrot.sh/parrot/iso/6.3.2/Parrot-htb-6.3.2_amd64.iso -parrotsec 6.3.2 security: https://download.parrot.sh/parrot/iso/6.3.2/Parrot-security-6.3.2_amd64.iso -parrotsec 6.2 home: https://download.parrot.sh/parrot/iso/6.2/Parrot-home-6.2_amd64.iso -parrotsec 6.2 htb: https://download.parrot.sh/parrot/iso/6.2/Parrot-htb-6.2_amd64.iso -parrotsec 6.2 security: https://download.parrot.sh/parrot/iso/6.2/Parrot-security-6.2_amd64.iso -parrotsec 6.1 home: https://download.parrot.sh/parrot/iso/6.1/Parrot-home-6.1_amd64.iso -parrotsec 6.1 htb: https://download.parrot.sh/parrot/iso/6.1/Parrot-htb-6.1_amd64.iso -parrotsec 6.1 security: https://download.parrot.sh/parrot/iso/6.1/Parrot-security-6.1_amd64.iso -tinycore 15 Core: http://www.tinycorelinux.net/15.x/x86/release/Core-15.0.iso -tinycore 15 TinyCore: http://www.tinycorelinux.net/15.x/x86/release/TinyCore-15.0.iso -tinycore 15 CorePlus: http://www.tinycorelinux.net/15.x/x86/release/CorePlus-15.0.iso -tinycore 15 CorePure64: http://www.tinycorelinux.net/15.x/x86_64/release/CorePure64-15.0.iso -tinycore 15 TinyCorePure64: http://www.tinycorelinux.net/15.x/x86_64/release/TinyCorePure64-15.0.iso -tinycore 14 Core: http://www.tinycorelinux.net/14.x/x86/release/Core-14.0.iso -tinycore 14 TinyCore: http://www.tinycorelinux.net/14.x/x86/release/TinyCore-14.0.iso -tinycore 14 CorePlus: http://www.tinycorelinux.net/14.x/x86/release/CorePlus-14.0.iso -tinycore 14 CorePure64: http://www.tinycorelinux.net/14.x/x86_64/release/CorePure64-14.0.iso -tinycore 14 TinyCorePure64: http://www.tinycorelinux.net/14.x/x86_64/release/TinyCorePure64-14.0.iso -antix 23.2 net-sysv: /-net_x64-net.iso -antix 23.2 core-sysv: /-net_x64-net.iso/_x64-core.iso -antix 23.2 base-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso -antix 23.2 full-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso -antix 23.2 net-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso -antix 23.2 core-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso -antix 23.2 base-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso -antix 23.2 full-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso -antix 23.1 net-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso -antix 23.1 core-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso -antix 23.1 base-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso -antix 23.1 full-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso -antix 23.1 net-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso -antix 23.1 core-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso -antix 23.1 base-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso -antix 23.1 full-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso -antix 23 net-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso -antix 23 core-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso -antix 23 base-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso -antix 23 full-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso -antix 23 net-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso -antix 23 core-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso -antix 23 base-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso -antix 23 full-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso -antix 22 net-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso -antix 22 core-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso -antix 22 base-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso -antix 22 full-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso -antix 22 net-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-22/-runit-net_x64-net.iso -antix 22 core-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-22/-runit-net_x64-net.iso/runit-antiX-22/-runit_x64-core.iso -antix 22 base-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-22/-runit-net_x64-net.iso/runit-antiX-22/-runit_x64-core.iso/runit-antiX-22/-runit_x64-base.iso -antix 22 full-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-22/-runit-net_x64-net.iso/runit-antiX-22/-runit_x64-core.iso/runit-antiX-22/-runit_x64-base.iso/runit-antiX-22/-runit_x64-full.iso -antix 21 net-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-22/-runit-net_x64-net.iso/runit-antiX-22/-runit_x64-core.iso/runit-antiX-22/-runit_x64-base.iso/runit-antiX-22/-runit_x64-full.iso/-net_x64-net.iso -antix 21 core-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-22/-runit-net_x64-net.iso/runit-antiX-22/-runit_x64-core.iso/runit-antiX-22/-runit_x64-base.iso/runit-antiX-22/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso -antix 21 base-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-22/-runit-net_x64-net.iso/runit-antiX-22/-runit_x64-core.iso/runit-antiX-22/-runit_x64-base.iso/runit-antiX-22/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso -antix 21 full-sysv: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-22/-runit-net_x64-net.iso/runit-antiX-22/-runit_x64-core.iso/runit-antiX-22/-runit_x64-base.iso/runit-antiX-22/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso -antix 21 net-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-22/-runit-net_x64-net.iso/runit-antiX-22/-runit_x64-core.iso/runit-antiX-22/-runit_x64-base.iso/runit-antiX-22/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-bullseye/-runit-net_x64-net.iso -antix 21 core-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-22/-runit-net_x64-net.iso/runit-antiX-22/-runit_x64-core.iso/runit-antiX-22/-runit_x64-base.iso/runit-antiX-22/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-bullseye/-runit-net_x64-net.iso/runit-bullseye/-runit_x64-core.iso -antix 21 base-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-22/-runit-net_x64-net.iso/runit-antiX-22/-runit_x64-core.iso/runit-antiX-22/-runit_x64-base.iso/runit-antiX-22/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-bullseye/-runit-net_x64-net.iso/runit-bullseye/-runit_x64-core.iso/runit-bullseye/-runit_x64-base.iso -antix 21 full-runit: /-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.2/-runit-net_x64-net.iso/runit-antiX-23.2/-runit_x64-core.iso/runit-antiX-23.2/-runit_x64-base.iso/runit-antiX-23.2/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23.1/-runit-net_x64-net.iso/runit-antiX-23.1/-runit_x64-core.iso/runit-antiX-23.1/-runit_x64-base.iso/runit-antiX-23.1/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-23/-runit-net_x64-net.iso/runit-antiX-23/-runit_x64-core.iso/runit-antiX-23/-runit_x64-base.iso/runit-antiX-23/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-antiX-22/-runit-net_x64-net.iso/runit-antiX-22/-runit_x64-core.iso/runit-antiX-22/-runit_x64-base.iso/runit-antiX-22/-runit_x64-full.iso/-net_x64-net.iso/_x64-core.iso/_x64-base.iso/_x64-full.iso/runit-bullseye/-runit-net_x64-net.iso/runit-bullseye/-runit_x64-core.iso/runit-bullseye/-runit_x64-base.iso/runit-bullseye/-runit_x64-full.iso -antix 23.2 net-sysv: https://sourceforge.net/projects/antix-linux/files/Final/antiX-23.2/antiX-23.2-net_x64-net.iso -antix 23.2 core-sysv: https://sourceforge.net/projects/antix-linux/files/Final/antiX-23.2/antiX-23.2_x64-core.iso -antix 23.2 base-sysv: https://sourceforge.net/projects/antix-linux/files/Final/antiX-23.2/antiX-23.2_x64-base.iso -antix 23.2 full-sysv: https://sourceforge.net/projects/antix-linux/files/Final/antiX-23.2/antiX-23.2_x64-full.iso -antix 23.2 net-runit: https://sourceforge.net/projects/antix-linux/files/Final/antiX-23.2/runit-antiX-23.2/antiX-23.2-runit-net_x64-net.iso -antix 23.2 core-runit: https://sourceforge.net/projects/antix-linux/files/Final/antiX-23.2/runit-antiX-23.2/antiX-23.2-runit_x64-core.iso -antix 23.2 base-runit: https://sourceforge.net/projects/antix-linux/files/Final/antiX-23.2/runit-antiX-23.2/antiX-23.2-runit_x64-base.iso -antix 23.2 full-runit: https://sourceforge.net/projects/antix-linux/files/Final/antiX-23.2/runit-antiX-23.2/antiX-23.2-runit_x64-full.iso -antix 23.1 net-sysv: https://sourceforge.net/projects/antix-linux/files/Final/antiX-23.1/antiX-23.1-net_x64-net.iso -antix 23.1 core-sysv: https://sourceforge.net/projects/antix-linux/files/Final/antiX-23.1/antiX-23.1_x64-core.iso -antix 23.1 base-sysv: https://sourceforge.net/projects/antix-linux/files/Final/antiX-23.1/antiX-23.1_x64-base.iso -antix 23.1 full-sysv: https://sourceforge.net/projects/antix-linux/files/Final/antiX-23.1/antiX-23.1_x64-full.iso -antix 23.1 net-runit: https://sourceforge.net/projects/antix-linux/files/Final/antiX-23.1/runit-antiX-23.1/antiX-23.1-runit-net_x64-net.iso -antix 23.1 core-runit: https://sourceforge.net/projects/antix-linux/files/Final/antiX-23.1/runit-antiX-23.1/antiX-23.1-runit_x64-core.iso -antix 23.1 base-runit: https://sourceforge.net/projects/antix-linux/files/Final/antiX-23.1/runit-antiX-23.1/antiX-23.1-runit_x64-base.iso -antix 23.1 full-runit: https://sourceforge.net/projects/antix-linux/files/Final/antiX-23.1/runit-antiX-23.1/antiX-23.1-runit_x64-full.iso -antix 23 net-sysv: https://sourceforge.net/projects/antix-linux/files/Final/antiX-23/antiX-23-net_x64-net.iso -antix 23 core-sysv: https://sourceforge.net/projects/antix-linux/files/Final/antiX-23/antiX-23_x64-core.iso -antix 23 base-sysv: https://sourceforge.net/projects/antix-linux/files/Final/antiX-23/antiX-23_x64-base.iso -antix 23 full-sysv: https://sourceforge.net/projects/antix-linux/files/Final/antiX-23/antiX-23_x64-full.iso -antix 23 net-runit: https://sourceforge.net/projects/antix-linux/files/Final/antiX-23/runit-antiX-23/antiX-23-runit-net_x64-net.iso -antix 23 core-runit: https://sourceforge.net/projects/antix-linux/files/Final/antiX-23/runit-antiX-23/antiX-23-runit_x64-core.iso -antix 23 base-runit: https://sourceforge.net/projects/antix-linux/files/Final/antiX-23/runit-antiX-23/antiX-23-runit_x64-base.iso -antix 23 full-runit: https://sourceforge.net/projects/antix-linux/files/Final/antiX-23/runit-antiX-23/antiX-23-runit_x64-full.iso -antix 22 net-sysv: https://sourceforge.net/projects/antix-linux/files/Final/antiX-22/antiX-22-net_x64-net.iso -antix 22 core-sysv: https://sourceforge.net/projects/antix-linux/files/Final/antiX-22/antiX-22_x64-core.iso -antix 22 base-sysv: https://sourceforge.net/projects/antix-linux/files/Final/antiX-22/antiX-22_x64-base.iso -antix 22 full-sysv: https://sourceforge.net/projects/antix-linux/files/Final/antiX-22/antiX-22_x64-full.iso -antix 22 net-runit: https://sourceforge.net/projects/antix-linux/files/Final/antiX-22/runit-antiX-22/antiX-22-runit-net_x64-net.iso -antix 22 core-runit: https://sourceforge.net/projects/antix-linux/files/Final/antiX-22/runit-antiX-22/antiX-22-runit_x64-core.iso -antix 22 base-runit: https://sourceforge.net/projects/antix-linux/files/Final/antiX-22/runit-antiX-22/antiX-22-runit_x64-base.iso -antix 22 full-runit: https://sourceforge.net/projects/antix-linux/files/Final/antiX-22/runit-antiX-22/antiX-22-runit_x64-full.iso -antix 21 net-sysv: https://sourceforge.net/projects/antix-linux/files/Final/antiX-21/antiX-21-net_x64-net.iso -antix 21 core-sysv: https://sourceforge.net/projects/antix-linux/files/Final/antiX-21/antiX-21_x64-core.iso -antix 21 base-sysv: https://sourceforge.net/projects/antix-linux/files/Final/antiX-21/antiX-21_x64-base.iso -antix 21 full-sysv: https://sourceforge.net/projects/antix-linux/files/Final/antiX-21/antiX-21_x64-full.iso -antix 21 net-runit: https://sourceforge.net/projects/antix-linux/files/Final/antiX-21/runit-bullseye/antiX-21-runit-net_x64-net.iso -antix 21 core-runit: https://sourceforge.net/projects/antix-linux/files/Final/antiX-21/runit-bullseye/antiX-21-runit_x64-core.iso -antix 21 base-runit: https://sourceforge.net/projects/antix-linux/files/Final/antiX-21/runit-bullseye/antiX-21-runit_x64-base.iso -antix 21 full-runit: https://sourceforge.net/projects/antix-linux/files/Final/antiX-21/runit-bullseye/antiX-21-runit_x64-full.iso -vanillaos 22.10-r8: https://github.com/Vanilla-OS/live-iso/releases/download/22.10-r8/VanillaOS-22.10-all.20230226.iso -vanillaos 22.10-r7.5: https://github.com/Vanilla-OS/live-iso/releases/download/22.10-r7.5/VanillaOS-22.10-all.20230214.iso -vanillaos 22.10-r7: https://github.com/Vanilla-OS/live-iso/releases/download/22.10-r7.5/VanillaOS-22.10-all.20230214.iso -vanillaos 22.10-r6: https://github.com/Vanilla-OS/live-iso/releases/download/22.10-r6/VanillaOS-22.10-all.20230123.iso -vanillaos 22.10-r5: https://github.com/Vanilla-OS/live-iso/releases/download/22.10-r5/VanillaOS-22.10-all.20230116.iso -vanillaos 22.10-r4: https://github.com/Vanilla-OS/live-iso/releases/download/22.10-r4/VanillaOS-22.10-all.20230115.iso -vanillaos 22.10-r3: https://github.com/Vanilla-OS/live-iso/releases/download/22.10-r3/VanillaOS-22.10-all.20230105.iso -vanillaos 22.10-r2: https://github.com/Vanilla-OS/live-iso/releases/download/22.10-r2/VanillaOS-22.10-all.20221231.iso -vanillaos 22.10-r1: https://github.com/Vanilla-OS/live-iso/releases/download/22.10-r1/VanillaOS-22.10-all.20221230.iso -vanillaos 22.10: https://github.com/Vanilla-OS/live-iso/releases/download/22.10-r8/VanillaOS-22.10-all.20230226.iso -vanillaos 2.0: https://github.com/Vanilla-OS/live-iso/releases/download/2.0/VanillaOS-2-stable.20250209.iso -bazzite latest gnome: https://download.bazzite.gg/bazzite-gnome-stable-amd64.iso -bazzite latest kde: https://download.bazzite.gg/bazzite-stable-amd64.iso -tinycore 15 Core: https://distro.ibiblio.org/tinycorelinux/15.x/x86/release/Core-15.0.iso -tinycore 15 TinyCore: https://distro.ibiblio.org/tinycorelinux/15.x/x86/release/TinyCore-15.0.iso -tinycore 15 CorePlus: https://distro.ibiblio.org/tinycorelinux/15.x/x86/release/CorePlus-15.0.iso -tinycore 15 CorePure64: https://distro.ibiblio.org/tinycorelinux/15.x/x86_64/release/CorePure64-15.0.iso -tinycore 15 TinyCorePure64: https://distro.ibiblio.org/tinycorelinux/15.x/x86_64/release/TinyCorePure64-15.0.iso -tinycore 14 Core: https://distro.ibiblio.org/tinycorelinux/14.x/x86/release/Core-14.0.iso -tinycore 14 TinyCore: https://distro.ibiblio.org/tinycorelinux/14.x/x86/release/TinyCore-14.0.iso -tinycore 14 CorePlus: https://distro.ibiblio.org/tinycorelinux/14.x/x86/release/CorePlus-14.0.iso -tinycore 14 CorePure64: https://distro.ibiblio.org/tinycorelinux/14.x/x86_64/release/CorePure64-14.0.iso -tinycore 14 TinyCorePure64: https://distro.ibiblio.org/tinycorelinux/14.x/x86_64/release/TinyCorePure64-14.0.iso -gnomeos nightly: https://1270333429.rsc.cdn77.org/nightly/790243/gnome_os_installer_790243.iso -gnomeos 48.alpha: https://download.gnome.org/gnomeos/48.alpha/gnome_os_installer_48.alpha.iso -gnomeos 47.rc: https://download.gnome.org/gnomeos/47.rc/gnome_os_installer_47.rc.iso -gnomeos 47.beta: https://download.gnome.org/gnomeos/47.beta/gnome_os_installer_47.beta.iso -gnomeos 47.alpha: https://download.gnome.org/gnomeos/47.alpha/gnome_os_installer_47.alpha.iso -gnomeos 47.0: https://download.gnome.org/gnomeos/47.0/gnome_os_installer_47.0.iso -gnomeos 46.rc: https://download.gnome.org/gnomeos/46.rc/gnome_os_installer_46.rc.iso -gnomeos 46.beta: https://download.gnome.org/gnomeos/46.beta/gnome_os_installer_46.beta.iso -gnomeos 46.alpha: https://download.gnome.org/gnomeos/46.alpha/gnome_os_installer_46.alpha.iso -gnomeos 46.0: https://download.gnome.org/gnomeos/46.0/gnome_os_installer_46.iso -gnomeos 45.rc: https://download.gnome.org/gnomeos/45.rc/gnome_os_installer_45.rc.iso -gnomeos 45.beta: https://download.gnome.org/gnomeos/45.beta/gnome_os_installer_45.beta.iso -gnomeos 44.rc: https://download.gnome.org/gnomeos/44.rc/gnome_os_installer_44.rc.iso -gnomeos 44.beta: https://download.gnome.org/gnomeos/44.beta/gnome_os_installer_44.beta.iso -gnomeos 44.0: https://download.gnome.org/gnomeos/44.0/gnome_os_installer_44.0.iso -gnomeos 43.beta: https://download.gnome.org/gnomeos/43.beta/gnome_os_installer_43.beta.iso -gnomeos 43.alpha: https://download.gnome.org/gnomeos/43.alpha/gnome_os_installer_43.alpha.iso -gnomeos 43.0: https://download.gnome.org/gnomeos/43.0/gnome_os_installer_43.0.iso -gnomeos 42.rc: https://download.gnome.org/gnomeos/42.rc/gnome_os_installer_42.rc.iso -gnomeos 42.beta: https://download.gnome.org/gnomeos/42.beta/gnome_os_installer_42.beta.iso -gnomeos 42.0: https://download.gnome.org/gnomeos/42.0/gnome_os_installer_42.0.iso -gnomeos 41.rc: https://download.gnome.org/gnomeos/41.rc/gnome_os_installer_41.rc.iso -gnomeos 41.beta: https://download.gnome.org/gnomeos/41.beta/gnome_os_installer_41.beta.iso -gnomeos 41.0: https://download.gnome.org/gnomeos/41.0/gnome_os_installer_41.0.iso -gnomeos 40.rc: https://download.gnome.org/gnomeos/40.rc/gnome_os_installer_40.rc.iso -gnomeos 40.beta: https://download.gnome.org/gnomeos/40.beta/gnome_os_installer_40.beta.iso -gnomeos 40.0: https://download.gnome.org/gnomeos/40.0/gnome_os_installer_40.0.iso -gnomeos 3.38.1: https://download.gnome.org/gnomeos/3.38.1/gnome_os_installer.iso -gnomeos 3.38.0: https://download.gnome.org/gnomeos/3.38.0/gnome_os_installer.iso -gnomeos nightly: https://1270333429.rsc.cdn77.org/nightly/790243/gnome_os_installer_790243.iso -gnomeos 48.alpha: https://download.gnome.org/gnomeos/48.alpha/gnome_os_installer_48.alpha.8.iso -gnomeos 47.rc: https://download.gnome.org/gnomeos/47.rc/gnome_os_installer_47.rc.iso -gnomeos 47.beta: https://download.gnome.org/gnomeos/47.beta/gnome_os_installer_47.beta.iso -gnomeos 47.alpha: https://download.gnome.org/gnomeos/47.alpha/gnome_os_installer_47.alpha.iso -gnomeos 47.0: https://download.gnome.org/gnomeos/47.0/gnome_os_installer_47.0.iso -gnomeos 46.rc: https://download.gnome.org/gnomeos/46.rc/gnome_os_installer_46.rc.iso -gnomeos 46.beta: https://download.gnome.org/gnomeos/46.beta/gnome_os_installer_46.beta.iso -gnomeos 46.alpha: https://download.gnome.org/gnomeos/46.alpha/gnome_os_installer_46.alpha.iso -gnomeos 46.0: https://download.gnome.org/gnomeos/46.0/gnome_os_installer_46.iso -gnomeos 45.rc: https://download.gnome.org/gnomeos/45.rc/gnome_os_installer_45.rc.iso -gnomeos 45.beta: https://download.gnome.org/gnomeos/45.beta/gnome_os_installer_45.beta.iso -gnomeos 44.rc: https://download.gnome.org/gnomeos/44.rc/gnome_os_installer_44.rc.iso -gnomeos 44.beta: https://download.gnome.org/gnomeos/44.beta/gnome_os_installer_44.beta.iso -gnomeos 44.0: https://download.gnome.org/gnomeos/44.0/gnome_os_installer_44.0.iso -gnomeos 43.beta: https://download.gnome.org/gnomeos/43.beta/gnome_os_installer_43.beta.iso -gnomeos 43.alpha: https://download.gnome.org/gnomeos/43.alpha/gnome_os_installer_43.alpha.iso -gnomeos 43.0: https://download.gnome.org/gnomeos/43.0/gnome_os_installer_43.0.iso -gnomeos 42.rc: https://download.gnome.org/gnomeos/42.rc/gnome_os_installer_42.rc.iso -gnomeos 42.beta: https://download.gnome.org/gnomeos/42.beta/gnome_os_installer_42.beta.iso -gnomeos 42.0: https://download.gnome.org/gnomeos/42.0/gnome_os_installer_42.0.iso -gnomeos 41.rc: https://download.gnome.org/gnomeos/41.rc/gnome_os_installer_41.rc.iso -gnomeos 41.beta: https://download.gnome.org/gnomeos/41.beta/gnome_os_installer_41.beta.iso -gnomeos 41.0: https://download.gnome.org/gnomeos/41.0/gnome_os_installer_41.0.iso -gnomeos 40.rc: https://download.gnome.org/gnomeos/40.rc/gnome_os_installer_40.rc.iso -gnomeos 40.beta: https://download.gnome.org/gnomeos/40.beta/gnome_os_installer_40.beta.iso -gnomeos 40.0: https://download.gnome.org/gnomeos/40.0/gnome_os_installer_40.0.iso -gnomeos 3.38.1: https://download.gnome.org/gnomeos/3.38.1/gnome_os_installer.iso -gnomeos 3.38.0: https://download.gnome.org/gnomeos/3.38.0/gnome_os_installer.iso -gnomeos nightly: https://1270333429.rsc.cdn77.org/nightly/790243/gnome_os_installer_790243.iso -gnomeos 48.alpha: https://download.gnome.org/gnomeos/48.alpha/gnome_os_installer_48.alpha.8.iso -gnomeos 47.rc: https://download.gnome.org/gnomeos/47.rc/gnome_os_installer_47.rc.iso -gnomeos 47.beta: https://download.gnome.org/gnomeos/47.beta/gnome_os_installer_47.beta.iso -gnomeos 47.alpha: https://download.gnome.org/gnomeos/47.alpha/gnome_os_installer_47.alpha.iso -gnomeos 47.0: https://download.gnome.org/gnomeos/47.0/gnome_os_installer_47.0.iso -gnomeos 46.rc: https://download.gnome.org/gnomeos/46.rc/gnome_os_installer_46.rc.iso -gnomeos 46.beta: https://download.gnome.org/gnomeos/46.beta/gnome_os_installer_46.beta.iso -gnomeos 46.alpha: https://download.gnome.org/gnomeos/46.alpha/gnome_os_installer_46.alpha.iso -gnomeos 46.0: https://download.gnome.org/gnomeos/46.0/gnome_os_installer_46.iso -gnomeos 45.rc: https://download.gnome.org/gnomeos/45.rc/gnome_os_installer_45.rc.iso -gnomeos 45.beta: https://download.gnome.org/gnomeos/45.beta/gnome_os_installer_45.beta.iso -gnomeos 44.rc: https://download.gnome.org/gnomeos/44.rc/gnome_os_installer_44.rc.iso -gnomeos 44.beta: https://download.gnome.org/gnomeos/44.beta/gnome_os_installer_44.beta.iso -gnomeos 44.0: https://download.gnome.org/gnomeos/44.0/gnome_os_installer_44.0.iso -gnomeos 43.beta: https://download.gnome.org/gnomeos/43.beta/gnome_os_installer_43.beta.iso -gnomeos 43.alpha: https://download.gnome.org/gnomeos/43.alpha/gnome_os_installer_43.alpha.iso -gnomeos 43.0: https://download.gnome.org/gnomeos/43.0/gnome_os_installer_43.0.iso -gnomeos 42.rc: https://download.gnome.org/gnomeos/42.rc/gnome_os_installer_42.rc.iso -gnomeos 42.beta: https://download.gnome.org/gnomeos/42.beta/gnome_os_installer_42.beta.iso -gnomeos 42.0: https://download.gnome.org/gnomeos/42.0/gnome_os_installer_42.0.iso -gnomeos 41.rc: https://download.gnome.org/gnomeos/41.rc/gnome_os_installer_41.rc.iso -gnomeos 41.beta: https://download.gnome.org/gnomeos/41.beta/gnome_os_installer_41.beta.iso -gnomeos 41.0: https://download.gnome.org/gnomeos/41.0/gnome_os_installer_41.0.iso -gnomeos 40.rc: https://download.gnome.org/gnomeos/40.rc/gnome_os_installer_40.rc.iso -gnomeos 40.beta: https://download.gnome.org/gnomeos/40.beta/gnome_os_installer_40.beta.iso -gnomeos 40.0: https://download.gnome.org/gnomeos/40.0/gnome_os_installer_40.0.iso -gnomeos 3.38.1: https://download.gnome.org/gnomeos/3.38.1/gnome_os_installer.iso -gnomeos 3.38.0: https://download.gnome.org/gnomeos/3.38.0/gnome_os_installer.iso diff --git a/public/agarimos b/public/agarimos index d28354c..5968ac6 100644 --- a/public/agarimos +++ b/public/agarimos @@ -5,5 +5,24 @@ BASEDOF="Void" DESCRIPTION="Includes a minimum set of applications so you can build your system on your own." HOMEPAGE="https://sourceforge.net/projects/agarimos" CREDENTIALS="anon:voidlinux,root:voidlinux" + + RELEASES="latest" EDITIONS="xfce4 plasma lxqt-kwin gnome cinnamon" + +function releases_() { + echo latest +} + +function editions_() { + echo plasma xfce4 cinnamon lxqt-kwin gnome +} + +function get_() { + local REL=$(echo "${EDITION}" | tr '[:lower:]' '[:upper:]') + local ISOS=$(web_pipe "https://sourceforge.net/projects/agarimos/rss?path=/" | grep 'title>> "${CONF_FILE}" +} + diff --git a/public/alpine b/public/alpine index 50d35fb..ea39e3c 100644 --- a/public/alpine +++ b/public/alpine @@ -5,5 +5,30 @@ BASEDOF="-" DESCRIPTION="Security-oriented, lightweight Linux distribution based on musl libc and busybox" HOMEPAGE="https://alpinelinux.org/" CREDENTIALS="-" + + RELEASES="v3.21 v3.20 v3.19 v3.18 v3.17 v3.16 v3.15 v3.14 v3.13 v3.12" + +function releases_() { + local REL="" + local RELS="" + RELS=$(web_pipe "https://dl-cdn.alpinelinux.org/alpine/" | grep '"v' | cut -d'"' -f2 | tr -d / | sort -Vr | head -n 10) + for REL in ${RELS}; do + if web_check "https://dl-cdn.alpinelinux.org/alpine/${REL}/releases/x86_64/"; then + echo -n "${REL} " + fi + done +} + +function get_() { + local HASH="" + local ISO="" + local URL="https://dl-cdn.alpinelinux.org/alpine/${RELEASE}/releases/x86_64" + local VERSION="" + VERSION=$(web_pipe "${URL}/latest-releases.yaml" | awk '/"Xen"/{found=0} {if(found) print} /"Virtual"/{found=1}' | grep 'version:' | awk '{print $2}') + ISO="alpine-virt-${VERSION}-x86_64.iso" + HASH=$(web_pipe "${URL}/latest-releases.yaml" | awk '/"Xen"/{found=0} {if(found) print} /"Virtual"/{found=1}' | grep 'sha256:' | awk '{print $2}') + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/android b/public/android index dfff1a1..f8f2706 100644 --- a/public/android +++ b/public/android @@ -5,5 +5,36 @@ BASEDOF="-" DESCRIPTION="Port Android Open Source Project to x86 platform" HOMEPAGE="https://www.android-x86.org" CREDENTIALS="-" + + RELEASES="9.0 8.1 7.1" EDITIONS="x86_64 x86" + +function releases_() { + echo 9.0 8.1 7.1 +} + +function editions_() { + echo x86_64 x86 +} + +function get_() { + local HASH="" + local ISO="" + local JSON_ALL="" + local JSON_REL="" + local URL="https://mirrors.gigenet.com/OSDN/android-x86" + JSON_ALL=$(web_pipe "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"))))') + ISO=$(echo "${JSON_REL}" | jq -r .n) + HASH=$(echo "${JSON_REL}" | jq -r .hash.sha256) + # Traverse the directories to find the .iso location + for DIR in $(web_pipe "${URL}" | grep -o -E '[0-9]{5}' | sort -ur); do + if web_pipe "${URL}/${DIR}" | grep "${ISO}" &>/dev/null; then + URL="${URL}/${DIR}" + break + fi + done + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/antix b/public/antix index 84eae6d..dac21a6 100644 --- a/public/antix +++ b/public/antix @@ -5,5 +5,41 @@ BASEDOF="Debian" DESCRIPTION="Fast, lightweight and easy to install systemd-free linux live CD distribution based on Debian Stable for Intel-AMD x86 compatible systems" HOMEPAGE="https://antixlinux.com" CREDENTIALS="-" + + RELEASES="23.2 23.1 23 22 21" EDITIONS="net-sysv net-runit full-sysv full-runit core-sysv core-runit base-sysv base-runit" + +function releases_() { + echo 23.2 23.1 23 22 21 +} + +function editions_() { + echo net-sysv core-sysv base-sysv full-sysv net-runit core-runit base-runit full-runit +} + +function get_() { + local HASH="" + local ISO="antiX-${RELEASE}" + local README="README" + local URL="https://sourceforge.net/projects/antix-linux/files/Final/antiX-${RELEASE}" + + # antiX uses a different URL and ISO naming for runit editions + if [[ "${EDITION}" == *"runit"* ]];then + ISO+="-runit" + README="README2" + case ${RELEASE} in + 21) URL+="/runit-bullseye";; + *) URL+="/runit-antiX-${RELEASE}";; + esac + fi + case ${EDITION} in + base-*) ISO+="_x64-base.iso";; + core-*) ISO+="_x64-core.iso";; + full-*) ISO+="_x64-full.iso";; + net-*) ISO+="-net_x64-net.iso";; + esac + HASH=$(web_pipe "${URL}/${README}.txt" | grep "${ISO}" | cut -d' ' -f1 | head -n 1) + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/archcraft b/public/archcraft index 1629830..9b5378a 100644 --- a/public/archcraft +++ b/public/archcraft @@ -5,5 +5,20 @@ BASEDOF="Arch" DESCRIPTION="Yet another minimal Linux distribution, based on Arch Linux" HOMEPAGE="https://archcraft.io" CREDENTIALS="-" + + RELEASES="latest" + +function releases_() { + echo latest +} + +function get_() { + local HASH="" + local URL="" + URL="https://sourceforge.net/projects/archcraft/files/${RELEASE}/download" + URL="$(web_redirect "${URL}" | cut -d? -f1)" + echo "${URL} ${HASH}" +} + diff --git a/public/archlinux b/public/archlinux index d1181cd..ad79647 100644 --- a/public/archlinux +++ b/public/archlinux @@ -5,5 +5,21 @@ BASEDOF="-" DESCRIPTION="Lightweight and flexible Linux® distribution that tries to Keep It Simple" HOMEPAGE="https://archlinux.org" CREDENTIALS="-" + + RELEASES="latest" + +function releases_() { + echo latest +} + +function get_() { + local HASH="" + local ISO="" + local URL="https://mirror.rackspace.com/archlinux" + ISO=$(web_pipe "https://archlinux.org/releng/releases/json/" | jq -r '.releases[0].iso_url') + HASH=$(web_pipe "https://archlinux.org/releng/releases/json/" | jq -r '.releases[0].sha256_sum') + echo "${URL}${ISO} ${HASH}" +} + diff --git a/public/arco b/public/arco index 25e2402..28be14d 100644 --- a/public/arco +++ b/public/arco @@ -5,5 +5,27 @@ BASEDOF="Arch" DESCRIPTION="Is all about becoming an expert in linux" HOMEPAGE="https://arcolinux.com" CREDENTIALS="-" -RELEASES="v25.02.04 v25.01.05 v25.01.01 v24.12.02 v24.11.01" + + +RELEASES="v25.03.05 v25.02.04 v25.01.05 v25.01.01 v24.12.02" EDITIONS="pro plasma net" + +function releases_() { + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe "https://mirror.accum.se/mirror/arcolinux.info/iso/" | grep -o -E -e "v[[:digit:]]{2}.[[:digit:]]{2}.[[:digit:]]{2}" | sort -ru | head -n 5) +} + +function editions_() { + echo net plasma pro +} + +function get_() { + local HASH="" + local ISO="" + local URL="" + URL="https://mirror.accum.se/mirror/arcolinux.info/iso/${RELEASE}" + ISO="arco${EDITION}-${RELEASE}-x86_64.iso" + HASH=$(web_pipe "${URL}/${ISO}.sha256" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/artixlinux b/public/artixlinux index 67d1984..63fadac 100644 --- a/public/artixlinux +++ b/public/artixlinux @@ -5,5 +5,27 @@ BASEDOF="Arch" DESCRIPTION="The Art of Linux. Simple. Fast. Systemd-free" HOMEPAGE="https://artixlinux.org" CREDENTIALS="-" + + RELEASES="20240823" EDITIONS="xfce-s6 xfce-runit xfce-openrc xfce-dinit plasma-s6 plasma-runit plasma-openrc plasma-dinit mate-s6 mate-runit mate-openrc mate-dinit lxqt-s6 lxqt-runit lxqt-openrc lxqt-dinit lxde-s6 lxde-runit lxde-openrc lxde-dinit community-qt community-gtk cinnamon-s6 cinnamon-runit cinnamon-openrc cinnamon-dinit base-s6 base-runit base-openrc base-dinit" + +function releases_() { + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe "https://mirror1.artixlinux.org/iso/" | grep "artix-" | cut -d'"' -f2 | grep -v sig | cut -d'-' -f 4 | sort -ru | tail -n 1) +} + +function editions_() { + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe "https://mirror1.artixlinux.org/iso/" | grep "artix-" | cut -d'"' -f2 | grep -v sig | cut -d'-' -f2-3 | sort -u) +} + +function get_() { + local HASH="" + local ISO="" + local URL="https://iso.artixlinux.org/iso" + ISO="artix-${EDITION}-${RELEASE}-x86_64.iso" + HASH=$(web_pipe "${URL}/sha256sums" | grep "${ISO}") + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/athenaos b/public/athenaos index 883b9c0..2d502ef 100644 --- a/public/athenaos +++ b/public/athenaos @@ -5,5 +5,25 @@ BASEDOF="Arch" DESCRIPTION="Offer a different experience than the most used pentesting distributions by providing only tools that fit with the user needs and improving the access to hacking resources and learning materials" HOMEPAGE="https://athenaos.org" CREDENTIALS="-" + + RELEASES="v23.11 v23.06.23" + +function releases_() { + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe "https://api.github.com/repos/Athena-OS/athena/releases" | grep 'download_url' | grep rolling | cut -d'/' -f8 | sort -u) +} + +function get_() { + local HASH="" + local URL="https://github.com/Athena-OS/athena/releases/download/${RELEASE}" + local ISO="athena-rolling-x86_64.iso" + HASH=$(web_pipe "${URL}/${ISO}.sha256" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + +function specific_tweaks() { + echo "disk_size=\"32G\"" >> "${CONF_FILE}" +} + diff --git a/public/batocera b/public/batocera index 249f035..e433746 100644 --- a/public/batocera +++ b/public/batocera @@ -5,5 +5,32 @@ BASEDOF="-" DESCRIPTION="Retro-gaming distribution with the aim of turning any computer/nano computer into a gaming console during a game or permanently" HOMEPAGE="https://batocera.org" CREDENTIALS="-" +GUEST="xfce-s6 xfce-runit xfce-openrc xfce-dinit plasma-s6 plasma-runit plasma-openrc plasma-dinit mate-s6 mate-runit mate-openrc mate-dinit lxqt-s6 lxqt-runit lxqt-openrc lxqt-dinit lxde-s6 lxde-runit lxde-openrc lxde-dinit community-qt community-gtk cinnamon-s6 cinnamon-runit cinnamon-openrc cinnamon-dinit base-s6 base-runit base-openrc base-dinit" +IMAGE_TYPE="" RELEASES="41 40 39 38 37" + +function releases_() { + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe "https://mirrors.o2switch.fr/batocera/x86_64/stable/" | grep ^\> "${CONF_FILE}" +} + diff --git a/public/bazzite b/public/bazzite index 2280778..9bbd57a 100644 --- a/public/bazzite +++ b/public/bazzite @@ -5,5 +5,32 @@ BASEDOF="Fedora SteamOS" DESCRIPTION="Container native gaming and a ready-to-game SteamOS like" HOMEPAGE="https://bazzite.gg" CREDENTIALS="-" + + RELEASES="latest" EDITIONS="kde gnome" + +function releases_() { + echo latest +} + +function editions_() { + echo gnome kde +} + +function get_() { + local HASH="" + local ISO="" + local URL="https://download.bazzite.gg" + case ${EDITION} in + gnome) ISO="bazzite-gnome-stable-amd64.iso";; + kde) ISO="bazzite-stable-amd64.iso";; + esac + HASH=$(web_pipe "${URL}/${ISO}-CHECKSUM" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + +function specific_tweaks() { + echo "disk_size=\"64G\"" >> "${CONF_FILE}" +} + diff --git a/public/biglinux b/public/biglinux index b0b0868..83f8032 100644 --- a/public/biglinux +++ b/public/biglinux @@ -5,5 +5,26 @@ BASEDOF="Manjaro" DESCRIPTION="Is the right choice if you want to have an easy and enriching experience with Linux. It has been perfected over more than 19 years, following our motto: 'In search of the perfect system'" HOMEPAGE="https://www.biglinux.com.br" CREDENTIALS="-" + + RELEASES="" EDITIONS="" + +function releases_() { + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe "https://iso.biglinux.com.br" | grep -Eo 'biglinux_[0-9]{4}(-[0-9]{2}){2}_k[0-9]{2,3}.iso' | cut -d'_' -f2 | sort -ru | head -n 1) +} + +function editions_() { + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe "https://iso.biglinux.com.br" | grep -Eo "biglinux_$(releases_biglinux)_k[0-9]{2,3}.iso" | cut -d'_' -f3 | cut -d'.' -f1 | sort -Vru) +} + +function get_() { + local HASH="" + local ISO="biglinux_${RELEASE}_${EDITION}.iso" + local URL="https://iso.biglinux.com.br" + HASH=$(web_pipe "${URL}/${ISO}.md5" | grep -Eo '[[:alnum:]]{32}') + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/blendos b/public/blendos index 181c5dd..654c3a3 100644 --- a/public/blendos +++ b/public/blendos @@ -5,5 +5,20 @@ BASEDOF="Arch" DESCRIPTION="A seamless blend of all Linux distributions. Allows you to have an immutable, atomic and declarative Arch Linux system, with application support from several Linux distributions & Android" HOMEPAGE="https://blendos.co" CREDENTIALS="-" + + RELEASES="" + +function releases_() { + # there is now just a single latest iso + echo latest +} + +function get_() { + local HASH=$(web_pipe "https://git.blendos.co/api/v4/projects/32/jobs/artifacts/main/raw/checksum?job=build-job | cut -d' ' -f1") + local ISO="blendOS.iso" + local URL="https://git.blendos.co/api/v4/projects/32/jobs/artifacts/main/raw/${ISO}?job=build-job" + echo "${URL} ${HASH}" +} + diff --git a/public/bodhi b/public/bodhi index 60ef977..25a1dbf 100644 --- a/public/bodhi +++ b/public/bodhi @@ -5,5 +5,28 @@ BASEDOF="Debian Ubuntu" DESCRIPTION="Lightweight distribution featuring the fast & fully customizable Moksha Desktop" HOMEPAGE="https://www.bodhilinux.com" CREDENTIALS="-" + + RELEASES="7.0.0" EDITIONS="standard s76 hwe apppack" + +function releases_() { + echo 7.0.0 +} + +function editions_() { + echo standard hwe s76 apppack +} + +function get_() { + local HASH="" + local ISO="" + local URL="https://sourceforge.net/projects/bodhilinux/files/${RELEASE}" + case ${EDITION} in + standard) ISO="bodhi-${RELEASE}-64.iso";; + *) ISO="bodhi-${RELEASE}-64-${EDITION}.iso";; + esac + HASH=$(web_pipe "${URL}/${ISO}.sha256" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/bunsenlabs b/public/bunsenlabs index 0f3cf9c..61c0e05 100644 --- a/public/bunsenlabs +++ b/public/bunsenlabs @@ -5,5 +5,20 @@ BASEDOF="Debian" DESCRIPTION="Light-weight and easily customizable Openbox desktop. The project is a community continuation of CrunchBang Linux" HOMEPAGE="https://www.bunsenlabs.org" CREDENTIALS="-" + + RELEASES="boron" + +function releases_() { + echo boron +} + +function get_() { + local HASH="" + local ISO="boron-1-240123-amd64.hybrid.iso" + local URL="https://ddl.bunsenlabs.org/ddl" + HASH=$(web_pipe "${URL}/release.sha256.txt" | head -n 1 | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/cachyos b/public/cachyos index 1a1425e..5e6c3e1 100644 --- a/public/cachyos +++ b/public/cachyos @@ -5,5 +5,26 @@ BASEDOF="Arch" DESCRIPTION="Designed to deliver lightning-fast speeds and stability, ensuring a smooth and enjoyable computing experience every time you use it" HOMEPAGE="https://cachyos.org" CREDENTIALS="-" + + RELEASES="latest" EDITIONS="handheld desktop" + +function releases_() { + # new cdn setup 10/2024 + echo latest +} + +function editions_() { + # desktop version now installs different desktop environments + echo desktop handheld +} + +function get_() { + local HASH="" + local URL="" + URL="$(web_pipe "https://cachyos.org/download/" | tr '&' '\n' | grep "ISO/${EDITION}" | grep -v 'iso.sha' | grep -v 'iso.sig' | cut -d';' -f2)" + HASH=$(web_pipe "${URL}.sha256" | cut -d' ' -f1) + echo "${URL} ${HASH}" +} + diff --git a/public/centos-stream b/public/centos-stream index 3437894..c36614c 100644 --- a/public/centos-stream +++ b/public/centos-stream @@ -5,5 +5,29 @@ BASEDOF="Fedora RedHat" DESCRIPTION="Continuously delivered distro that tracks just ahead of Red Hat Enterprise Linux (RHEL) development, positioned as a midstream between Fedora Linux and RHEL" HOMEPAGE="https://www.centos.org/centos-stream" CREDENTIALS="-" + + RELEASES="9 10" EDITIONS="dvd1 boot" + +function releases_() { + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe "https://linuxsoft.cern.ch/centos-stream/" | grep "\-stream" | cut -d'"' -f 6 | cut -d'-' -f 1) +} + +function editions_() { + echo boot dvd1 +} + +function get_() { + local HASH="" + local ISO="CentOS-Stream-${RELEASE}-latest-x86_64-${EDITION}.iso" + local URL="https://linuxsoft.cern.ch/centos-stream/${RELEASE}-stream/BaseOS/x86_64/iso" + HASH=$(web_pipe "${URL}/${ISO}.SHA256SUM" | grep "SHA256 (${ISO}" | cut -d' ' -f4) + echo "${URL}/${ISO} ${HASH}" +} + +function specific_tweaks() { + echo "disk_size=\"32G\"" >> "${CONF_FILE}" +} + diff --git a/public/cereus b/public/cereus index f406317..6553003 100644 --- a/public/cereus +++ b/public/cereus @@ -5,5 +5,31 @@ BASEDOF="Void" DESCRIPTION="Void-based distribution focused on give an user-friendly experience." HOMEPAGE="https://sourceforge.net/projects/cereus-linux" CREDENTIALS="-" + + RELEASES="latest" EDITIONS="xfce musl-xfce musl-lxqt musl-base lxqt base" + +function releases_() { + echo latest +} + +function editions_() { + echo base musl-base lxqt musl-lxqt xfce musl-xfce +} + +function get_() { + local EDITION="${1:-}" + local HASH="" + local DATE="" + local ISO="" + local URL="https://sourceforge.net/projects/cereus-linux/files" + REST=$(web_pipe "https://sourceforge.net/projects/cereus-linux/rss?path=/isos/beta" | grep 'title>' -f 9 | cut -d'/' -f 1) + echo -n "${NEW}" + MAJ=$(echo "${NEW}" | cut -d'.' -f 1) + ARCHIVE="$(web_pipe "https://cdimage.debian.org/cdimage/archive/" | grep folder | grep -v NEVER | cut -d'"' -f 6)" + for i in {1..2}; do + CUR=$((MAJ - i)) + OLD=$(grep ^"${CUR}" <<< "${ARCHIVE}" | tail -n 1 | tr -d '/') + echo -n " ${OLD}" + done + echo +} + +function editions_() { + echo standard cinnamon gnome kde lxde lxqt mate xfce netinst +} + +function get_() { + local DEBCURRENT="" + local HASH="" + local ISO="debian-live-${RELEASE}-amd64-${EDITION}.iso" + local URL="https://cdimage.debian.org/cdimage/archive/${RELEASE}-live/amd64/iso-hybrid" + DEBCURRENT=$(web_pipe "https://cdimage.debian.org/debian-cd/" | grep '\.[0-9]/' | cut -d'>' -f 9 | cut -d'/' -f 1) + case "${RELEASE}" in + "${DEBCURRENT}") URL="https://cdimage.debian.org/debian-cd/${RELEASE}-live/amd64/iso-hybrid";; + esac + if [ "${EDITION}" == "netinst" ]; then + URL="${URL/-live/}" + URL="${URL/hybrid/cd}" + ISO="${ISO/-live/}" + fi + HASH=$(web_pipe "${URL}/SHA512SUMS" | grep "${ISO}" | cut -d' ' -f1 | head -n 1) + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/deepin b/public/deepin index 25fe7c0..ed4978d 100644 --- a/public/deepin +++ b/public/deepin @@ -5,5 +5,32 @@ BASEDOF="Debian" DESCRIPTION="Beautiful UI design, intimate human-computer interaction, and friendly community environment make you feel at home" HOMEPAGE="https://www.deepin.org" CREDENTIALS="-" + + RELEASES="23 20.9" + +function releases_() { + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe "https://mirrors.kernel.org/deepin-cd/" | grep "href=" | cut -d'"' -f2 | grep -v "\.\." | grep -v nightly | grep -v preview | sed 's|/||g' | tail -n 10 | sort -r) +} + +function get_() { + local HASH="" + local REV=${RELEASE} + # deepin-desktop-community-20.3-amd64.iso + local URL="https://cdimage.deepin.com/releases/"${RELEASE} + # Correct URL for 23-RC onwards which has architecture directories + if [ "${RELEASE}" != "20.9" ]; then + URL+="/amd64" + fi + local ISO="deepin-desktop-community-${REV}-amd64.iso" + HASH=$(web_pipe "${URL}/SHA256SUMS" | grep "${ISO}" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + +function specific_tweaks() { + echo "disk_size=\"64G\"" >> "${CONF_FILE}" + echo "ram=\"4G\"" >> "${CONF_FILE}" +} + diff --git a/public/devuan b/public/devuan index 5093312..c016ddf 100644 --- a/public/devuan +++ b/public/devuan @@ -5,5 +5,27 @@ BASEDOF="Debian" DESCRIPTION="Fork of Debian without systemd that allows users to reclaim control over their system by avoiding unnecessary entanglements and ensuring Init Freedom" HOMEPAGE="https://www.devuan.org" CREDENTIALS="-" + + RELEASES="daedalus chimaera beowulf" + +function releases_() { + echo daedalus chimaera beowulf +} + +function get_() { + local HASH="" + local ISO="" + local URL="https://files.devuan.org/devuan_${RELEASE}/desktop-live" + local VER="" + case ${RELEASE} in + beowulf) VER="3.1.1";; + chimaera) VER="4.0.3";; + daedalus) VER="5.0.0";; + esac + ISO="devuan_${RELEASE}_${VER}_amd64_desktop-live.iso" + HASH=$(web_pipe "${URL}/SHASUMS.txt" | grep "${ISO}" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/dietpi b/public/dietpi index 77d27ee..cefc9a7 100644 --- a/public/dietpi +++ b/public/dietpi @@ -5,5 +5,56 @@ BASEDOF="Debian" DESCRIPTION="Highly optimised minimal Debian OS" HOMEPAGE="https://dietpi.com" CREDENTIALS="-" + + RELEASES="uefi bios" EDITIONS="bullseye-installer bullseye bookworm-installer bookworm" + +function releases_() { + echo bios uefi +} + +function editions_() { + echo bookworm bookworm-installer bullseye bullseye-installer +} + +function get_() { + local HASH="" + local ISO="" + local URL="https://dietpi.com/downloads/images" + if [ "${RELEASE}" == 'bios' ]; then + case ${EDITION} in + bookworm ) + local ISO="DietPi_NativePC-BIOS-x86_64-Bookworm.7z";; + bullseye ) + local ISO="DietPi_NativePC-BIOS-x86_64-Bullseye.7z";; + 'bookworm-installer' ) + local ISO="DietPi_NativePC-BIOS-x86_64-Bookworm_Installer.7z";; + 'bullseye-installer' ) + local ISO="DietPi_NativePC-BIOS-x86_64-Bullseye_Installer.7z";; + esac + elif [ "${RELEASE}" == 'uefi' ]; then + case ${EDITION} in + 'bookworm-installer' ) + local ISO="DietPi_NativePC-UEFI-x86_64-Bookworm_Installer.7z";; + 'bullseye-installer' ) + local ISO="DietPi_NativePC-UEFI-x86_64-Bullseye_Installer.7z";; + esac + fi + HASH=$(wget -q -O- "${URL}/SHASUMS.txt" | grep "${ISO}" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + +function distro_specific() { + if [[ "${ISO}" =~ ".7z" ]]; then + 7zip x -o${VM_PATH} ${VM_PATH}/${ISO} + ISO=$(ls ${VM_PATH} | grep -i '.iso') + fi +} + +function specific_tweaks() { + if [[ "${RELEASE}" == 'bios' ]]; then + echo "boot=\"legacy\"" >> "${CONF_FILE}" + fi +} + diff --git a/public/dragonflybsd b/public/dragonflybsd index cdeadb8..3dd6e60 100644 --- a/public/dragonflybsd +++ b/public/dragonflybsd @@ -5,5 +5,36 @@ BASEDOF="FreeBSD" DESCRIPTION="Provides an opportunity for the BSD base to grow in an entirely different direction from the one taken in the FreeBSD, NetBSD, and OpenBSD series" HOMEPAGE="https://www.dragonflybsd.org" CREDENTIALS="-" +GUEST="bullseye-installer bullseye bookworm-installer bookworm" + RELEASES="6.4.0 6.2.2 6.2.1 6.0.1 6.0.0 5.8.3 5.8.2 5.8.1 5.8.0 5.6.3 5.6.2 5.6.1 5.6.0 5.4.3 5.4.2 5.4.1 5.4.0 5.2.2 5.2.1 5.2.0 5.0.2 5.0.1 5.0.0" + +function releases_() { + # If you remove "".bz2" from the end of the searched URL, you will get only the current release - currently 6.4.0 + # We could add a variable so this behaviour is optional/switchable (maybe from option or env) + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe "https://mirror-master.dragonflybsd.org/iso-images/" | grep -E -o '"dfly-x86_64-.*_REL.iso.bz2"' | grep -o -E '[[:digit:]]+\.[[:digit:]]+\.[[:digit:]]+') +} + +function get_() { + local HASH="" + local ISO="dfly-x86_64-${RELEASE}_REL.iso.bz2" + local URL="http://mirror-master.dragonflybsd.org/iso-images" + HASH=$(web_pipe "${URL}/md5.txt" | grep "(${ISO})" | cut -d' ' -f4) + echo "${URL}/${ISO} ${HASH}" +} + +function distro_specific() { + # Could be other OS iso files compressed with bzip2 or gzip + # but for now we'll keep this to know cases + if [[ ${ISO} = *".bz2"* ]]; then + bzip2 -d "${VM_PATH}/${ISO}" + ISO="${ISO/.bz2/}" + fi +} + +function specific_tweaks() { + echo "boot=\"legacy\"" >> "${CONF_FILE}" +} + diff --git a/public/dsl b/public/dsl index ecfc754..16e939a 100644 --- a/public/dsl +++ b/public/dsl @@ -5,5 +5,28 @@ BASEDOF="Antix" DESCRIPTION="Goal of DSL is to pack as much usable desktop distribution into an image small enough to fit on a single CD" HOMEPAGE="https://www.damnsmalllinux.org/" CREDENTIALS="-" + + RELEASES="2024.rc7" EDITIONS="lz4 cdrom" + +function releases_() { + echo 2024.rc7 +} + +function editions_() { + echo lz4 cdrom +} + +function get_() { + local ISO="" + local HASH="" + local URL="https://www.damnsmalllinux.org/download" + case "$EDITION" in + lz4) ISO="dsl-${RELEASE}.lz4.iso";; + cdrom) ISO="dsl-${RELEASE}.iso";; + esac + HASH=$(web_pipe "${URL}/${ISO}.md5.txt" | cut -f1) + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/easyos b/public/easyos index 4a258aa..399dc1b 100644 --- a/public/easyos +++ b/public/easyos @@ -5,5 +5,43 @@ BASEDOF="-" DESCRIPTION="Experimental distribution designed from scratch to support containers" HOMEPAGE="https://easyos.org" CREDENTIALS="-" + +IMAGE_TYPE="" RELEASES="5.8.5" + +function releases_() { + local ALL_RELEASES="" + local YEAR="" + # get the latest 2 years of releases so that when we hit next year we still have the latest 2 years + TWO_YEARS=$(web_pipe https://distro.ibiblio.org/easyos/amd64/releases/kirkstone/ | grep -o -E '[[:digit:]]{4}/' | sort -nr | tr -d / | head -n 2 ) + for YEAR in ${TWO_YEARS} ; do + ALL_RELEASES="${ALL_RELEASES} $(web_pipe https://distro.ibiblio.org/easyos/amd64/releases/kirkstone/${YEAR}/ | grep -o -E '[[:digit:]]+(\.[[:digit:]])+/' | tr -d / | sort -nr)" + done + echo ${ALL_RELEASES} +} + +function get_() { + local HASH="" + local URL="" + local ISO="" + local YEAR="" + ISO="easy-${RELEASE}-amd64.img" + TWO_YEARS=$(web_pipe https://distro.ibiblio.org/easyos/amd64/releases/kirkstone/ | grep -o -E '[[:digit:]]{4}/' | sort -nr | tr -d / | head -n 2 ) + for YEAR in ${TWO_YEARS} ; do + if web_check "https://distro.ibiblio.org/easyos/amd64/releases/kirkstone/${YEAR}/${RELEASE}/" ; then + URL="https://distro.ibiblio.org/easyos/amd64/releases/kirkstone/${YEAR}/${RELEASE}" + HASH=$(web_pipe "${URL}/md5.sum.txt" | cut -d' ' -f1) + break + fi + done + echo "${URL}/${ISO} ${HASH}" +} + +function distro_specific() { + if [[ ${ISO} = *".img"* ]]; then + ${QEMU_IMG} convert -f raw -O qcow2 "${VM_PATH}/${ISO}" "${VM_PATH}/disk.qcow2" + ISO="${ISO/.img/}" + fi +} + diff --git a/public/elementary b/public/elementary index 08011d2..7898067 100644 --- a/public/elementary +++ b/public/elementary @@ -5,5 +5,24 @@ BASEDOF="Debian Ubuntu" DESCRIPTION="Thoughtful, capable, and ethical replacement for Windows and macOS" HOMEPAGE="https://elementary.io" CREDENTIALS="-" + + RELEASES="8.0 7.1 7.0" + +function releases_() { + echo 8.0 7.1 7.0 +} + +function get_() { + local HASH="" + case ${RELEASE} in + 7.0) STAMP="20230129rc";; + 7.1) STAMP="20230926rc";; + 8.0) STAMP="20241122rc";; + esac + local ISO="elementaryos-${RELEASE}-stable.${STAMP}.iso" + local URL="https://ams3.dl.elementary.io/download" + echo "${URL}/$(date +%s | base64)/${ISO} ${HASH}" +} + diff --git a/public/endeavouros b/public/endeavouros index 250d94b..07aa41f 100644 --- a/public/endeavouros +++ b/public/endeavouros @@ -5,5 +5,26 @@ BASEDOF="Arch" DESCRIPTION="Provides an Arch experience without the hassle of installing it manually for both x86_64 and ARM systems" HOMEPAGE="https://endeavouros.com" CREDENTIALS="-" + + RELEASES="mercury-2025.02.08 gemini-2024.04.20 galileo-neo-2024.01.25 galileo-11-2023 endeavour_neo-2024.09.22" + +function releases_() { + local ENDEAVOUR_RELEASES="" + ENDEAVOUR_RELEASES="$(web_pipe "https://mirror.alpix.eu/endeavouros/iso/" | grep -o '' | sed 's/^.*//' | grep -v 'x86_64' | LC_ALL="en_US.UTF-8" sort -Mr | cut -c 13- | head -n 5 | tr '\n' ' ')" + echo "${ENDEAVOUR_RELEASES,,}" +} + +function get_() { + local ENDEAVOUR_RELEASES="" + local HASH="" + local ISO="" + local URL="https://mirror.alpix.eu/endeavouros/iso" + # Find EndeavourOS releases from mirror, pick one matching release + ENDEAVOUR_RELEASES="$(web_pipe "${URL}/" | grep -o '' | sed 's/^.*//' | grep -v 'x86_64')" + ISO="$(echo "${ENDEAVOUR_RELEASES}" | grep -i "${RELEASE}").iso" + HASH=$(web_pipe "${URL}/${ISO}.sha512sum" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/endless b/public/endless index c3a051a..5fa152d 100644 --- a/public/endless +++ b/public/endless @@ -5,5 +5,41 @@ BASEDOF="Debian" DESCRIPTION="Completely Free, User-Friendly Operating System Packed with Educational Tools, Games, and More" HOMEPAGE="https://www.endlessos.org/os" CREDENTIALS="-" + + RELEASES="6.0.4" EDITIONS="pt_BR fr es en base" + +function releases_() { + echo 6.0.4 +} + +function editions_() { + echo base en fr pt_BR es +} + +function get_() { + local HASH="" # No hash - there is a signature in .asc signed by + #https://d1anzknqnc1kmb.cloudfront.net/eos-image-keyring.gpg + # (4096R: CB50 0F7B C923 3FAD 32B4 E720 9E0C 1250 587A 279C) + local FILE_TS="" + # https://support.endlessos.org/en/installation/direct-download gives the info but computes the URLS in js + # so parsing out the useful info is not happening tonight + # Endless edition names are "base" for the small minimal one or the Language for the large full release + # The isos are stamped as they are finished so .... + case ${EDITION} in + base) FILE_TS="241023-183516";; + en) FILE_TS="241023-200926";; + es) FILE_TS="241023-184649";; + fr) FILE_TS="241023-191212";; + pt_BR) FILE_TS="241023-191427";; + esac + URL="https://images-dl.endlessm.com/release/${RELEASE}/eos-amd64-amd64/${EDITION}" + ISO="eos-eos${RELEASE:0:3}-amd64-amd64.${FILE_TS}.${EDITION}.iso" + echo "${URL}/${ISO} ${HASH}" +} + +function specific_tweaks() { + echo "disk_size=\"32G\"" >> "${CONF_FILE}" +} + diff --git a/public/fedora b/public/fedora index 8a1b746..a2a3372 100644 --- a/public/fedora +++ b/public/fedora @@ -5,5 +5,47 @@ BASEDOF="-" DESCRIPTION="Innovative platform for hardware, clouds, and containers, built with love by you" HOMEPAGE="https://www.fedoraproject.org" CREDENTIALS="-" + + RELEASES="41 40 39" EDITIONS="i3 Xfce Workstation Sway Silverblue Server Sericea Onyx MiracleWM Mate LXQt LXDE Kinoite KDE_Mobile KDE Cinnamon Budgie" + +function releases_() { + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe "https://getfedora.org/releases.json" | jq -r 'map(.version) | unique | .[]' | sed 's/ /_/g' | sort -r) +} + +function editions_() { + #shellcheck disable=SC2046,SC2005 + if [[ -z ${RELEASE} ]]; then + echo $(web_pipe "https://getfedora.org/releases.json" | jq -r "map(select(.arch==\"x86_64\" and .variant!=\"Labs\" and .variant!=\"IoT\" and .variant!=\"Container\" and .variant!=\"Cloud\" and .variant!=\"Everything\" and .subvariant!=\"Security\" and .subvariant!=\"Server_KVM\" and .subvariant!=\"SoaS\")) | map(.subvariant) | unique | .[]") + else + echo $(web_pipe "https://getfedora.org/releases.json" | jq -r "map(select(.arch==\"x86_64\" and .version==\"${RELEASE/_/ }\" and .variant!=\"Labs\" and .variant!=\"IoT\" and .variant!=\"Container\" and .variant!=\"Cloud\" and .variant!=\"Everything\" and .subvariant!=\"Security\" and .subvariant!=\"Server_KVM\" and .subvariant!=\"SoaS\")) | map(.subvariant) | unique | .[]") + fi +} + +function get_() { + local HASH="" + local ISO="" + local JSON="" + local URL="" + local VARIANT="" + case ${EDITION} in + Server|Kinoite|Onyx|Silverblue|Sericea|Workstation) VARIANT="${EDITION}";; + *) VARIANT="Spins";; + esac + # The naming of 41 Beta with a space is problematic so we replaced it with an underscore + # but we need to convert it back to a space for the URL search in the JSON + #shellcheck disable=SC2086 + # if RELEASE contains an underscore, replace it with a space + if [[ "${RELEASE}" == *"_"* ]]; then + RELEASE="${RELEASE/_/ }" + fi + + # shellcheck disable=SC2086 + JSON=$(web_pipe "https://getfedora.org/releases.json" | jq '.[] | select(.variant=="'${VARIANT}'" and .subvariant=="'"${EDITION}"'" and .arch=="x86_64" and .version=="'"${RELEASE}"'" and (.link | endswith(".iso")))') + URL=$(echo "${JSON}" | jq -r '.link' | head -n1) + HASH=$(echo "${JSON}" | jq -r '.sha256' | head -n1) + echo "${URL} ${HASH}" +} + diff --git a/public/freebsd b/public/freebsd index 4fd93f1..759dff1 100644 --- a/public/freebsd +++ b/public/freebsd @@ -5,5 +5,25 @@ BASEDOF="-" DESCRIPTION="Operating system used to power modern servers, desktops, and embedded platforms" HOMEPAGE="https://www.freebsd.org" CREDENTIALS="-" +freebsd + RELEASES="14.2 14.1 13.4 13.3" EDITIONS="dvd1 disc1" + +function releases_() { + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe "https://download.freebsd.org/ftp/releases/amd64/amd64/" | grep -Eo "href=\"[0-9\.]+-RELEASE" | grep -oE '[0-9\.]+' | sort -r) +} + +function editions_() { + echo disc1 dvd1 +} + +function get_() { + local HASH="" + local ISO="FreeBSD-${RELEASE}-RELEASE-amd64-${EDITION}.iso" + local URL="https://download.freebsd.org/ftp/releases/amd64/amd64/ISO-IMAGES/${RELEASE}" + HASH=$(web_pipe "${URL}/CHECKSUM.SHA256-FreeBSD-${RELEASE}-RELEASE-amd64" | grep "${ISO}" | grep -v ".xz" | cut -d' ' -f4) + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/freedos b/public/freedos index b24b940..cad9943 100644 --- a/public/freedos +++ b/public/freedos @@ -5,5 +5,40 @@ BASEDOF="-" DESCRIPTION="DOS-compatible operating system that you can use to play classic DOS games, run legacy business software, or develop embedded systems" HOMEPAGE="https://freedos.org" CREDENTIALS="-" +GUEST="dvd1 disc1" + RELEASES="1.3 1.2" + +function releases_() { + echo 1.3 1.2 +} + +function get_() { + local HASH="" + local ISO="" + local URL="https://www.ibiblio.org/pub/micro/pc-stuff/freedos/files/distributions/${RELEASE}/official" + case ${RELEASE} in + 1.2) ISO="FD12CD.iso" + HASH=$(web_pipe "${URL}/FD12.sha" | grep "${ISO}" | cut -d' ' -f1);; + 1.3) ISO="FD13-LiveCD.zip" + HASH=$(web_pipe "${URL}/verify.txt" | grep -A 8 "sha256sum" | grep "${ISO}" | cut -d' ' -f1);; + esac + echo "${URL}/${ISO} ${HASH}" +} + +function distro_specific() { + if [[ ${ISO} = *".zip"* ]]; then + unzip -qo "${VM_PATH}/${ISO}" -d "${VM_PATH}" + rm -f "${VM_PATH}/${ISO}" + ISO="$(ls -1 "${VM_PATH}/"*.iso)" + ISO="$(basename "${ISO}")" + fi +} + +function specific_tweaks() { + echo "boot=\"legacy\"" >> "${CONF_FILE}" + echo "disk_size=\"4G\"" >> "${CONF_FILE}" + echo "ram=\"256M\"" >> "${CONF_FILE}" +} + diff --git a/public/fvoid b/public/fvoid index b8f4e2b..251663e 100644 --- a/public/fvoid +++ b/public/fvoid @@ -5,5 +5,19 @@ BASEDOF="Void" DESCRIPTION="F-Void (Fork of Void) is a mild modification of Void Linux" HOMEPAGE="https://sourceforge.net/projects/f-void" CREDENTIALS="-" + + RELEASES="latest" + +function releases_() { + echo latest +} + +function get_() { + local HASH="" + local URL="https://sourceforge.net/projects/f-void/files" + REST=$(web_pipe "https://sourceforge.net/projects/f-void/rss?path=/" | grep 'title>> "${CONF_FILE}" +} + diff --git a/public/gentoo b/public/gentoo index 91667cf..4ae0abc 100644 --- a/public/gentoo +++ b/public/gentoo @@ -5,5 +5,32 @@ BASEDOF="-" DESCRIPTION="Highly flexible, source-based Linux distribution" HOMEPAGE="https://www.gentoo.org" CREDENTIALS="-" + + RELEASES="latest" EDITIONS="minimal livegui" + +function releases_() { + echo latest +} + +function editions_() { + echo minimal livegui +} + +function get_() { + local HASH="" + local ISO="" + local URL="https://mirror.bytemark.co.uk/gentoo/releases/amd64/autobuilds" + case ${EDITION} in + minimal) ISO=$(web_pipe "${URL}/${RELEASE}-iso.txt" | grep install | cut -d' ' -f1);; + livegui) ISO=$(web_pipe "${URL}/${RELEASE}-iso.txt" | grep livegui | cut -d' ' -f1);; + esac + HASH=$(web_pipe "${URL}/${ISO}.DIGESTS" | grep -A 1 SHA512 | grep iso | grep -v CONTENTS | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + +function specific_tweaks() { + echo "disk_size=\"32G\"" >> "${CONF_FILE}" +} + diff --git a/public/ghostbsd b/public/ghostbsd index b40816a..801062f 100644 --- a/public/ghostbsd +++ b/public/ghostbsd @@ -5,5 +5,29 @@ BASEDOF="FreeBSD" DESCRIPTION="Simple, elegant desktop BSD Operating System" HOMEPAGE="https://www.ghostbsd.org" CREDENTIALS="-" -RELEASES="24.10.1 24.07.3 24.07.2" +freebsd + +RELEASES="25.01-R14.2p1 24.10.1 24.07.3" EDITIONS="xfce mate" + +function releases_() { + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe "https://download.ghostbsd.org/releases/amd64/" | grep "href" | cut -d'"' -f2 | cut -d'/' -f1 | sort -r | tail -n +3 | head -n 3) +} + +function editions_() { + echo mate xfce +} + +function get_() { + local ISO="" + local URL="https://download.ghostbsd.org/releases/amd64/${RELEASE}" + local HASH="" + case ${EDITION} in + mate) ISO="GhostBSD-${RELEASE}.iso";; + xfce) ISO="GhostBSD-${RELEASE}-XFCE.iso";; + esac + HASH=$(web_pipe "${URL}/${ISO}.sha256" | grep "${ISO}" | cut -d' ' -f4) + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/gnomeos b/public/gnomeos index 09f3aca..cc9928f 100644 --- a/public/gnomeos +++ b/public/gnomeos @@ -5,5 +5,30 @@ BASEDOF="-" DESCRIPTION="Alpha nightly bleeding edge distro of GNOME" HOMEPAGE="https://os.gnome.org" CREDENTIALS="-" -RELEASES="nightly 48.alpha 47.rc 47.beta 47.alpha 47.0 46.rc 46.beta 46.alpha 46.0 45.rc 45.beta 44.rc 44.beta 44.0 43.beta 43.alpha 43.0 42.rc 42.beta 42.0 41.rc 41.beta 41.0 40.rc 40.beta 40.0 3.38.1 3.38.0" + + +RELEASES="nightly 48.beta 48.alpha 47.rc 47.beta 47.alpha 47.0 46.rc 46.beta 46.alpha 46.0 45.rc 45.beta 44.rc 44.beta 44.0 43.beta 43.alpha 43.0 42.rc 42.beta 42.0 41.rc 41.beta 41.0 40.rc 40.beta 40.0 3.38.1 3.38.0" + + +function releases_() { + #shellcheck disable=SC2046,SC2005 + echo "nightly" $(web_pipe "https://download.gnome.org/gnomeos/" | grep "title=" | awk -F'"' '{print $4}' | tr -d '/' | sort -nr) +} + +function get_() { + local HASH="" + local ISO="gnome_os_installer_${RELEASE}.iso" + local URL="https://download.gnome.org/gnomeos/${RELEASE}" + case ${RELEASE} in + nightly) + ISO="gnome_os_installer.iso" + URL="https://os.gnome.org/download/latest";; + 46.0) ISO="gnome_os_installer_46.iso";; + 3*) ISO="gnome_os_installer.iso";; + 48.alpha) ISO=$(web_pipe "https://download.gnome.org/gnomeos/48.alpha/" | grep '.iso' | cut -d'"' -f4);; + esac + # Process the URL redirections; required for GNOME + ISO=$(web_redirect "${URL}/${ISO}") + echo "${ISO} ${HASH}" +} diff --git a/public/guix b/public/guix index 6986a8d..74da74c 100644 --- a/public/guix +++ b/public/guix @@ -5,5 +5,19 @@ BASEDOF="-" DESCRIPTION="Distribution of the GNU operating system developed by the GNU Project—which respects the freedom of computer users" HOMEPAGE="https://guix.gnu.org" CREDENTIALS="-" + + RELEASES="1.4.0 1.3.0" + +function releases_() { + echo 1.4.0 1.3.0 +} + +function get_() { + local HASH="" + local ISO="guix-system-install-${RELEASE}.x86_64-linux.iso" + local URL="https://ftpmirror.gnu.org/gnu/guix/" + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/haiku b/public/haiku index 8ce3bf4..d35d7f9 100644 --- a/public/haiku +++ b/public/haiku @@ -5,5 +5,27 @@ BASEDOF="-" DESCRIPTION="Specifically targets personal computing. Inspired by the BeOS, Haiku is fast, simple to use, easy to learn and yet very powerful" HOMEPAGE="https://www.haiku-os.org" CREDENTIALS="-" +haiku + RELEASES="r1beta5 r1beta4 r1beta3" EDITIONS="x86_gcc2h x86_64" + +function releases_() { + echo r1beta5 r1beta4 r1beta3 +} + +function editions_() { + echo x86_64 x86_gcc2h +} + +function get_() { + local ISO="haiku-${RELEASE}-${EDITION}-anyboot.iso" + local URL="http://mirror.rit.edu/haiku/${RELEASE}" + HASH=$(web_pipe "${URL}/${ISO}.sha256" | grep "${ISO}" | cut -d' ' -f4) + echo "${URL}/${ISO} ${HASH}" +} + +function specific_tweaks() { + echo "boot=\"legacy\"" >> "${CONF_FILE}" +} + diff --git a/public/kali b/public/kali index f042ec8..48f6cff 100644 --- a/public/kali +++ b/public/kali @@ -5,5 +5,25 @@ BASEDOF="Debian" DESCRIPTION="The most advanced Penetration Testing Distribution" HOMEPAGE="https://www.kali.org" CREDENTIALS="-" + + RELEASES="kali-weekly current" + +function releases_() { + echo current kali-weekly +} + +function get_() { + local HASH="" + local ISO="" + local URL="https://cdimage.kali.org/${RELEASE}" + ISO=$(web_pipe "${URL}/?C=M;O=D" | grep -o ">kali-linux-.*-installer-amd64.iso" | head -n 1 | cut -c 2-) + HASH=$(web_pipe "${URL}/SHA256SUMS" | grep -v torrent | grep "${ISO}" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + +function specific_tweaks() { + echo "disk_size=\"32G\"" >> "${CONF_FILE}" +} + diff --git a/public/kdeneon b/public/kdeneon index c334f25..6cfebeb 100644 --- a/public/kdeneon +++ b/public/kdeneon @@ -5,5 +5,25 @@ BASEDOF="Debian Ubuntu" DESCRIPTION="Latest and greatest of KDE community software packaged on a rock-solid base" HOMEPAGE="https://neon.kde.org" CREDENTIALS="-" + + RELEASES="user unstable testing developer" + +function releases_() { + echo user testing unstable developer +} + +function get_() { + local HASH="" + local ISO="" + local URL="https://files.kde.org/neon/images/${RELEASE}/current" + if [ "$RELEASE" == 'developer' ]; then + ISO=$(web_pipe "${URL}/neon-unstable-${RELEASE}-current.sha256sum" | cut -d' ' -f3-) + else + ISO=$(web_pipe "${URL}/neon-${RELEASE}-current.sha256sum" | cut -d' ' -f3-) + fi + HASH=$(web_pipe "${URL}/neon-${RELEASE}-current.sha256sum" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/kodachi b/public/kodachi new file mode 100644 index 0000000..c252389 --- /dev/null +++ b/public/kodachi @@ -0,0 +1,24 @@ +# Template file for 'kodachi' +OSNAME="kodachi" +PRETTY="Kodachi" +BASEDOF="Ubuntu" +DESCRIPTION="Provide you with a secure, anti forensic, and anonymous operating system considering all features that a person who is concerned about privacy would need to have in order to be secure" +HOMEPAGE="https://www.digi77.com/linux-kodachi/" +CREDENTIALS="kodachi:r@@t00,root:r@@t00" + + +RELEASES="latest" + + +function releases_() { + echo latest +} + +function get_() { + local HASH="" + local ISO=$(web_pipe "https://sourceforge.net/projects/linuxkodachi/rss?path=/" | grep 'title>/dev/null 2>&1 + rm -f "${VM_PATH}/${ISO}" + ISO="$(ls -1 "${VM_PATH}/"*.iso)" + ISO="$(basename "${ISO}")" + fi + fi +} + +function specific_tweaks() { + echo "boot=\"legacy\"" >> "${CONF_FILE}" + echo "disk_size=\"2G\"" >> "${CONF_FILE}" + echo "ram=\"128M\"" >> "${CONF_FILE}" +} + diff --git a/public/linuxlite b/public/linuxlite index 16e2492..c325053 100644 --- a/public/linuxlite +++ b/public/linuxlite @@ -5,5 +5,20 @@ BASEDOF="Debian Ubuntu" DESCRIPTION="Your first simple, fast and free stop in the world of Linux" HOMEPAGE="https://www.linuxliteos.com" CREDENTIALS="-" + + RELEASES="6.6 6.4 6.2 6.0" + +function releases_() { + echo 6.6 6.4 6.2 6.0 +} + +function get_() { + local HASH="" + local ISO="linux-lite-${RELEASE}-64bit.iso" + local URL="https://sourceforge.net/projects/linux-lite/files/${RELEASE}" + HASH=$(web_pipe "${URL}/${ISO}.sha256" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/linuxmint b/public/linuxmint index 7341400..330b386 100644 --- a/public/linuxmint +++ b/public/linuxmint @@ -5,5 +5,24 @@ BASEDOF="Ubuntu" DESCRIPTION="Designed to work out of the box and comes fully equipped with the apps most people need" HOMEPAGE="https://linuxmint.com" CREDENTIALS="-" + + RELEASES="22.1 22 21.3 21.2 21.1 21 20.3 20.2" EDITIONS="xfce mate cinnamon" + +function releases_() { + echo 22.1 22 21.3 21.2 21.1 21 20.3 20.2 +} + +function editions_() { + echo cinnamon mate xfce +} + +function get_() { + local HASH="" + local ISO="linuxmint-${RELEASE}-${EDITION}-64bit.iso" + local URL="https://mirror.bytemark.co.uk/linuxmint/stable/${RELEASE}" + HASH=$(web_pipe "${URL}/sha256sum.txt" | grep "${ISO}" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/lmde b/public/lmde index d22d705..22e5612 100644 --- a/public/lmde +++ b/public/lmde @@ -5,5 +5,24 @@ BASEDOF="Debian" DESCRIPTION="Aims to be as similar as possible to Linux Mint, but without using Ubuntu. The package base is provided by Debian instead" HOMEPAGE="https://www.linuxmint.com/download_lmde.php" CREDENTIALS="-" + + RELEASES="6" EDITIONS="cinnamon" + +function releases_() { + echo 6 +} + +function editions_() { + echo cinnamon +} + +function get_() { + local HASH="" + local ISO="lmde-${RELEASE}-${EDITION}-64bit.iso" + local URL="https://mirror.bytemark.co.uk/linuxmint/debian" + HASH=$(web_pipe "${URL}/sha256sum.txt" | grep "${ISO}" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/loc-os b/public/loc-os index fe90052..3a9f625 100644 --- a/public/loc-os +++ b/public/loc-os @@ -5,5 +5,27 @@ BASEDOF="Debian" DESCRIPTION="Distribution of GNU/Linux focused on low resource consumption." HOMEPAGE="https://loc-os.com" CREDENTIALS="-" + + RELEASES="latest" EDITIONS="xfce lxde kde" + +function releases_() { + echo latest +} + +function editions_() { + echo lxde xfce kde +} + +function get_() { + local HASH="" + local REL=$(echo "${EDITION}" | tr '[:lower:]' '[:upper:]') + URL="https://sourceforge.net/projects/loc-os/files" + REST_URL=$(web_pipe "https://sourceforge.net/projects/loc-os/rss?path=/" | grep 'title>&1 | tr ';' '\n' | awk -F'session=|;' '{print $2}' | grep 1) + info=$(curl --disable -s -X POST -H "Host: osrecovery.apple.com" \ + -H "Connection: close" \ + -A "InternetRecovery/1.0" \ + -b "session=\"${appleSession}\"" \ + -H "Content-Type: text/plain" \ + -d $'cid='"$(generate_id 16)"$'\nsn='${MLB}$'\nbid='${BOARD_ID}$'\nk='"$(generate_id 64)"$'\nfg='"$(generate_id 64)"$'\nos='${OS_TYPE} \ + https://osrecovery.apple.com/InstallationPayload/RecoveryImage | tr ' ' '\n') + downloadLink=$(echo "$info" | grep 'oscdn' | grep 'dmg') + downloadSession=$(echo "$info" | grep 'expires' | grep 'dmg') + chunkListLink=$(echo "$info" | grep 'oscdn' | grep 'chunklist') + chunkListSession=$(echo "$info" | grep 'expires' | grep 'chunklist') + + if [ "${OPERATION}" == "show" ]; then + test_result "${OS}" "${RELEASE}" "" "${downloadLink}" | tee -a "public/tmp_${OS}" + exit 0 + elif [ "${OPERATION}" == "test" ]; then + CHECK=$(web_check "${downloadLink}" --header "Host: oscdn.apple.com" --header "Connection: close" --header "User-Agent: InternetRecovery/1.0" --header "Cookie: AssetToken=${downloadSession}" && echo "PASS" || echo "FAIL") + test_result "${OS}" "${RELEASE}" "" "${downloadLink}" "${CHECK}" | tee -a "public/tmp_${OS}" + exit 0 + elif [ "${OPERATION}" == "download" ]; then + echo "Downloading macOS (${RELEASE^}) RecoveryImage" + echo " - URL: ${downloadLink}" + web_get "${downloadLink}" "${VM_PATH}" RecoveryImage.dmg --header "Host: oscdn.apple.com" --header "Connection: close" --header "User-Agent: InternetRecovery/1.0" --header "Cookie: AssetToken=${downloadSession}" + web_get "${chunkListLink}" "${VM_PATH}" RecoveryImage.chunklist --header "Host: oscdn.apple.com" --header "Connection: close" --header "User-Agent: InternetRecovery/1.0" --header "Cookie: AssetToken=${chunkListSession}" + VM_PATH="$(pwd)" + else + if [ ! -e "${VM_PATH}/RecoveryImage.chunklist" ]; then + echo "Downloading macOS (${RELEASE^}) RecoveryImage" + echo " - URL: ${downloadLink}" + web_get "${downloadLink}" "${VM_PATH}" RecoveryImage.dmg --header "Host: oscdn.apple.com" --header "Connection: close" --header "User-Agent: InternetRecovery/1.0" --header "Cookie: AssetToken=${downloadSession}" + web_get "${chunkListLink}" "${VM_PATH}" RecoveryImage.chunklist --header "Host: oscdn.apple.com" --header "Connection: close" --header "User-Agent: InternetRecovery/1.0" --header "Cookie: AssetToken=${chunkListSession}" + if ! "${CHUNKCHECK}" "${VM_PATH}" 2> /dev/null; then + echo " - WARNING! Verification failed, continuing anyway" + else + echo " - Verification passed" + fi + + if [ -e "${VM_PATH}/RecoveryImage.dmg" ] && [ ! -e "${VM_PATH}/RecoveryImage.img" ]; then + echo " - Converting RecoveryImage.dmg" + ${QEMU_IMG} convert "${VM_PATH}/RecoveryImage.dmg" -O raw "${VM_PATH}/RecoveryImage.img" 2>/dev/null + fi + rm "${VM_PATH}/RecoveryImage.dmg" "${VM_PATH}/RecoveryImage.chunklist" + echo " - RecoveryImage.img is ready." + fi + echo "Downloading OpenCore & UEFI firmware" + web_get "https://github.com/kholia/OSX-KVM/raw/master/OpenCore/OpenCore.qcow2" "${VM_PATH}" + web_get "https://github.com/kholia/OSX-KVM/raw/master/OVMF_CODE.fd" "${VM_PATH}" + if [ ! -e "${VM_PATH}/OVMF_VARS-1920x1080.fd" ]; then + web_get "https://github.com/kholia/OSX-KVM/raw/master/OVMF_VARS-1920x1080.fd" "${VM_PATH}" + fi + fi + make_vm_config RecoveryImage.img +} + +function specific_tweaks() { + echo "disk_size=\"128G\"" >> "${CONF_FILE}" + echo "macos_release=\"${RELEASE}\"" >> "${CONF_FILE}" + # https://github.com/quickemu-project/quickemu/issues/438 + if [ "${RELEASE}" == "monterey" ]; then + echo "cpu_cores=2" >> "${CONF_FILE}" + fi +} + diff --git a/public/mageia b/public/mageia index 11db7fb..9cd4bf7 100644 --- a/public/mageia +++ b/public/mageia @@ -5,5 +5,24 @@ BASEDOF="-" DESCRIPTION="Stable, secure operating system for desktop & server" HOMEPAGE="https://www.mageia.org" CREDENTIALS="-" + + RELEASES="9 8" EDITIONS="Xfce Plasma GNOME" + +function releases_() { + echo 9 8 +} + +function editions_() { + echo Plasma GNOME Xfce +} + +function get_() { + local HASH="" + local ISO="" + ISO=$(web_pipe https://www.mageia.org/en/downloads/get/?q="Mageia-${RELEASE}-Live-${EDITION}-x86_64.iso" | grep 'click here'| grep -o 'href=.*\.iso'|cut -d\" -f2) + HASH=$(web_pipe "${ISO}.sha512" | cut -d' ' -f1) + echo "${ISO} ${HASH}" +} + diff --git a/public/manjaro b/public/manjaro index 788d5b6..ff8eb6f 100644 --- a/public/manjaro +++ b/public/manjaro @@ -5,5 +5,46 @@ BASEDOF="Arch" DESCRIPTION="Versatile, free, and open-source Linux operating system designed with a strong focus on safeguarding user privacy and offering extensive control over hardware" HOMEPAGE="https://manjaro.org" CREDENTIALS="-" + + RELEASES="xfce sway plasma i3 gnome cinnamon" EDITIONS="minimal full" + +function releases_() { + echo xfce gnome plasma cinnamon i3 sway +} + +function editions_() { + echo full minimal +} + +function get_() { + local HASH="" + local ISO="" + local MANIFEST="" + local URL="" + local TYPE="official" + MANIFEST="$(web_pipe https://gitlab.manjaro.org/web/iso-info/-/raw/master/file-info.json)" + case "${RELEASE}" in + sway) + MANIFEST="$(web_pipe https://mirror.manjaro-sway.download/manjaro-sway/release.json)" + TYPE="sway" + ;; + cinnamon|i3) TYPE="community";; + esac + + if [ "${EDITION}" == "minimal" ] && [ "${TYPE}" != "sway" ]; then + EDITION=".minimal" + else + EDITION="" + fi + + if [ "${RELEASE}" == "sway" ]; then + URL=$(echo "${MANIFEST}" | jq -r '.[] | select(.name|test("^manjaro-sway-.*[.]iso$")) | .url') + else + URL="$(echo "${MANIFEST}" | jq -r ."${TYPE}.${RELEASE}${EDITION}".image)" + fi + HASH=$(web_pipe "${URL}.sha512" | cut -d' ' -f1) + echo "${URL} ${HASH}" +} + diff --git a/public/miyo b/public/miyo index 6b935df..27848bf 100644 --- a/public/miyo +++ b/public/miyo @@ -5,5 +5,31 @@ BASEDOF="Devuan" DESCRIPTION="Very minimal Linux OS based on Devuan and various Window Managers. " HOMEPAGE="https://sourceforge.net/projects/miyolinux/" CREDENTIALS="-" + + RELEASES="2022" EDITIONS="Openbox MATE Kwin JWM Deboot-Ceres" + +function releases_() { + echo 2022 +} + +function editions_() { + echo Kwin Deboot-Ceres JWM Openbox MATE +} + +function get_() { + local EDITION="${1:-}" + local HASH="" + local URL="https://sourceforge.net/projects/miyolinux/files/${RELEASE}-Release/${EDITION}" + case ${EDITION} in + Kwin) ISO="miyo-kwin-x86_64-BIOS-20220526.iso";; + Deboot-Ceres) ISO="Deboot-Ceres-x86-64-BIOS-20220415.iso";; + JWM) ISO="miyolinux-jwm-x86_64-BIOS-20220226.iso";; + Openbox) ISO="MiyoLinux-x86_64-BIOS-20220129.iso";; + MATE) ISO="mate-minimal-x86_64-BIOS-20220107.iso";; + esac + HASH=$(wget -q -O- "${URL}/${ISO}.sha256" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/mxlinux b/public/mxlinux index 8b258ff..6ddcf89 100644 --- a/public/mxlinux +++ b/public/mxlinux @@ -5,5 +5,30 @@ BASEDOF="Debian Antix" DESCRIPTION="Designed to combine elegant and efficient desktops with high stability and solid performance" HOMEPAGE="https://mxlinux.org" CREDENTIALS="-" + + RELEASES="23.5" EDITIONS="Xfce KDE Fluxbox" + +function releases_() { + # needs header, so not web_pipe: + curl --disable -Ils "https://sourceforge.net/projects/mx-linux/files/latest/download" | grep -i 'location:' | cut -d? -f1 | cut -d_ -f1 | cut -d- -f3 +} + +function editions_() { + echo Xfce KDE Fluxbox +} + +function get_() { + local HASH="" + local ISO="" + local URL="https://sourceforge.net/projects/mx-linux/files/Final/${EDITION}" + case ${EDITION} in + Xfce) ISO="MX-${RELEASE}_x64.iso";; + KDE) ISO="MX-${RELEASE}_KDE_x64.iso";; + Fluxbox) ISO="MX-${RELEASE}_fluxbox_x64.iso";; + esac + HASH=$(web_pipe "${URL}/${ISO}.sha256" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/netboot b/public/netboot index a19db4a..526f4e0 100644 --- a/public/netboot +++ b/public/netboot @@ -5,5 +5,20 @@ BASEDOF="iPXE" DESCRIPTION="Your favorite operating systems in one place" HOMEPAGE="https://netboot.xyz" CREDENTIALS="-" + + RELEASES="latest" + +function releases_() { + echo latest +} + +function get_() { + local HASH="" + local ISO="netboot.xyz.iso" + local URL="https://boot.netboot.xyz/ipxe" + HASH=$(web_pipe "${URL}/netboot.xyz-sha256-checksums.txt" | grep "${ISO}" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/netbsd b/public/netbsd index 330dbbb..f6c6887 100644 --- a/public/netbsd +++ b/public/netbsd @@ -5,5 +5,26 @@ BASEDOF="-" DESCRIPTION="Free, fast, secure, and highly portable Unix-like Open Source operating system. It is available for a wide range of platforms, from large-scale servers and powerful desktop systems to handheld and embedded devices" HOMEPAGE="https://www.netbsd.org" CREDENTIALS="-" +GUEST="Xfce KDE Fluxbox" + RELEASES="9.4 9.3 10.1 10.0" + +function releases_() { + # V8 is EOL so filter it out + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe "https://cdn.netbsd.org/pub/NetBSD/iso/" | grep -o -E '"[[:digit:]]+\.[[:digit:]]+/"' | tr -d '"/' | grep -v ^8 | sort -nr | head -n 4) +} + +function get_() { + local HASH="" + local ISO="NetBSD-${RELEASE}-amd64.iso" + local URL="https://cdn.netbsd.org/pub/NetBSD/NetBSD-${RELEASE}/images" + HASH=$(web_pipe "${URL}/MD5" | grep "${ISO}" | cut -d' ' -f4) + echo "${URL}/${ISO} ${HASH}" +} + +function specific_tweaks() { + echo "boot=\"legacy\"" >> "${CONF_FILE}" +} + diff --git a/public/nitrux b/public/nitrux index 19a2e18..0e1e305 100644 --- a/public/nitrux +++ b/public/nitrux @@ -5,5 +5,24 @@ BASEDOF="Debian Ubuntu" DESCRIPTION="Powered by Debian, KDE Plasma and Frameworks, and AppImages" HOMEPAGE="https://nxos.org" CREDENTIALS="-" + + RELEASES="latest" + +function releases_() { + echo latest +} + +function get_() { + local HASH="" + local URLBASE="" + local URL="" + local ISO="" + URLBASE="https://sourceforge.net/projects/nitruxos/files/Release" + URL="${URLBASE}/ISO" + ISO=$(web_pipe 'https://sourceforge.net/projects/nitruxos/rss?path=/Release/ISO' | grep '.iso' | head -n 1 | cut -d']' -f1 | cut -d '/' -f4) + HASH=$(web_pipe "${URLBASE}/MD5/${ISONAME}.md5sum" | grep "${ISO}" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/nixos b/public/nixos index 3c7dec2..d7b4c79 100644 --- a/public/nixos +++ b/public/nixos @@ -5,5 +5,40 @@ BASEDOF="-" DESCRIPTION="Linux distribution based on Nix package manager, tool that takes a unique approach to package management and system configuration" HOMEPAGE="https://nixos.org" CREDENTIALS="-" -RELEASES="unstable 24.11 24.05" + + +RELEASES="unstable 24.05 23.05" EDITIONS="plasma minimal gnome" + +function releases_() { + # Lists unstable plus the two most recent releases + #shellcheck disable=SC2046 + echo unstable $(web_pipe "https://nix-channels.s3.amazonaws.com/?delimiter=/" | grep -o -E 'nixos-[[:digit:]]+\.[[:digit:]]+' | cut -d- -f2 | sort -nru | head -n +2) +} + +function editions_() { + echo minimal plasma gnome +} + +function get_() { + local HASH="" + # Adapt the plasma edition according to the NixOS release + case "${EDITION}" in + plasma) + if [ "${RELEASE}" == "23.11" ]; then + EDITION+="5" + else + EDITION+="6" + fi + ;; + esac + local ISO="latest-nixos-${EDITION}-x86_64-linux.iso" + local URL="https://channels.nixos.org/nixos-${RELEASE}" + HASH=$(web_pipe "${URL}/${ISO}.sha256" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + +function specific_tweaks() { + echo "disk_size=\"32G\"" >> "${CONF_FILE}" +} + diff --git a/public/nwg-shell b/public/nwg-shell index f439b50..671a99c 100644 --- a/public/nwg-shell +++ b/public/nwg-shell @@ -5,5 +5,21 @@ BASEDOF="Arch" DESCRIPTION="Arch Linux ISO with nwg-shell for sway and Hyprland" HOMEPAGE="https://nwg-piotr.github.io/nwg-shell" CREDENTIALS="-" -RELEASES="2025.01.01" + + +RELEASES="2025.02.23" + + +function releases_() { + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe "https://sourceforge.net/projects/nwg-iso/rss?path=/" | grep 'url=' | grep '64.iso' | cut -d'/' -f12 | cut -d'-' -f3) +} + +function get_() { + local HASH="" + local ISO="nwg-live-${RELEASE}-x86_64.iso" + local URL="https://sourceforge.net/projects/nwg-iso/files" + HASH="$(web_pipe "https://sourceforge.net/projects/nwg-iso/rss?path=/" | grep "${ISO}" | cut -d'>' -f3 | cut -d'<' -f1 | tail -n 1)" + echo "${URL}/${ISO} ${HASH}" +} diff --git a/public/openbsd b/public/openbsd index bfc55f4..9e54ec7 100644 --- a/public/openbsd +++ b/public/openbsd @@ -5,5 +5,25 @@ BASEDOF="-" DESCRIPTION="Free, multi-platform 4.4BSD-based UNIX-like operating system. Our efforts emphasize portability, standardization, correctness, proactive security and integrated cryptography" HOMEPAGE="https://www.openbsd.org" CREDENTIALS="-" +GUEST="plasma minimal gnome" + RELEASES="7.6 7.5 7.4 7.3 7.2 7.1 7.0 6.9 6.8" + +function releases_() { + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe "https://mirror.leaseweb.com/pub/OpenBSD/" | grep -e '6\.[8-9]/' -e '[7-9]\.' | cut -d\" -f4 | tr -d '/' | sort -r) +} + +function get_() { + local HASH="" + local ISO="install${RELEASE//\./}.iso" + local URL="https://mirror.leaseweb.com/pub/OpenBSD/${RELEASE}/amd64" + HASH=$(web_pipe "${URL}/SHA256" | grep "${ISO}" | cut -d' ' -f4) + echo "${URL}/${ISO} ${HASH}" +} + +function specific_tweaks() { + echo "boot=\"legacy\"" >> "${CONF_FILE}" +} + diff --git a/public/openindiana b/public/openindiana index 38a8c9a..8446c09 100644 --- a/public/openindiana +++ b/public/openindiana @@ -5,5 +5,32 @@ BASEDOF="Solaris OPenSolaris" DESCRIPTION="Community supported illumos-based operating system" HOMEPAGE="https://www.openindiana.org" CREDENTIALS="-" +solaris + RELEASES="20241026 20240426 20231027 20230502 20230421" EDITIONS="text minimal gui" + +function releases_() { + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe "https://dlc.openindiana.org/isos/hipster/" | grep link | cut -d'/' -f 1 | cut -d '"' -f4 | sort -r | tail -n +2 | head -n 5) +} + +function editions_() { + echo gui text minimal +} + +function get_() { + local HASH="" + local ISO="" + local URL="" + URL="https://dlc.openindiana.org/isos/hipster/${RELEASE}" + ISO="OI-hipster-${EDITION}-${RELEASE}.iso" + HASH=$(web_pipe "${URL}/${ISO}.sha256" |cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + +function specific_tweaks() { + echo "boot=\"legacy\"" >> "${CONF_FILE}" + echo "disk_size=\"32G\"" >> "${CONF_FILE}" +} + diff --git a/public/opensuse b/public/opensuse index e5d6a04..8d901cb 100644 --- a/public/opensuse +++ b/public/opensuse @@ -5,5 +5,37 @@ BASEDOF="-" DESCRIPTION="The makers choice for sysadmins, developers and desktop users" HOMEPAGE="https://www.opensuse.org" CREDENTIALS="-" + + RELEASES="tumbleweed microos aeon 16.0 15.6 15.5 15.4 15.3 15.2 15.1 15.0" + +function releases_() { + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe "https://download.opensuse.org/distribution/leap/" | grep 'class="name"' | cut -d '/' -f2 | grep -v 42 | sort -r) aeon microos tumbleweed +} + +function get_() { + local HASH="" + local ISO="" + local URL="" + if [ "${RELEASE}" == "tumbleweed" ]; then + ISO="openSUSE-Tumbleweed-DVD-x86_64-Current.iso" + URL="https://download.opensuse.org/tumbleweed/iso" + elif [ "${RELEASE}" == "microos" ]; then + ISO="openSUSE-MicroOS-DVD-x86_64-Current.iso" + URL="https://download.opensuse.org/tumbleweed/iso" + elif [ "${RELEASE}" == "aeon" ]; then + ISO="opensuse-aeon.x86_64.iso" + URL="https://mirrorcache.opensuse.org/tumbleweed/appliances/iso" + elif [ "${RELEASE}" == 15.0 ] || [ "${RELEASE}" == 15.1 ]; then + ISO="openSUSE-Leap-${RELEASE}-DVD-x86_64.iso" + URL="https://download.opensuse.org/distribution/leap/${RELEASE}/iso" + else + ISO="openSUSE-Leap-${RELEASE}-DVD-x86_64-Current.iso" + URL="https://download.opensuse.org/distribution/leap/${RELEASE}/iso" + fi + HASH=$(web_pipe "${URL}/${ISO}.sha256" | awk '{if(NR==4) print $0}' | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/oraclelinux b/public/oraclelinux index 8a25eac..759c2eb 100644 --- a/public/oraclelinux +++ b/public/oraclelinux @@ -5,5 +5,30 @@ BASEDOF="RedHar" DESCRIPTION="Linux with everything required to deploy, optimize, and manage applications on-premises, in the cloud, and at the edge" HOMEPAGE="https://www.oracle.com/linux" CREDENTIALS="-" + + RELEASES="9.3 9.2 9.1 9.0 8.9 8.8 8.7 8.6 8.5 8.4 7.9 7.8 7.7" + +function releases_() { + echo 9.3 9.2 9.1 9.0 8.9 8.8 8.7 8.6 8.5 8.4 7.9 7.8 7.7 +} + +function get_() { + local HASH="" + local ISO="" + local VER_MAJ=${RELEASE::1} + local VER_MIN=${RELEASE:2:1} + local URL="https://yum.oracle.com/ISOS/OracleLinux/OL${VER_MAJ}/u${VER_MIN}/x86_64" + case ${VER_MAJ} in + 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";; + esac + HASH=$(web_pipe "https://linux.oracle.com/security/gpg/checksum/OracleLinux-R${VER_MAJ}-U${VER_MIN}-Server-x86_64.checksum" | grep "${ISO}" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + +function specific_tweaks() { + echo "disk_size=\"32G\"" >> "${CONF_FILE}" +} + diff --git a/public/parrotsec b/public/parrotsec index fcebdaa..38ac3fb 100644 --- a/public/parrotsec +++ b/public/parrotsec @@ -5,5 +5,27 @@ BASEDOF="Debian" DESCRIPTION="Provides a huge arsenal of tools, utilities and libraries that IT and security professionals can use to test and assess the security of their assets in a reliable, compliant and reproducible way" HOMEPAGE="https://www.parrotsec.org" CREDENTIALS="parrot:parrot" + + RELEASES="6.3.2 6.2 6.1" EDITIONS="security htb home" + +function releases_() { + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe "https://download.parrot.sh/parrot/iso/" | grep -o -E 'href="[[:digit:]]+(\.[[:digit:]]+)+' | sort -Vr | head -n 3 | cut -d\" -f 2) +} + +function editions_() { + echo home htb security +} + +function get_() { + local HASH="" + local ISO="" + local URL="" + ISO="Parrot-${EDITION}-${RELEASE}_amd64.iso" + URL="https://download.parrot.sh/parrot/iso/${RELEASE}" + HASH="$(web_pipe "${URL}/signed-hashes.txt" | grep "${ISO}" | cut -d' ' -f1)" + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/pbpuppy b/public/pbpuppy index d91b33c..2ce1d54 100644 --- a/public/pbpuppy +++ b/public/pbpuppy @@ -5,5 +5,25 @@ BASEDOF="Void,Ubuntu,Debian,Slackware" DESCRIPTION="Puppy Linux releases from Github. Brought to you by: peabee" HOMEPAGE="https://sourceforge.net/projects/pb-gh-releases" CREDENTIALS="-" -RELEASES="ghtest 250201 250101 241201" + + +RELEASES="ghtest 250301 250201 250101" EDITIONS="VoidPup64 S15Pup64 BookwormPup64" + +function releases_() { + echo $(web_pipe "https://sourceforge.net/projects/pb-gh-releases/rss?path=/" | grep 'title>> "${CONF_FILE}" +} + diff --git a/public/porteus b/public/porteus index 869890f..eb6a3e3 100644 --- a/public/porteus +++ b/public/porteus @@ -5,5 +5,27 @@ BASEDOF="Slackware" DESCRIPTION="Complete linux operating system that is optimized to run from CD, USB flash drive, hard drive, or other bootable storage media" HOMEPAGE="http://www.porteus.org" CREDENTIALS="-" + + RELEASES="5.01" EDITIONS="xfce openbox mate lxqt lxde kde gnome cinnamon" + +function releases_() { + echo 5.01 +} + +function editions_() { + echo cinnamon gnome kde lxde lxqt mate openbox xfce +} + +function get_() { + local HASH="" + local ISO="" + local URL="" + edition="${EDITION~~}" + ISO="Porteus-${edition}-v${RELEASE}-x86_64.iso" + URL="https://mirrors.dotsrc.org/porteus/x86_64/Porteus-v${RELEASE}" + HASH=$(web_pipe "${URL}/sha256sums.txt" | grep "${ISO}" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/primtux b/public/primtux index 8ad1016..ec3ddc9 100644 --- a/public/primtux +++ b/public/primtux @@ -5,5 +5,26 @@ BASEDOF="Ubuntu" DESCRIPTION="Complete and customizable GNU/Linux operating system intended for primary school students and suitable even for older hardware" HOMEPAGE="https://primtux.fr" CREDENTIALS="-" + + RELEASES="7" EDITIONS="2022-10" + +function releases_() { + echo 7 +} + +function editions_() { + echo 2022-10 +} + +function get_() { + local HASH="" + local URL="" + local ISO="" + ISO="PrimTux${RELEASE}-amd64-${EDITION}.iso" + URL="https://sourceforge.net/projects/primtux/files/Distribution" + HASH=$(web_pipe "${URL}/${ISO}.md5" | grep "${ISO}" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/proxmox-ve b/public/proxmox-ve index 09e7086..5fcd752 100644 --- a/public/proxmox-ve +++ b/public/proxmox-ve @@ -5,5 +5,28 @@ BASEDOF="Debian" DESCRIPTION="Proxmox Virtual Environment is a complete, open-source server management platform for enterprise virtualization" HOMEPAGE="https://proxmox.com/en/proxmox-virtual-environment" CREDENTIALS="-" + + RELEASES="8.3-1 8.2-2 7.4-1 6.4-1 5.4-1" + +function releases_() { + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe https://enterprise.proxmox.com/iso/ | grep proxmox-ve | grep -E -o '[0-9]+\.[0-9]+-[0-9]\.iso' | uniq | sort -ru | cut -d'.' -f 1-2) +} + +function get_() { + local HASH="" + local ISO="" + local URL="" + ISO="proxmox-ve_${RELEASE}.iso" + URL="https://enterprise.proxmox.com/iso" + HASH=$(web_pipe "${URL}/SHA256SUMS" | grep "${ISO}" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + +function specific_tweaks() { + echo "disk_size=\"20G\"" >> "${CONF_FILE}" + echo "ram=\"4G\"" >> "${CONF_FILE}" +} + diff --git a/public/pureos b/public/pureos index 11a01ca..83b5244 100644 --- a/public/pureos +++ b/public/pureos @@ -5,5 +5,34 @@ BASEDOF="Debian" DESCRIPTION="Fully free/libre and open source GNU/Linux operating system, endorsed by the Free Software Foundation" HOMEPAGE="https://www.pureos.net" CREDENTIALS="-" + + RELEASES="10.3" EDITIONS="plasma gnome" + +function releases_() { + web_pipe "https://www.pureos.net/download/" | grep -m 1 "downloads.puri" | cut -d '"' -f 2 | cut -d '-' -f 4 +} + +function editions_() { + echo gnome plasma +} + +function get_() { + local HASH="" + local ISO="" + local URL="" + local PureName= + PureName="$(web_pipe "https://www.pureos.net/download/" | grep -m 1 "downloads.puri" | cut -d '/' -f 4)" + local PureDate= + PureDate="$(web_pipe "https://www.pureos.net/download/" | grep -m 1 "downloads.puri" | cut -d '/' -f 6)" + local PureDateSquashed="${PureDate//'-'/}" + edition="${EDITION,,}" + URL="https://downloads.puri.sm/${PureName}/${edition}/${PureDate}" + ISO="pureos-${RELEASE}-${edition}-live-${PureDateSquashed}_amd64.iso" + local IsoTrimmed= + IsoTrimmed="${ISO%.*}" + HASH="$(web_pipe "${URL}/${IsoTrimmed}.checksums_sha256.txt" | grep -m 1 '.iso' | cut -d '.' -f 1)" + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/reactos b/public/reactos index 7fee95e..95328e4 100644 --- a/public/reactos +++ b/public/reactos @@ -5,5 +5,34 @@ BASEDOF="-" DESCRIPTION="Imagine running your favorite Windows applications and drivers in an open-source environment you can trust" HOMEPAGE="https://reactos.org" CREDENTIALS="-" +GUEST="plasma gnome" + RELEASES="latest" + +function releases_() { + echo latest +} + +function get_() { + local HASH="" + local URL="" + URL="$(web_redirect "https://sourceforge.net/projects/reactos/files/latest/download")" + echo "${URL} ${HASH}" +} + +function distro_specific() { + if [[ ${ISO} = *".zip"* ]]; then + unzip -qo "${VM_PATH}/${ISO}" -d "${VM_PATH}" + rm -f "${VM_PATH}/${ISO}" + ISO="$(ls -1 "${VM_PATH}/"*.iso)" + ISO="$(basename "${ISO}")" + fi +} + +function specific_tweaks() { + echo "boot=\"legacy\"" >> "${CONF_FILE}" + echo "disk_size=\"12G\"" >> "${CONF_FILE}" + echo "ram=\"2048M\"" >> "${CONF_FILE}" +} + diff --git a/public/rebornos b/public/rebornos index 827d4cb..1b7bbf1 100644 --- a/public/rebornos +++ b/public/rebornos @@ -5,5 +5,20 @@ BASEDOF="Arch" DESCRIPTION="Aiming to make Arch Linux as user friendly as possible by providing interface solutions to things you normally have to do in a terminal" HOMEPAGE="https://rebornos.org" CREDENTIALS="-" + + RELEASES="latest" + +function releases_() { + echo latest +} + +function get_() { + local HASH="" + local ISO="" + ISO=$(web_pipe "https://meta.cdn.soulharsh007.dev/RebornOS-ISO?format=json" | jq -r ".url") + HASH=$(web_pipe "https://meta.cdn.soulharsh007.dev/RebornOS-ISO?format=json" | jq -r ".md5") + echo "${ISO} ${HASH}" +} + diff --git a/public/rhino b/public/rhino index 8eb8e78..9d3582e 100644 --- a/public/rhino +++ b/public/rhino @@ -5,5 +5,20 @@ BASEDOF="Ubuntu" DESCRIPTION="Re-invents the Ubuntu experience as a rolling-release distribution built on a stable desktop environment. With Pacstall & XFCE" HOMEPAGE="https://rhinolinux.org/" CREDENTIALS="-" + + RELEASES="2025.1" + +function releases_() { + echo 2025.1 +} + +function get_() { + local HASH="" + local ISO="Rhino-Linux-${RELEASE}-amd64.iso" + local URL="https://sourceforge.net/projects/rhino-linux-builder/files/${RELEASE}" + HASH="$(web_pipe "${URL}/${ISO}.sha256/download" | grep "(${ISO}" | cut -d' ' -f1)" + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/rockylinux b/public/rockylinux index 57ce72a..cfda123 100644 --- a/public/rockylinux +++ b/public/rockylinux @@ -5,5 +5,33 @@ BASEDOF="RedHat" DESCRIPTION="Open-source enterprise operating system designed to be 100% bug-for-bug compatible with Red Hat Enterprise Linux" HOMEPAGE="https://rockylinux.org" CREDENTIALS="-" + + RELEASES="9.5 9.4 9.3 9.2 9.1 9.0 8.9 8.8 8.7 8.6 8.5 8.4 8.3" EDITIONS="minimal dvd boot" + +function releases_() { + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe "http://dl.rockylinux.org/vault/rocky/" | grep "^> "${CONF_FILE}" +} + diff --git a/public/siduction b/public/siduction index 05fcd77..0932b61 100644 --- a/public/siduction +++ b/public/siduction @@ -5,5 +5,33 @@ BASEDOF="Debian" DESCRIPTION="Operating system based on the Linux kernel and the GNU project. In addition, there are applications and libraries from Debian" HOMEPAGE="https://siduction.org" CREDENTIALS="-" + + RELEASES="latest" EDITIONS="xorg xfce nox lxqt kde" + +function releases_() { + echo latest +} + +function editions_() { + #shellcheck disable=SC2046,SC2005 + NAME=$(web_pipe "https://mirror.math.princeton.edu/pub/siduction/iso/" | grep folder | cut -d'"' -f8 | tr -d '/') + web_pipe "https://mirror.math.princeton.edu/pub/siduction/iso/${NAME}/" | grep folder | cut -d'"' -f8 | tr -d '/' | sort -u +} + +function get_() { + local HASH="" + local DATE="" + local ISO="" + local NAME="" + local URL="" + NAME=$(web_pipe "https://mirror.math.princeton.edu/pub/siduction/iso/" | grep folder | cut -d'"' -f8 | tr -d '/') + URL="https://mirrors.dotsrc.org/siduction/iso/${NAME}/${EDITION}" + DATE=$(web_pipe "${URL}"| grep .iso.md5 | cut -d'-' -f6 | cut -d'.' -f1) + HASH=$(web_pipe "${URL}/${ISO}.md5" | cut -d' ' -f1) + VERSION=$(web_pipe "${URL}"| grep .iso.md5 | cut -d'-' -f2) + ISO="siduction-${VERSION}-${NAME}-${EDITION}-amd64-${DATE}.iso" + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/slackware b/public/slackware index d740b3b..84dccc0 100644 --- a/public/slackware +++ b/public/slackware @@ -5,5 +5,25 @@ BASEDOF="-" DESCRIPTION="Advanced Linux operating system, designed with the twin goals of ease of use and stability as top priorities" HOMEPAGE="http://www.slackware.com" CREDENTIALS="-" + + RELEASES="15.0 14.2 14.1 14.0 13.37" + +function releases_() { + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe "https://slackware.nl/slackware/slackware-iso/" | grep "slackware-" | cut -d'<' -f7 | cut -d'-' -f2 | sort -ru | head -n 5) +} + +function get_() { + local HASH="" + local ISO="slackware64-${RELEASE}-install-dvd.iso" + local URL="https://slackware.nl/slackware/slackware-iso/slackware64-${RELEASE}-iso" + HASH=$(web_pipe "${URL}/${ISO}.md5" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + +function specific_tweaks() { + echo "boot=\"legacy\"" >> "${CONF_FILE}" +} + diff --git a/public/slax b/public/slax index c8329a0..c17aa21 100644 --- a/public/slax +++ b/public/slax @@ -5,5 +5,36 @@ BASEDOF="Debian Slackware" DESCRIPTION="Compact, fast, and modern Linux operating system that combines sleek design with modular approach. With the ability to run directly from a USB flash drive without the need for installation, Slax is truly portable and fits easily in your pocket" HOMEPAGE="https://www.slax.org" CREDENTIALS="-" + + RELEASES="latest" EDITIONS="slackware debian" + +function releases_() { + echo latest +} + +function editions_() { + echo debian slackware +} + +function get_() { + local HASH="" + local ISO="" + local URL="" + case ${EDITION} in + debian) + URL="https://ftp.fi.muni.cz/pub/linux/slax/Slax-12.x" + ISO=$(web_pipe "${URL}/md5.txt" | grep '64bit-' | cut -d' ' -f3 | tail -n1);; + slackware) + URL="https://ftp.fi.muni.cz/pub/linux/slax/Slax-15.x" + ISO=$(web_pipe "${URL}/md5.txt" | grep '64bit-' | cut -d' ' -f3 | tail -n1);; + esac + HASH=$(web_pipe "${URL}/md5.txt" | grep '64bit-' | cut -d' ' -f1 | tail -n1) + echo "${URL}/${ISO} ${HASH}" +} + +function specific_tweaks() { + echo "boot=\"legacy\"" >> "${CONF_FILE}" +} + diff --git a/public/slint b/public/slint index 1d7a482..c04e60d 100644 --- a/public/slint +++ b/public/slint @@ -5,5 +5,26 @@ BASEDOF="Slackware" DESCRIPTION="Easy-to-use, versatile, blind-friendly Linux distribution for 64-bit computers. Slint is based on Slackware and borrows tools from Salix" HOMEPAGE="https://slint.fr" CREDENTIALS="-" + + RELEASES="15.0-5" + +function releases_() { + echo "15.0-5" +} + +function get_() { + local HASH="" + local MAJ_VER="" + local ISO="slint64-${RELEASE}.iso" + MAJ_VER="$(echo "${RELEASE}" | cut -d'-' -f 1)" + local URL="https://slackware.uk/slint/x86_64/slint-${MAJ_VER}/iso" + HASH=$(web_pipe "${URL}/${ISO}.sha256" | cut -d' ' -f4) + echo "${URL}/${ISO}" "${HASH}" +} + +function specific_tweaks() { + echo "disk_size=\"50G\"" >> "${CONF_FILE}" +} + diff --git a/public/slitaz b/public/slitaz index a564691..e444711 100644 --- a/public/slitaz +++ b/public/slitaz @@ -5,5 +5,27 @@ BASEDOF="-" DESCRIPTION="Simple, fast and low resource Linux OS for servers & desktops" HOMEPAGE="https://www.slitaz.org" CREDENTIALS="-" + + RELEASES="preinit loram core64 core-5in1 core" + +function releases_() { + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe "https://mirror.slitaz.org/iso/rolling/" | grep "class='iso'" | cut -d"'" -f4 | cut -d'-' -f3- | grep iso | cut -d'.' -f1 | sort -u) +} + +function get_() { + local HASH="" + local ISO="slitaz-rolling-${RELEASE}" + local URL="http://mirror.slitaz.org/iso/rolling" + HASH=$(web_pipe "${URL}/${ISO}.md5" | cut -d' ' -f1) + echo "${URL}/${ISO}.iso ${HASH}" +} + +function specific_tweaks() { + echo "boot=\"legacy\"" >> "${CONF_FILE}" + echo "disk_size=\"4G\"" >> "${CONF_FILE}" + echo "ram=\"512M\"" >> "${CONF_FILE}" +} + diff --git a/public/solus b/public/solus index 475f191..d571fc4 100644 --- a/public/solus +++ b/public/solus @@ -5,5 +5,26 @@ BASEDOF="-" DESCRIPTION="Designed for home computing. Every tweak enables us to deliver a cohesive computing experience" HOMEPAGE="https://getsol.us" CREDENTIALS="-" + + RELEASES="" EDITIONS="" + +function releases_() { + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe_json "https://downloads.getsol.us/isos/" | jq -r '.[].name[:-1]' | grep -E "^[0-9-]+$" | sort -u) +} + +function editions_() { + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe_json "https://downloads.getsol.us/isos/$(releases_ | tail -n1)/" | jq -r '.[].name | sub("Solus-(?.*)-Release-.*"; "\(.e)")' | sort -u) +} + +function get_() { + local HASH="" + local ISO="Solus-${EDITION}-Release-${RELEASE}.iso" + local URL="https://downloads.getsol.us/isos/${RELEASE}" + HASH=$(web_pipe "${URL}/${ISO}.sha256sum" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/sparkylinux b/public/sparkylinux index 080ed4b..f35c817 100644 --- a/public/sparkylinux +++ b/public/sparkylinux @@ -5,5 +5,36 @@ BASEDOF="Debian" DESCRIPTION="Fast, lightweight and fully customizable operating system which offers several versions for different use cases" HOMEPAGE="https://sparkylinux.org" CREDENTIALS="-" -RELEASES="7.6" -EDITIONS="xfce minimalgui minimalcli mate lxqt kde" + + +RELEASES="" +EDITIONS="" + +function releases_() { + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe "https://sparkylinux.org/download/stable/" | grep -E -o "sparkylinux-.*\.iso\"" | cut -d'-' -f2 | sort -ru) +} + +function editions_() { + #shellcheck disable=SC2046,SC2005 + if [ -z "${RELEASE}" ]; then + echo $(web_pipe "https://sparkylinux.org/download/stable/" | grep -E -o "sparkylinux-.*\.iso\"" | cut -d'-' -f4 | cut -d'.' -f1 | sort -u) + else + echo $(web_pipe "https://sparkylinux.org/download/stable/" | grep -E -o "sparkylinux-${RELEASE}-.*\.iso\"" | cut -d'-' -f4 | cut -d'.' -f1 | sort -u) + fi +} + +function get_() { + local HASH="" + local ISO="" + local URL="" + ISO="sparkylinux-${RELEASE}-x86_64-${EDITION}.iso" + case ${EDITION} in + minimalcli) URL="https://sourceforge.net/projects/sparkylinux/files/cli";; + minimalgui) URL="https://sourceforge.net/projects/sparkylinux/files/base";; + *) URL="https://sourceforge.net/projects/sparkylinux/files/${EDITION}";; + esac + HASH=$(web_pipe "${URL}/${ISO}.allsums.txt" | head -n 2 | grep 'iso' | cut -d' ' -f1) + echo "${URL}/${ISO}" "${HASH}" +} + diff --git a/public/spirallinux b/public/spirallinux index c288fcf..ace2918 100644 --- a/public/spirallinux +++ b/public/spirallinux @@ -5,5 +5,24 @@ BASEDOF="Debian" DESCRIPTION="Selection of Linux spins built from Debian GNU/Linux, with a focus on simplicity and out-of-the-box usability across all the major desktop environments" HOMEPAGE="https://spirallinux.github.io" CREDENTIALS="-" + + RELEASES="latest" EDITIONS="XFCE Plasma Mate LXQt Gnome Cinnamon Builder Budgie" + +function releases_() { + echo latest +} + +function editions_() { + echo Plasma XFCE Mate LXQt Gnome Budgie Cinnamon Builder +} + +function get_() { + local HASH="" + local ISO="SpiralLinux_${EDITION}_12.231005_x86-64.iso" + local URL="https://sourceforge.net/projects/spirallinux/files/12.231005" + HASH=$(web_pipe 'https://sourceforge.net/projects/spirallinux/rss?path=/' | grep "${ISO}" | grep 'md5' | cut -d'<' -f3 | cut -d'>' -f2) + echo "${URL}/${ISO}" "${HASH}" +} + diff --git a/public/tails b/public/tails index c3c33b9..0e81ba2 100644 --- a/public/tails +++ b/public/tails @@ -5,5 +5,26 @@ BASEDOF="Debian" DESCRIPTION="Portable operating system that protects against surveillance and censorship" HOMEPAGE="https://tails.net" CREDENTIALS="-" + + RELEASES="stable" + +function releases_() { + echo stable +} + +function get_() { + local JSON="" + local HASH="" + local URL="" + JSON="$(web_pipe "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') + HASH=$(echo "${JSON}" | jq -r '.installations[0]."installation-paths"[]|select(.type=="iso")|."target-files"[0].sha256') + echo "${URL} ${HASH}" +} + +function specific_tweaks() { + echo "boot=\"legacy\"" >> "${CONF_FILE}" +} + diff --git a/public/tinycore b/public/tinycore index 78e3885..dcc418e 100644 --- a/public/tinycore +++ b/public/tinycore @@ -5,5 +5,34 @@ BASEDOF="-" DESCRIPTION="Highly modular based system with community build extensions" HOMEPAGE="http://www.tinycorelinux.net" CREDENTIALS="-" + + RELEASES="15 14" EDITIONS="TinyCorePure64 TinyCore CorePure64 CorePlus Core" + +function releases_() { + echo 15 14 +} + +function editions_() { + echo Core TinyCore CorePlus CorePure64 TinyCorePure64 +} + +function get_() { + local ARCH="x86" + local HASH="" + local ISO="${EDITION}-${RELEASE}.0.iso" + case "${EDITION}" in + *Pure*) ARCH+="_64";; + esac + # tinycorelinux.net not stable enough + #local URL="http://www.tinycorelinux.net/${RELEASE}.x/${ARCH}/release" + local URL="https://distro.ibiblio.org/tinycorelinux/${RELEASE}.x/${ARCH}/release" + HASH=$(web_pipe "${URL}/${ISO}.md5.txt" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + +function specific_tweaks() { + echo "boot=\"legacy\"" >> "${CONF_FILE}" +} + diff --git a/public/trisquel b/public/trisquel index 1cb9c49..c72f542 100644 --- a/public/trisquel +++ b/public/trisquel @@ -5,5 +5,30 @@ BASEDOF="Ubuntu" DESCRIPTION="Fully free operating system for home users, small enterprises and educational centers" HOMEPAGE="https://trisquel.info" CREDENTIALS="-" + + RELEASES="11.0 10.0.1" EDITIONS="sugar mate lxde kde" + +function releases_() { + echo 11.0 10.0.1 +} + +function editions_() { + echo mate lxde kde sugar +} + +function get_() { + local HASH="" + local ISO="" + local URL="https://mirrors.ocf.berkeley.edu/trisquel-images" + case ${EDITION} in + mate) ISO="trisquel_${RELEASE}_amd64.iso";; + lxde) ISO="trisquel-mini_${RELEASE}_amd64.iso";; + kde) ISO="triskel_${RELEASE}_amd64.iso";; + sugar) ISO="trisquel-sugar_${RELEASE}_amd64.iso";; + esac + HASH=$(web_pipe "${URL}/${ISO}.sha1" | grep "${ISO}" | cut -d' ' -f1) + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/truenas-core b/public/truenas-core index 831631f..c6cb1e2 100644 --- a/public/truenas-core +++ b/public/truenas-core @@ -5,5 +5,29 @@ BASEDOF="FreeBSD" DESCRIPTION="World’s most popular storage OS because it gives you the power to build your own professional-grade storage system to use in a variety of data-intensive applications without any software costs" HOMEPAGE="https://www.truenas.com/truenas-core" CREDENTIALS="-" +GUEST="sugar mate lxde kde" + RELEASES="13" + +function releases_() { + echo 13 +} + +function get_() { + local ISO="" + local URL="" + local DLINFO="https://www.truenas.com/download-truenas-core/" + URL=$(web_pipe "${DLINFO}" | grep -o "\"https://.*${RELEASE}.*\.iso\"" | cut -d'"' -f 2) + HASH=$(web_pipe "${URL}".sha256 | cut -d' ' -f1) + echo "${URL} ${HASH}" +} + +function specific_tweaks() { + echo "boot=\"legacy\"" >> "${CONF_FILE}" + # the rest is non-functional + # echo "bootdrive_size=\"5G\"" >> "${CONF_FILE}" # boot drive + # echo "1stdrive_size=\"20G\"" >> "${CONF_FILE}" # for testing + # echo "2nddrive_size=\"20G\"" >> "${CONF_FILE}" # again, for testing +} + diff --git a/public/truenas-scale b/public/truenas-scale index 3e557c5..ae21142 100644 --- a/public/truenas-scale +++ b/public/truenas-scale @@ -5,5 +5,30 @@ BASEDOF="Debian" DESCRIPTION="Open Source Hyperconverged Infrastructure (HCI) solution. In addition to powerful scale-out storage capabilities, SCALE adds Linux Containers and VMs (KVM) so apps run closer to data" HOMEPAGE="https://www.truenas.com/truenas-scale" CREDENTIALS="-" +GUEST="sugar mate lxde kde" + RELEASES="24" + +function releases_() { + echo 24 +} + +function get_() { + local HASH="" + local ISO="" + local URL="" + local DLINFO="https://www.truenas.com/download-truenas-scale/" + URL=$(web_pipe "${DLINFO}" | grep -o "\"https://.*${RELEASE}.*\.iso\"" | cut -d'"' -f 2) + HASH=$(web_pipe "${URL}.sha256" | cut -d' ' -f1) + echo "${URL} ${HASH}" +} + +function specific_tweaks() { + echo "boot=\"legacy\"" >> "${CONF_FILE}" + # the rest is non-functional + # echo "bootdrive_size=\"5G\"" >> "${CONF_FILE}" # boot drive + # echo "1stdrive_size=\"20G\"" >> "${CONF_FILE}" # for testing + # echo "2nddrive_size=\"20G\"" >> "${CONF_FILE}" # again, for testing +} + diff --git a/public/tuxedo-os b/public/tuxedo-os index e087667..a995b66 100644 --- a/public/tuxedo-os +++ b/public/tuxedo-os @@ -5,5 +5,21 @@ BASEDOF="Ubuntu" DESCRIPTION="KDE Ubuntu LTS designed to go with their Linux hardware" HOMEPAGE="https://www.tuxedocomputers.com" CREDENTIALS="-" + + RELEASES="current" + +function releases_() { + echo current +} + +function get_() { + local HASH="" + local ISO="" + local URL="https://os.tuxedocomputers.com" + ISO="$(web_pipe "https://os.tuxedocomputers.com/" | grep -m 1 current.iso | cut -d '=' -f 4 | cut -d '"' -f 2)" + HASH="$(web_pipe "https://os.tuxedocomputers.com/checksums/${ISO}.sha256" | cut -d ' ' -f 1)" + echo "${URL}/${ISO} ${HASH}" +} + diff --git a/public/ubuntu b/public/ubuntu index a946e35..5e2939e 100644 --- a/public/ubuntu +++ b/public/ubuntu @@ -5,5 +5,80 @@ BASEDOF="Debian" DESCRIPTION="Complete desktop Linux operating system, freely available with both community and professional support" HOMEPAGE="https://ubuntu.com" CREDENTIALS="-" +GUEST="sugar mate lxde kde" + RELEASES="daily-live 24.10 24.04 22.04 20.04 18.04 16.04 14.04" + +function releases_() { + local VERSION_DATA="" + local SUPPORTED_VERSIONS=() + VERSION_DATA="$(IFS=$'\n' web_pipe https://api.launchpad.net/devel/ubuntu/series | jq -r '.entries[]')" + # shellcheck disable=SC2207 + SUPPORTED_VERSIONS=($(IFS=$'\n' jq -r 'select(.status=="Supported" or .status=="Current Stable Release") | .version' <<<"${VERSION_DATA}" | sort)) + case "${OS}" in + ubuntu) + echo "${SUPPORTED_VERSIONS[@]}" daily-live;; + kubuntu|lubuntu|ubuntukylin|ubuntu-mate|ubuntustudio|xubuntu) + # after 16.04 + echo "${SUPPORTED_VERSIONS[@]:1}" daily-live;; + ubuntu-budgie) + # after 18.04 + echo "${SUPPORTED_VERSIONS[@]:2}" daily-live;; + edubuntu|ubuntu-unity|ubuntucinnamon) + # after 23.10 + echo "${SUPPORTED_VERSIONS[@]:5}" daily-live;; + esac +} + +function get_() { + local ISO="" + local HASH="" + local URL="" + local DATA="" + + if [[ "${RELEASE}" == "daily"* ]] && [ "${OS}" == "ubuntustudio" ]; then + # Ubuntu Studio daily-live images are in the dvd directory + RELEASE="dvd" + fi + if [[ "${RELEASE}" == "jammy-daily" ]]; then + if [[ "${OS}" == "ubuntustudio" ]]; then + URL="https://cdimage.ubuntu.com/${OS}/jammy/dvd/current" + else + URL="https://cdimage.ubuntu.com/${OS}/jammy/daily-live/current" + fi + VM_PATH="${OS}-jammy-live" + elif [[ "${RELEASE}" == "daily"* ]] || [ "${RELEASE}" == "dvd" ]; then + URL="https://cdimage.ubuntu.com/${OS}/${RELEASE}/current" + VM_PATH="${OS}-${RELEASE}" + elif [ "${OS}" == "ubuntu" ]; then + URL="https://releases.ubuntu.com/${RELEASE}" + else + URL="https://cdimage.ubuntu.com/${OS}/releases/${RELEASE}/release" + fi + if web_check "${URL}/SHA256SUMS"; then + DATA=$(web_pipe "${URL}/SHA256SUMS" | grep 'desktop\|dvd\|install' | grep amd64 | grep iso | grep -v "+mac") + ISO=$(cut -d'*' -f2 <<<"${DATA}" | sed '1q;d') + HASH=$(cut -d' ' -f1 <<<"${DATA}" | sed '1q;d') + else + DATA=$(web_pipe "${URL}/MD5SUMS" | grep 'desktop\|dvd\|install' | grep amd64 | grep iso | grep -v "+mac") + ISO=$(cut -d'*' -f2 <<<"${DATA}") + HASH=$(cut -d' ' -f1 <<<"${DATA}") + fi + if [ -z "${ISO}" ] || [ -z "${HASH}" ]; then + echo "${PRETTY} ${RELEASE} is currently unavailable. Please select other OS/Release combination" + exit 1 + fi + if [[ "${RELEASE}" == "daily"* ]] || [ "${RELEASE}" == "dvd" ]; then + zsync_get "${URL}/${ISO}" "${VM_PATH}" "${OS}-devel.iso" + make_vm_config "${OS}-devel.iso" + elif [[ "${RELEASE}" == "jammy-daily" ]]; then + zsync_get "${URL}/${ISO}" "${VM_PATH}" "${OS}-jammy-live.iso" + make_vm_config "${OS}-jammy-live.iso" + else + web_get "${URL}/${ISO}" "${VM_PATH}" + check_hash "${ISO}" "${HASH}" + make_vm_config "${ISO}" + fi +} + diff --git a/public/ubuntu-server b/public/ubuntu-server index bbd6600..ce8b723 100644 --- a/public/ubuntu-server +++ b/public/ubuntu-server @@ -5,5 +5,60 @@ BASEDOF="Debian" DESCRIPTION="Brings economic and technical scalability to your datacentre, public or private. Whether you want to deploy an OpenStack cloud, a Kubernetes cluster or a 50,000-node render farm, Ubuntu Server delivers the best value scale-out performance available" HOMEPAGE="https://ubuntu.com/server" CREDENTIALS="-" + + RELEASES="daily-live 24.10 24.04 22.04 20.04 18.04 16.04 14.04" + +function releases_() { + local ALL_VERSIONS=() + # shellcheck disable=SC2207 + ALL_VERSIONS=($(IFS=$'\n' web_pipe http://releases.ubuntu.com/streams/v1/com.ubuntu.releases:ubuntu-server.json | jq -r '.products[] | select(.arch=="amd64") | .version' | sort -rV)) + echo daily-live "${ALL_VERSIONS[@]}" +} + +function get_() { + local HASH="" + local ISO="" + local NAME="live-server" + local URL="" + + if [[ "${RELEASE}" == "daily"* ]]; then + URL="https://cdimage.ubuntu.com/${OS}/${RELEASE}/current" + else + URL="https://releases.ubuntu.com/${RELEASE}" + fi + + case "${RELEASE}" in + 14*|16*) NAME="server";; + esac + + if web_check "${URL}/SHA256SUMS"; then + DATA=$(web_pipe "${URL}/SHA256SUMS" | grep "${NAME}" | grep amd64 | grep iso) + ISO=$(cut -d'*' -f2 <<<"${DATA}") + HASH=$(cut -d' ' -f1 <<<"${DATA}") + else + DATA=$(web_pipe "${URL}/MD5SUMS" | grep "${NAME}" | grep amd64 | grep iso) + ISO=$(cut -d' ' -f3 <<<"${DATA}") + HASH=$(cut -d' ' -f1 <<<"${DATA}") + fi + if [[ "${RELEASE}" == "daily"* ]] || [ "${RELEASE}" == "dvd" ]; then + zsync_get "${URL}/${ISO}" "${VM_PATH}" "${OS}-devel.iso" + make_vm_config "${OS}-devel.iso" + else + web_get "${URL}/${ISO}" "${VM_PATH}" + check_hash "${ISO}" "${HASH}" + make_vm_config "${ISO}" + fi +} + +function specific_tweaks() { + # 22.04+ fails on LVM build if disk size is < 10G + # 22.04.1 fails on auto-install if TPM is disabled + echo "disk_size=\"10G\"" >> "${CONF_FILE}" + echo "ram=\"4G\"" >> "${CONF_FILE}" + if [[ "${RELEASE}" == *"22.04"* ]]; then + echo "tpm=\"on\"" >> "${CONF_FILE}" + fi +} + diff --git a/public/vanillaos b/public/vanillaos index ace502d..e760c95 100644 --- a/public/vanillaos +++ b/public/vanillaos @@ -5,5 +5,28 @@ BASEDOF="Ubuntu" DESCRIPTION="Designed to be a reliable and productive operating system for your daily work" HOMEPAGE="https://vanillaos.org" CREDENTIALS="-" + + RELEASES="22.10-r8 22.10-r7.5 22.10-r7 22.10-r6 22.10-r5 22.10-r4 22.10-r3 22.10-r2 22.10-r1 22.10 2.0" + +function releases_() { + #shellcheck disable=SC2046,SC2005 + echo $(web_pipe "https://api.github.com/repos/Vanilla-OS/live-iso/releases" | grep 'download_url' | cut -d'/' -f8 | sort -ru) +} + +function get_() { + local HASH="" + local HASH_URL="" + local ISO="" + ISO=$(web_pipe "https://api.github.com/repos/Vanilla-OS/live-iso/releases" | grep 'download_url' | grep "${RELEASE}" | head -n 1 | cut -d'"' -f4) + HASH_URL="${ISO//.iso/.sha256.txt}" + HASH=$(web_pipe "${HASH_URL}" | cut -d' ' -f1) + echo "${ISO} ${HASH}" +} + +function specific_tweaks() { + ## Minimum is 50G for abroot, but a 64GB is allocated to give some headroom + echo "disk_size=\"64G\"" >> "${CONF_FILE}" +} + diff --git a/public/ventoy b/public/ventoy index 5c0846a..b92adb1 100644 --- a/public/ventoy +++ b/public/ventoy @@ -5,5 +5,20 @@ BASEDOF="Void" DESCRIPTION="Tool to create bootable USB drive for ISO/WIM/IMG/VHD(x)/EFI files. " HOMEPAGE="https://www.ventoy.net" CREDENTIALS="-" -RELEASES="1.1.02 1.1.01 1.1.00 1.0.99 1.0.98 1.0.97 1.0.96 1.0.95 1.0.94 1.0.93 1.0.91 1.0.90 1.0.89 1.0.88 1.0.87 1.0.86 1.0.85 1.0.84" + + +RELEASES="1.1.05 1.1.04 1.1.02 1.1.01 1.1.00 1.0.99 1.0.98 1.0.97 1.0.96 1.0.95 1.0.94 1.0.93 1.0.91 1.0.90 1.0.89 1.0.88 1.0.87 1.0.86 1.0.85" + + +function releases_() { + echo $(web_pipe "https://sourceforge.net/projects/ventoy/rss?path=/" | grep 'title>/dev/null + + cat << 'EOF' > "${1}/unattended/autounattend.xml" + + + + + + false + + + * + + + + + + true + + + 1 + + + + + + true + + + * + + Quickemu Project + Quickemu + 24/7 + + Quickemu Project + https://github.com/quickemu-project/quickemu/issues + + Quickemu Project + W269N-WFGWX-YVC9B-4J6C9-T83GX + + + 0 + + + + + + + false + + + + 0 + true + + + + 1 + Primary + 256 + + + + 2 + EFI + 128 + + + + 3 + MSR + 128 + + + + 4 + Primary + true + + + + + + 1 + 1 + + NTFS + DE94BBA4-06D1-4D40-A16A-BFD50179D6AC + + + + 2 + 2 + + FAT32 + + + + 3 + 3 + + + + 4 + 4 + + C + NTFS + + + + + + true + Never + + + + + 0 + 4 + + false + + + + + 1 + reg add HKLM\System\Setup\LabConfig /v BypassCPUCheck /t REG_DWORD /d 0x00000001 /f + + + 2 + reg add HKLM\System\Setup\LabConfig /v BypassRAMCheck /t REG_DWORD /d 0x00000001 /f + + + 3 + reg add HKLM\System\Setup\LabConfig /v BypassSecureBootCheck /t REG_DWORD /d 0x00000001 /f + + + 4 + reg add HKLM\System\Setup\LabConfig /v BypassTPMCheck /t REG_DWORD /d 0x00000001 /f + + + + false + Never + + + true + Quickemu + Quickemu Project + + + W269N-WFGWX-YVC9B-4J6C9-T83GX + Never + + + + + + + + + E:\qemufwcfg\w10\amd64 + + + E:\vioinput\w10\amd64 + + + E:\vioscsi\w10\amd64 + + + E:\viostor\w10\amd64 + + + E:\vioserial\w10\amd64 + + + E:\qxldod\w10\amd64 + + + E:\amd64\w10 + + + E:\viogpudo\w10\amd64 + + + E:\viorng\w10\amd64 + + + E:\NetKVM\w10\amd64 + + + E:\viofs\w10\amd64 + + + E:\Balloon\w10\amd64 + + + + + + + + + + quickemu + true</PlainText> + </Password> + <Enabled>true</Enabled> + <Username>Quickemu</Username> + </AutoLogon> + <DisableAutoDaylightTimeSet>false</DisableAutoDaylightTimeSet> + <OOBE> + <HideEULAPage>true</HideEULAPage> + <HideLocalAccountScreen>true</HideLocalAccountScreen> + <HideOEMRegistrationScreen>true</HideOEMRegistrationScreen> + <HideOnlineAccountScreens>true</HideOnlineAccountScreens> + <HideWirelessSetupInOOBE>true</HideWirelessSetupInOOBE> + <NetworkLocation>Home</NetworkLocation> + <ProtectYourPC>3</ProtectYourPC> + <SkipUserOOBE>true</SkipUserOOBE> + <SkipMachineOOBE>true</SkipMachineOOBE> + <VMModeOptimizations> + <SkipWinREInitialization>true</SkipWinREInitialization> + </VMModeOptimizations> + </OOBE> + <UserAccounts> + <LocalAccounts> + <LocalAccount wcm:action="add"> + <Password> + <Value>quickemu</Value> + <PlainText>true</PlainText> + </Password> + <Description>Quickemu</Description> + <DisplayName>Quickemu</DisplayName> + <Group>Administrators</Group> + <Name>Quickemu</Name> + </LocalAccount> + </LocalAccounts> + </UserAccounts> + <RegisteredOrganization>Quickemu Project</RegisteredOrganization> + <RegisteredOwner>Quickemu</RegisteredOwner> + <FirstLogonCommands> + <SynchronousCommand wcm:action="add"> + <CommandLine>msiexec /i E:\guest-agent\qemu-ga-x86_64.msi /quiet /passive /qn</CommandLine> + <Description>Install Virtio Guest Agent</Description> + <Order>1</Order> + </SynchronousCommand> + <SynchronousCommand wcm:action="add"> + <CommandLine>msiexec /i F:\spice-webdavd-x64-latest.msi /quiet /passive /qn</CommandLine> + <Description>Install spice-webdavd file sharing agent</Description> + <Order>2</Order> + </SynchronousCommand> + <SynchronousCommand wcm:action="add"> + <CommandLine>msiexec /i F:\UsbDk_1.0.22_x64.msi /quiet /passive /qn</CommandLine> + <Description>Install usbdk USB sharing agent</Description> + <Order>3</Order> + </SynchronousCommand> + <SynchronousCommand wcm:action="add"> + <CommandLine>msiexec /i F:\spice-vdagent-x64-0.10.0.msi /quiet /passive /qn</CommandLine> + <Description>Install spice-vdagent SPICE agent</Description> + <Order>4</Order> + </SynchronousCommand> + <SynchronousCommand wcm:action="add"> + <CommandLine>Cmd /c POWERCFG -H OFF</CommandLine> + <Description>Disable Hibernation</Description> + <Order>5</Order> + </SynchronousCommand> + </FirstLogonCommands> + </component> + </settings> +</unattend> +EOF + + +echo "Downloading Spice drivers..." +web_get https://www.spice-space.org/download/windows/spice-webdavd/spice-webdavd-x64-latest.msi "${VM_PATH}/unattended" +web_get https://www.spice-space.org/download/windows/vdagent/vdagent-win-0.10.0/spice-vdagent-x64-0.10.0.msi "${VM_PATH}/unattended" +web_get https://www.spice-space.org/download/windows/usbdk/UsbDk_1.0.22_x64.msi "${VM_PATH}/unattended" + +echo "Making unattended.iso" +mkisofs -quiet -l -o "${VM_PATH}/unattended.iso" "${VM_PATH}/unattended/" +} + +function handle_curl_error() { + local error_code="$1" + local fatal_error_action=2 + case "$error_code" in + 6) + echo "Failed to resolve Microsoft servers! Is there an Internet connection? Exiting..." + return "$fatal_error_action" + ;; + 7) + echo "Failed to contact Microsoft servers! Is there an Internet connection or is the server down?" + ;; + 8) + echo "Microsoft servers returned a malformed HTTP response!" + ;; + 22) + echo "Microsoft servers returned a failing HTTP status code!" + ;; + 23) + echo "Failed at writing Windows media to disk! Out of disk space or permission error? Exiting..." + return "$fatal_error_action" + ;; + 26) + echo "Ran out of memory during download! Exiting..." + return "$fatal_error_action" + ;; + 36) + echo "Failed to continue earlier download!" + ;; + 63) + echo "Microsoft servers returned an unexpectedly large response!" + ;; + # POSIX defines exit statuses 1-125 as usable by us + # https://pubs.opengroup.org/onlinepubs/9699919799/utilities/V3_chap02.html#tag_18_08_02 + $((error_code <= 125))) + # Must be some other server or network error (possibly with this specific request/file) + # This is when accounting for all possible errors in the curl manual assuming a correctly formed curl command and an HTTP(S) request, using only the curl features we're using, and a sane build + echo "Miscellaneous server or network error!" + ;; + 126 | 127 ) + echo "Curl command not found! Please install curl and try again. Exiting..." + return "$fatal_error_action" + ;; + # Exit statuses are undefined by POSIX beyond this point + *) + case "$(kill -l "$error_code")" in + # Signals defined to exist by POSIX: + # https://pubs.opengroup.org/onlinepubs/009695399/basedefs/signal.h.html + INT) + echo "Curl was interrupted!" + ;; + # There could be other signals but these are most common + SEGV | ABRT ) + echo "Curl crashed! Failed exploitation attempt? Please report any core dumps to curl developers. Exiting..." + return "$fatal_error_action" + ;; + *) + echo "Curl terminated due to a fatal signal!" + ;; + esac + esac + return 1 +} + +function download_windows_server() { + local iso_download_page_html="" + # Copyright (C) 2024 Elliot Killick <contact@elliotkillick.com> + # This function is adapted from the Mido project: + # https://github.com/ElliotKillick/Mido + + # Download enterprise evaluation Windows versions + local windows_version="$1" + local enterprise_type="$2" + local PRETTY_RELEASE="" + + case "${RELEASE}" in + *) PRETTY_RELEASE="${RELEASE}";; + esac + + echo "Downloading $(pretty_name "${OS}") ${PRETTY_RELEASE} (${I18N})" + + local url="https://www.microsoft.com/en-us/evalcenter/download-$windows_version" + + echo " - Parsing download page: ${url}" + iso_download_page_html="$(curl --disable --silent --location --max-filesize 1M --fail --proto =https --tlsv1.2 --http1.1 -- "$url")" || { + handle_curl_error $? + return $? + } + + if ! [ "$iso_download_page_html" ]; then + # This should only happen if there's been some change to where this download page is located + echo " - Windows server download page gave us an empty response" + return 1 + fi + + local CULTURE="" + local COUNTRY="" + case "${I18N}" in + "English (Great Britain)") + CULTURE="en-gb" + COUNTRY="GB";; + "Chinese (Simplified)") + CULTURE="zh-cn" + COUNTRY="CN";; + "Chinese (Traditional)") + CULTURE="zh-tw" + COUNTRY="TW";; + "French") + CULTURE="fr-fr" + COUNTRY="FR";; + "German") + CULTURE="de-de" + COUNTRY="DE";; + "Italian") + CULTURE="it-it" + COUNTRY="IT";; + "Japanese") + CULTURE="ja-jp" + COUNTRY="JP";; + "Korean") + CULTURE="ko-kr" + COUNTRY="KR";; + "Portuguese (Brazil)") + CULTURE="pt-br" + COUNTRY="BR";; + "Spanish") + CULTURE="es-es" + COUNTRY="ES";; + "Russian") + CULTURE="ru-ru" + COUNTRY="RU";; + *) + CULTURE="en-us" + COUNTRY="US";; + esac + + echo " - Getting download link.." + iso_download_links="$(echo "$iso_download_page_html" | grep -o "https://go.microsoft.com/fwlink/p/?LinkID=[0-9]\+&clcid=0x[0-9a-z]\+&culture=${CULTURE}&country=${COUNTRY}")" || { + # This should only happen if there's been some change to the download endpoint web address + echo " - Windows server download page gave us no download link" + return 1 + } + + # Limit untrusted size for input validation + iso_download_links="$(echo "$iso_download_links" | head -c 1024)" + + case "$enterprise_type" in + # Select x64 download link + "enterprise") iso_download_link=$(echo "$iso_download_links" | head -n 2 | tail -n 1) ;; + # Select x64 LTSC download link + "ltsc") iso_download_link=$(echo "$iso_download_links" | head -n 4 | tail -n 1) ;; + *) iso_download_link="$iso_download_links" ;; + esac + + # Follow redirect so proceeding log message is useful + # This is a request we make this Fido doesn't + # We don't need to set "--max-filesize" here because this is a HEAD request and the output is to /dev/null anyway + iso_download_link="$(curl --disable --silent --location --output /dev/null --silent --write-out "%{url_effective}" --head --fail --proto =https --tlsv1.2 --http1.1 -- "$iso_download_link")" || { + # This should only happen if the Microsoft servers are down + handle_curl_error $? + return $? + } + + # Limit untrusted size for input validation + iso_download_link="$(echo "$iso_download_link" | head -c 1024)" + + echo " - URL: $iso_download_link" + + # Download ISO + FILE_NAME="${iso_download_link##*/}" + web_get "${iso_download_link}" "${VM_PATH}" "${FILE_NAME}" + OS="windows-server" +} + +function download_windows_workstation() { + local HASH="" + local session_id="" + local iso_download_page_html="" + local product_edition_id="" + local language_skuid_table_json="" + local sku_id="" + local iso_download_link_json="" + local iso_download_link="" + + echo "Downloading Windows ${RELEASE} (${I18N})" + # This function is adapted from the Mido project: + # https://github.com/ElliotKillick/Mido + # Download newer consumer Windows versions from behind gated Microsoft API + + # Either 10, or 11 + local windows_version="$1" + + local url="https://www.microsoft.com/en-us/software-download/windows$windows_version" + case "$windows_version" in + 10) url="${url}ISO";; + esac + + local user_agent="Mozilla/5.0 (X11; Linux x86_64; rv:100.0) Gecko/20100101 Firefox/100.0" + session_id="$(uuidgen)" + + # Get product edition ID for latest release of given Windows version + # Product edition ID: This specifies both the Windows release (e.g. 22H2) and edition ("multi-edition" is default, either Home/Pro/Edu/etc., we select "Pro" in the answer files) in one number + # This is the *only* request we make that Fido doesn't. Fido manually maintains a list of all the Windows release/edition product edition IDs in its script (see: $WindowsVersions array). This is helpful for downloading older releases (e.g. Windows 10 1909, 21H1, etc.) but we always want to get the newest release which is why we get this value dynamically + # Also, keeping a "$WindowsVersions" array like Fido does would be way too much of a maintenance burden + # Remove "Accept" header that curl sends by default + echo " - Parsing download page: ${url}" + iso_download_page_html="$(curl --disable --silent --user-agent "$user_agent" --header "Accept:" --max-filesize 1M --fail --proto =https --tlsv1.2 --http1.1 -- "$url")" || { + handle_curl_error $? + return $? + } + + echo -n " - Getting Product edition ID: " + # tr: Filter for only numerics to prevent HTTP parameter injection + # head -c was recently added to POSIX: https://austingroupbugs.net/view.php?id=407 + product_edition_id="$(echo "$iso_download_page_html" | grep -Eo '<option value="[0-9]+">Windows' | cut -d '"' -f 2 | head -n 1 | tr -cd '0-9' | head -c 16)" + echo "$product_edition_id" + + echo " - Permit Session ID: $session_id" + # Permit Session ID + # "org_id" is always the same value + curl --disable --silent --output /dev/null --user-agent "$user_agent" --header "Accept:" --max-filesize 100K --fail --proto =https --tlsv1.2 --http1.1 -- "https://vlscppe.microsoft.com/tags?org_id=y6jn8c31&session_id=$session_id" || { + # This should only happen if there's been some change to how this API works + handle_curl_error $? + return $? + } + + local profile="606624d44113" + + echo -n " - Getting language SKU ID: " + # Get language -> skuID association table + language_skuid_table_json="$(curl --disable -s --fail --max-filesize 100K --proto =https --tlsv1.2 --http1.1 "https://www.microsoft.com/software-download-connector/api/getskuinformationbyproductedition?profile=${profile}&ProductEditionId=${product_edition_id}&SKU=undefined&friendlyFileName=undefined&Locale=en-US&sessionID=${session_id}")" || { + handle_curl_error $? + return $? + } + + sku_id="$(echo "${language_skuid_table_json}" | jq -r '.Skus[] | select(.LocalizedLanguage=="'"${I18N}"'" or .Language=="'"${I18N}"'").Id')" + echo "$sku_id" + + echo " - Getting ISO download link..." + # Get ISO download link + # If any request is going to be blocked by Microsoft it's always this last one (the previous requests always seem to succeed) + # --referer: Required by Microsoft servers to allow request + iso_download_link_json="$(curl --disable -s --fail --referer "$url" "https://www.microsoft.com/software-download-connector/api/GetProductDownloadLinksBySku?profile=${profile}&productEditionId=undefined&SKU=${sku_id}&friendlyFileName=undefined&Locale=en-US&sessionID=${session_id}")" + + local failed=0 + + if ! [ "$iso_download_link_json" ]; then + # This should only happen if there's been some change to how this API works + echo " - Microsoft servers gave us an empty response to our request for an automated download." + failed=1 + fi + + if echo "$iso_download_link_json" | grep -q "Sentinel marked this request as rejected."; then + echo " - WARNING! Microsoft blocked the automated download request based on your IP address." + failed=1 + fi + + if [ ${failed} -eq 1 ]; then + echo " Manually download the Windows ${windows_version} ISO using a web browser from: ${url}" + echo " Save the downloaded ISO to: $(realpath "${VM_PATH}")" + echo " Update the config file to reference the downloaded ISO: ./${VM_PATH}.conf" + echo " Continuing with the VM creation process..." + return 1 + fi + + # Filter for 64-bit ISO download URL + iso_download_link="$(echo "${iso_download_link_json}" | jq -r '.ProductDownloadOptions[].Uri' | grep x64)" + + if ! [ "$iso_download_link" ]; then + # This should only happen if there's been some change to the download endpoint web address + echo " - Microsoft servers gave us no download link to our request for an automated download. Please manually download this ISO in a web browser: $url" + return 1 + fi + + echo " - URL: ${iso_download_link%%\?*}" + + # Download ISO + FILE_NAME="$(echo "$iso_download_link" | cut -d'?' -f1 | cut -d'/' -f5)" + web_get "${iso_download_link}" "${VM_PATH}" "${FILE_NAME}" +} + +function get_windows() { + if [ "${OS}" == "windows-server" ]; then + download_windows_server "windows-server-${RELEASE}" + else + download_windows_workstation "${RELEASE}" + fi + + if [ "${OPERATION}" == "download" ]; then + exit 0 + fi + + echo "Downloading VirtIO drivers..." + web_get "https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/stable-virtio/virtio-win.iso" "${VM_PATH}" + + rm -f "${VM_PATH}/unattended.iso" + case ${RELEASE} in + 10|11) + unattended_windows "${VM_PATH}" + ;; + esac + + if [ -n "${FILE_NAME}" ]; then + make_vm_config "${FILE_NAME}" "virtio-win.iso" + else + make_vm_config "windows-${RELEASE}.iso" "virtio-win.iso" + fi +} + diff --git a/public/windows-server b/public/windows-server index f7a65e4..b4afd26 100644 --- a/public/windows-server +++ b/public/windows-server @@ -5,5 +5,620 @@ BASEDOF="-" DESCRIPTION="Platform for building an infrastructure of connected applications, networks, and web services" HOMEPAGE="https://www.microsoft.com/en-us/windows-server" CREDENTIALS="-" +GUEST="xfce-musl xfce-glibc musl glibc" + RELEASES="2022 2019 2016" + +function releases_() { + echo 2022 2019 2016 +} + +function languages_windows-server() { + I18NS=("English (United States)" "Chinese (Simplified)" "French" "German" "Italian" "Japanese" "Russian" "Spanish") +} + +function unattended_windows() { + mkdir -p "${1}/unattended" 2>/dev/null + + cat << 'EOF' > "${1}/unattended/autounattend.xml" +<?xml version="1.0" encoding="utf-8"?> +<unattend xmlns="urn:schemas-microsoft-com:unattend" + xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" + xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + <!-- + For documentation on components: + https://docs.microsoft.com/en-us/windows-hardware/customize/desktop/unattend/ + --> + <settings pass="offlineServicing"> + <component name="Microsoft-Windows-LUA-Settings" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS" xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + <EnableLUA>false</EnableLUA> + </component> + <component name="Microsoft-Windows-Shell-Setup" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS" xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + <ComputerName>*</ComputerName> + </component> + </settings> + + <settings pass="generalize"> + <component name="Microsoft-Windows-PnPSysprep" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS"> + <PersistAllDeviceInstalls>true</PersistAllDeviceInstalls> + </component> + <component name="Microsoft-Windows-Security-SPP" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS" xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + <SkipRearm>1</SkipRearm> + </component> + </settings> + + <settings pass="specialize"> + <component name="Microsoft-Windows-Security-SPP-UX" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS" xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + <SkipAutoActivation>true</SkipAutoActivation> + </component> + <component name="Microsoft-Windows-Shell-Setup" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS" xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + <ComputerName>*</ComputerName> + <OEMInformation> + <Manufacturer>Quickemu Project</Manufacturer> + <Model>Quickemu</Model> + <SupportHours>24/7</SupportHours> + <SupportPhone></SupportPhone> + <SupportProvider>Quickemu Project</SupportProvider> + <SupportURL>https://github.com/quickemu-project/quickemu/issues</SupportURL> + </OEMInformation> + <OEMName>Quickemu Project</OEMName> + <ProductKey>W269N-WFGWX-YVC9B-4J6C9-T83GX</ProductKey> + </component> + <component name="Microsoft-Windows-SQMApi" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS" xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + <CEIPEnabled>0</CEIPEnabled> + </component> + </settings> + + <settings pass="windowsPE"> + <component name="Microsoft-Windows-Setup" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS" xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + <Diagnostics> + <OptIn>false</OptIn> + </Diagnostics> + <DiskConfiguration> + <Disk wcm:action="add"> + <DiskID>0</DiskID> + <WillWipeDisk>true</WillWipeDisk> + <CreatePartitions> + <!-- Windows RE Tools partition --> + <CreatePartition wcm:action="add"> + <Order>1</Order> + <Type>Primary</Type> + <Size>256</Size> + </CreatePartition> + <!-- System partition (ESP) --> + <CreatePartition wcm:action="add"> + <Order>2</Order> + <Type>EFI</Type> + <Size>128</Size> + </CreatePartition> + <!-- Microsoft reserved partition (MSR) --> + <CreatePartition wcm:action="add"> + <Order>3</Order> + <Type>MSR</Type> + <Size>128</Size> + </CreatePartition> + <!-- Windows partition --> + <CreatePartition wcm:action="add"> + <Order>4</Order> + <Type>Primary</Type> + <Extend>true</Extend> + </CreatePartition> + </CreatePartitions> + <ModifyPartitions> + <!-- Windows RE Tools partition --> + <ModifyPartition wcm:action="add"> + <Order>1</Order> + <PartitionID>1</PartitionID> + <Label>WINRE</Label> + <Format>NTFS</Format> + <TypeID>DE94BBA4-06D1-4D40-A16A-BFD50179D6AC</TypeID> + </ModifyPartition> + <!-- System partition (ESP) --> + <ModifyPartition wcm:action="add"> + <Order>2</Order> + <PartitionID>2</PartitionID> + <Label>System</Label> + <Format>FAT32</Format> + </ModifyPartition> + <!-- MSR partition does not need to be modified --> + <ModifyPartition wcm:action="add"> + <Order>3</Order> + <PartitionID>3</PartitionID> + </ModifyPartition> + <!-- Windows partition --> + <ModifyPartition wcm:action="add"> + <Order>4</Order> + <PartitionID>4</PartitionID> + <Label>Windows</Label> + <Letter>C</Letter> + <Format>NTFS</Format> + </ModifyPartition> + </ModifyPartitions> + </Disk> + </DiskConfiguration> + <DynamicUpdate> + <Enable>true</Enable> + <WillShowUI>Never</WillShowUI> + </DynamicUpdate> + <ImageInstall> + <OSImage> + <InstallTo> + <DiskID>0</DiskID> + <PartitionID>4</PartitionID> + </InstallTo> + <InstallToAvailablePartition>false</InstallToAvailablePartition> + </OSImage> + </ImageInstall> + <RunSynchronous> + <RunSynchronousCommand wcm:action="add"> + <Order>1</Order> + <Path>reg add HKLM\System\Setup\LabConfig /v BypassCPUCheck /t REG_DWORD /d 0x00000001 /f</Path> + </RunSynchronousCommand> + <RunSynchronousCommand wcm:action="add"> + <Order>2</Order> + <Path>reg add HKLM\System\Setup\LabConfig /v BypassRAMCheck /t REG_DWORD /d 0x00000001 /f</Path> + </RunSynchronousCommand> + <RunSynchronousCommand wcm:action="add"> + <Order>3</Order> + <Path>reg add HKLM\System\Setup\LabConfig /v BypassSecureBootCheck /t REG_DWORD /d 0x00000001 /f</Path> + </RunSynchronousCommand> + <RunSynchronousCommand wcm:action="add"> + <Order>4</Order> + <Path>reg add HKLM\System\Setup\LabConfig /v BypassTPMCheck /t REG_DWORD /d 0x00000001 /f</Path> + </RunSynchronousCommand> + </RunSynchronous> + <UpgradeData> + <Upgrade>false</Upgrade> + <WillShowUI>Never</WillShowUI> + </UpgradeData> + <UserData> + <AcceptEula>true</AcceptEula> + <FullName>Quickemu</FullName> + <Organization>Quickemu Project</Organization> + <!-- https://docs.microsoft.com/en-us/windows-server/get-started/kms-client-activation-keys --> + <ProductKey> + <Key>W269N-WFGWX-YVC9B-4J6C9-T83GX</Key> + <WillShowUI>Never</WillShowUI> + </ProductKey> + </UserData> + </component> + + <component name="Microsoft-Windows-PnpCustomizationsWinPE" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS" processorArchitecture="amd64" xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + <!-- + This makes the VirtIO drivers available to Windows, assuming that + the VirtIO driver disk is available as drive E: + https://github.com/virtio-win/virtio-win-pkg-scripts/blob/master/README.md + --> + <DriverPaths> + <PathAndCredentials wcm:action="add" wcm:keyValue="1"> + <Path>E:\qemufwcfg\w10\amd64</Path> + </PathAndCredentials> + <PathAndCredentials wcm:action="add" wcm:keyValue="2"> + <Path>E:\vioinput\w10\amd64</Path> + </PathAndCredentials> + <PathAndCredentials wcm:action="add" wcm:keyValue="3"> + <Path>E:\vioscsi\w10\amd64</Path> + </PathAndCredentials> + <PathAndCredentials wcm:action="add" wcm:keyValue="4"> + <Path>E:\viostor\w10\amd64</Path> + </PathAndCredentials> + <PathAndCredentials wcm:action="add" wcm:keyValue="5"> + <Path>E:\vioserial\w10\amd64</Path> + </PathAndCredentials> + <PathAndCredentials wcm:action="add" wcm:keyValue="6"> + <Path>E:\qxldod\w10\amd64</Path> + </PathAndCredentials> + <PathAndCredentials wcm:action="add" wcm:keyValue="7"> + <Path>E:\amd64\w10</Path> + </PathAndCredentials> + <PathAndCredentials wcm:action="add" wcm:keyValue="8"> + <Path>E:\viogpudo\w10\amd64</Path> + </PathAndCredentials> + <PathAndCredentials wcm:action="add" wcm:keyValue="9"> + <Path>E:\viorng\w10\amd64</Path> + </PathAndCredentials> + <PathAndCredentials wcm:action="add" wcm:keyValue="10"> + <Path>E:\NetKVM\w10\amd64</Path> + </PathAndCredentials> + <PathAndCredentials wcm:action="add" wcm:keyValue="11"> + <Path>E:\viofs\w10\amd64</Path> + </PathAndCredentials> + <PathAndCredentials wcm:action="add" wcm:keyValue="12"> + <Path>E:\Balloon\w10\amd64</Path> + </PathAndCredentials> + </DriverPaths> + </component> + </settings> + + <settings pass="oobeSystem"> + <component name="Microsoft-Windows-Shell-Setup" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS" xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + <AutoLogon> + <Password> + <Value>quickemu</Value> + <PlainText>true</PlainText> + </Password> + <Enabled>true</Enabled> + <Username>Quickemu</Username> + </AutoLogon> + <DisableAutoDaylightTimeSet>false</DisableAutoDaylightTimeSet> + <OOBE> + <HideEULAPage>true</HideEULAPage> + <HideLocalAccountScreen>true</HideLocalAccountScreen> + <HideOEMRegistrationScreen>true</HideOEMRegistrationScreen> + <HideOnlineAccountScreens>true</HideOnlineAccountScreens> + <HideWirelessSetupInOOBE>true</HideWirelessSetupInOOBE> + <NetworkLocation>Home</NetworkLocation> + <ProtectYourPC>3</ProtectYourPC> + <SkipUserOOBE>true</SkipUserOOBE> + <SkipMachineOOBE>true</SkipMachineOOBE> + <VMModeOptimizations> + <SkipWinREInitialization>true</SkipWinREInitialization> + </VMModeOptimizations> + </OOBE> + <UserAccounts> + <LocalAccounts> + <LocalAccount wcm:action="add"> + <Password> + <Value>quickemu</Value> + <PlainText>true</PlainText> + </Password> + <Description>Quickemu</Description> + <DisplayName>Quickemu</DisplayName> + <Group>Administrators</Group> + <Name>Quickemu</Name> + </LocalAccount> + </LocalAccounts> + </UserAccounts> + <RegisteredOrganization>Quickemu Project</RegisteredOrganization> + <RegisteredOwner>Quickemu</RegisteredOwner> + <FirstLogonCommands> + <SynchronousCommand wcm:action="add"> + <CommandLine>msiexec /i E:\guest-agent\qemu-ga-x86_64.msi /quiet /passive /qn</CommandLine> + <Description>Install Virtio Guest Agent</Description> + <Order>1</Order> + </SynchronousCommand> + <SynchronousCommand wcm:action="add"> + <CommandLine>msiexec /i F:\spice-webdavd-x64-latest.msi /quiet /passive /qn</CommandLine> + <Description>Install spice-webdavd file sharing agent</Description> + <Order>2</Order> + </SynchronousCommand> + <SynchronousCommand wcm:action="add"> + <CommandLine>msiexec /i F:\UsbDk_1.0.22_x64.msi /quiet /passive /qn</CommandLine> + <Description>Install usbdk USB sharing agent</Description> + <Order>3</Order> + </SynchronousCommand> + <SynchronousCommand wcm:action="add"> + <CommandLine>msiexec /i F:\spice-vdagent-x64-0.10.0.msi /quiet /passive /qn</CommandLine> + <Description>Install spice-vdagent SPICE agent</Description> + <Order>4</Order> + </SynchronousCommand> + <SynchronousCommand wcm:action="add"> + <CommandLine>Cmd /c POWERCFG -H OFF</CommandLine> + <Description>Disable Hibernation</Description> + <Order>5</Order> + </SynchronousCommand> + </FirstLogonCommands> + </component> + </settings> +</unattend> +EOF + + +echo "Downloading Spice drivers..." +web_get https://www.spice-space.org/download/windows/spice-webdavd/spice-webdavd-x64-latest.msi "${VM_PATH}/unattended" +web_get https://www.spice-space.org/download/windows/vdagent/vdagent-win-0.10.0/spice-vdagent-x64-0.10.0.msi "${VM_PATH}/unattended" +web_get https://www.spice-space.org/download/windows/usbdk/UsbDk_1.0.22_x64.msi "${VM_PATH}/unattended" + +echo "Making unattended.iso" +mkisofs -quiet -l -o "${VM_PATH}/unattended.iso" "${VM_PATH}/unattended/" +} + +function handle_curl_error() { + local error_code="$1" + local fatal_error_action=2 + case "$error_code" in + 6) + echo "Failed to resolve Microsoft servers! Is there an Internet connection? Exiting..." + return "$fatal_error_action" + ;; + 7) + echo "Failed to contact Microsoft servers! Is there an Internet connection or is the server down?" + ;; + 8) + echo "Microsoft servers returned a malformed HTTP response!" + ;; + 22) + echo "Microsoft servers returned a failing HTTP status code!" + ;; + 23) + echo "Failed at writing Windows media to disk! Out of disk space or permission error? Exiting..." + return "$fatal_error_action" + ;; + 26) + echo "Ran out of memory during download! Exiting..." + return "$fatal_error_action" + ;; + 36) + echo "Failed to continue earlier download!" + ;; + 63) + echo "Microsoft servers returned an unexpectedly large response!" + ;; + # POSIX defines exit statuses 1-125 as usable by us + # https://pubs.opengroup.org/onlinepubs/9699919799/utilities/V3_chap02.html#tag_18_08_02 + $((error_code <= 125))) + # Must be some other server or network error (possibly with this specific request/file) + # This is when accounting for all possible errors in the curl manual assuming a correctly formed curl command and an HTTP(S) request, using only the curl features we're using, and a sane build + echo "Miscellaneous server or network error!" + ;; + 126 | 127 ) + echo "Curl command not found! Please install curl and try again. Exiting..." + return "$fatal_error_action" + ;; + # Exit statuses are undefined by POSIX beyond this point + *) + case "$(kill -l "$error_code")" in + # Signals defined to exist by POSIX: + # https://pubs.opengroup.org/onlinepubs/009695399/basedefs/signal.h.html + INT) + echo "Curl was interrupted!" + ;; + # There could be other signals but these are most common + SEGV | ABRT ) + echo "Curl crashed! Failed exploitation attempt? Please report any core dumps to curl developers. Exiting..." + return "$fatal_error_action" + ;; + *) + echo "Curl terminated due to a fatal signal!" + ;; + esac + esac + return 1 +} + +function download_windows_server() { + local iso_download_page_html="" + # Copyright (C) 2024 Elliot Killick <contact@elliotkillick.com> + # This function is adapted from the Mido project: + # https://github.com/ElliotKillick/Mido + + # Download enterprise evaluation Windows versions + local windows_version="$1" + local enterprise_type="$2" + local PRETTY_RELEASE="" + + case "${RELEASE}" in + *) PRETTY_RELEASE="${RELEASE}";; + esac + + echo "Downloading $(pretty_name "${OS}") ${PRETTY_RELEASE} (${I18N})" + + local url="https://www.microsoft.com/en-us/evalcenter/download-$windows_version" + + echo " - Parsing download page: ${url}" + iso_download_page_html="$(curl --disable --silent --location --max-filesize 1M --fail --proto =https --tlsv1.2 --http1.1 -- "$url")" || { + handle_curl_error $? + return $? + } + + if ! [ "$iso_download_page_html" ]; then + # This should only happen if there's been some change to where this download page is located + echo " - Windows server download page gave us an empty response" + return 1 + fi + + local CULTURE="" + local COUNTRY="" + case "${I18N}" in + "English (Great Britain)") + CULTURE="en-gb" + COUNTRY="GB";; + "Chinese (Simplified)") + CULTURE="zh-cn" + COUNTRY="CN";; + "Chinese (Traditional)") + CULTURE="zh-tw" + COUNTRY="TW";; + "French") + CULTURE="fr-fr" + COUNTRY="FR";; + "German") + CULTURE="de-de" + COUNTRY="DE";; + "Italian") + CULTURE="it-it" + COUNTRY="IT";; + "Japanese") + CULTURE="ja-jp" + COUNTRY="JP";; + "Korean") + CULTURE="ko-kr" + COUNTRY="KR";; + "Portuguese (Brazil)") + CULTURE="pt-br" + COUNTRY="BR";; + "Spanish") + CULTURE="es-es" + COUNTRY="ES";; + "Russian") + CULTURE="ru-ru" + COUNTRY="RU";; + *) + CULTURE="en-us" + COUNTRY="US";; + esac + + echo " - Getting download link.." + iso_download_links="$(echo "$iso_download_page_html" | grep -o "https://go.microsoft.com/fwlink/p/?LinkID=[0-9]\+&clcid=0x[0-9a-z]\+&culture=${CULTURE}&country=${COUNTRY}")" || { + # This should only happen if there's been some change to the download endpoint web address + echo " - Windows server download page gave us no download link" + return 1 + } + + # Limit untrusted size for input validation + iso_download_links="$(echo "$iso_download_links" | head -c 1024)" + + case "$enterprise_type" in + # Select x64 download link + "enterprise") iso_download_link=$(echo "$iso_download_links" | head -n 2 | tail -n 1) ;; + # Select x64 LTSC download link + "ltsc") iso_download_link=$(echo "$iso_download_links" | head -n 4 | tail -n 1) ;; + *) iso_download_link="$iso_download_links" ;; + esac + + # Follow redirect so proceeding log message is useful + # This is a request we make this Fido doesn't + # We don't need to set "--max-filesize" here because this is a HEAD request and the output is to /dev/null anyway + iso_download_link="$(curl --disable --silent --location --output /dev/null --silent --write-out "%{url_effective}" --head --fail --proto =https --tlsv1.2 --http1.1 -- "$iso_download_link")" || { + # This should only happen if the Microsoft servers are down + handle_curl_error $? + return $? + } + + # Limit untrusted size for input validation + iso_download_link="$(echo "$iso_download_link" | head -c 1024)" + + echo " - URL: $iso_download_link" + + # Download ISO + FILE_NAME="${iso_download_link##*/}" + web_get "${iso_download_link}" "${VM_PATH}" "${FILE_NAME}" + OS="windows-server" +} + +function download_windows_workstation() { + local HASH="" + local session_id="" + local iso_download_page_html="" + local product_edition_id="" + local language_skuid_table_json="" + local sku_id="" + local iso_download_link_json="" + local iso_download_link="" + + echo "Downloading Windows ${RELEASE} (${I18N})" + # This function is adapted from the Mido project: + # https://github.com/ElliotKillick/Mido + # Download newer consumer Windows versions from behind gated Microsoft API + + # Either 10, or 11 + local windows_version="$1" + + local url="https://www.microsoft.com/en-us/software-download/windows$windows_version" + case "$windows_version" in + 10) url="${url}ISO";; + esac + + local user_agent="Mozilla/5.0 (X11; Linux x86_64; rv:100.0) Gecko/20100101 Firefox/100.0" + session_id="$(uuidgen)" + + # Get product edition ID for latest release of given Windows version + # Product edition ID: This specifies both the Windows release (e.g. 22H2) and edition ("multi-edition" is default, either Home/Pro/Edu/etc., we select "Pro" in the answer files) in one number + # This is the *only* request we make that Fido doesn't. Fido manually maintains a list of all the Windows release/edition product edition IDs in its script (see: $WindowsVersions array). This is helpful for downloading older releases (e.g. Windows 10 1909, 21H1, etc.) but we always want to get the newest release which is why we get this value dynamically + # Also, keeping a "$WindowsVersions" array like Fido does would be way too much of a maintenance burden + # Remove "Accept" header that curl sends by default + echo " - Parsing download page: ${url}" + iso_download_page_html="$(curl --disable --silent --user-agent "$user_agent" --header "Accept:" --max-filesize 1M --fail --proto =https --tlsv1.2 --http1.1 -- "$url")" || { + handle_curl_error $? + return $? + } + + echo -n " - Getting Product edition ID: " + # tr: Filter for only numerics to prevent HTTP parameter injection + # head -c was recently added to POSIX: https://austingroupbugs.net/view.php?id=407 + product_edition_id="$(echo "$iso_download_page_html" | grep -Eo '<option value="[0-9]+">Windows' | cut -d '"' -f 2 | head -n 1 | tr -cd '0-9' | head -c 16)" + echo "$product_edition_id" + + echo " - Permit Session ID: $session_id" + # Permit Session ID + # "org_id" is always the same value + curl --disable --silent --output /dev/null --user-agent "$user_agent" --header "Accept:" --max-filesize 100K --fail --proto =https --tlsv1.2 --http1.1 -- "https://vlscppe.microsoft.com/tags?org_id=y6jn8c31&session_id=$session_id" || { + # This should only happen if there's been some change to how this API works + handle_curl_error $? + return $? + } + + local profile="606624d44113" + + echo -n " - Getting language SKU ID: " + # Get language -> skuID association table + language_skuid_table_json="$(curl --disable -s --fail --max-filesize 100K --proto =https --tlsv1.2 --http1.1 "https://www.microsoft.com/software-download-connector/api/getskuinformationbyproductedition?profile=${profile}&ProductEditionId=${product_edition_id}&SKU=undefined&friendlyFileName=undefined&Locale=en-US&sessionID=${session_id}")" || { + handle_curl_error $? + return $? + } + + sku_id="$(echo "${language_skuid_table_json}" | jq -r '.Skus[] | select(.LocalizedLanguage=="'"${I18N}"'" or .Language=="'"${I18N}"'").Id')" + echo "$sku_id" + + echo " - Getting ISO download link..." + # Get ISO download link + # If any request is going to be blocked by Microsoft it's always this last one (the previous requests always seem to succeed) + # --referer: Required by Microsoft servers to allow request + iso_download_link_json="$(curl --disable -s --fail --referer "$url" "https://www.microsoft.com/software-download-connector/api/GetProductDownloadLinksBySku?profile=${profile}&productEditionId=undefined&SKU=${sku_id}&friendlyFileName=undefined&Locale=en-US&sessionID=${session_id}")" + + local failed=0 + + if ! [ "$iso_download_link_json" ]; then + # This should only happen if there's been some change to how this API works + echo " - Microsoft servers gave us an empty response to our request for an automated download." + failed=1 + fi + + if echo "$iso_download_link_json" | grep -q "Sentinel marked this request as rejected."; then + echo " - WARNING! Microsoft blocked the automated download request based on your IP address." + failed=1 + fi + + if [ ${failed} -eq 1 ]; then + echo " Manually download the Windows ${windows_version} ISO using a web browser from: ${url}" + echo " Save the downloaded ISO to: $(realpath "${VM_PATH}")" + echo " Update the config file to reference the downloaded ISO: ./${VM_PATH}.conf" + echo " Continuing with the VM creation process..." + return 1 + fi + + # Filter for 64-bit ISO download URL + iso_download_link="$(echo "${iso_download_link_json}" | jq -r '.ProductDownloadOptions[].Uri' | grep x64)" + + if ! [ "$iso_download_link" ]; then + # This should only happen if there's been some change to the download endpoint web address + echo " - Microsoft servers gave us no download link to our request for an automated download. Please manually download this ISO in a web browser: $url" + return 1 + fi + + echo " - URL: ${iso_download_link%%\?*}" + + # Download ISO + FILE_NAME="$(echo "$iso_download_link" | cut -d'?' -f1 | cut -d'/' -f5)" + web_get "${iso_download_link}" "${VM_PATH}" "${FILE_NAME}" +} + +function get_() { + if [ "${OS}" == "windows-server" ]; then + download_windows_server "windows-server-${RELEASE}" + else + download_windows_workstation "${RELEASE}" + fi + + if [ "${OPERATION}" == "download" ]; then + exit 0 + fi + + echo "Downloading VirtIO drivers..." + web_get "https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/stable-virtio/virtio-win.iso" "${VM_PATH}" + + rm -f "${VM_PATH}/unattended.iso" + case ${RELEASE} in + 10|11) + unattended_windows "${VM_PATH}" + ;; + esac + + if [ -n "${FILE_NAME}" ]; then + make_vm_config "${FILE_NAME}" "virtio-win.iso" + else + make_vm_config "windows-${RELEASE}.iso" "virtio-win.iso" + fi +} + diff --git a/public/zorin b/public/zorin index b046793..8b86fd3 100644 --- a/public/zorin +++ b/public/zorin @@ -5,5 +5,31 @@ BASEDOF="Ubuntu" DESCRIPTION="Alternative to Windows and macOS designed to make your computer faster, more powerful, secure, and privacy-respecting" HOMEPAGE="https://zorin.com/os" CREDENTIALS="-" + + RELEASES="17 16" EDITIONS="lite64 education64 core64" + +function releases_() { + echo 17 16 +} + +function editions_() { + echo core64 lite64 education64 +} + +function get_() { + local HASH="" + local ISO="" + local URL="" + # Process the URL redirections; required for Zorin + URL=$(web_redirect "https://zrn.co/${RELEASE}${EDITION}") + echo "${URL} ${HASH}" +} + +function specific_tweaks() { + case ${EDITION} in + education64|edulite64) echo "disk_size=\"32G\"" >> "${CONF_FILE}" + esac +} +