From aa4ecf1ed00222c2c9473ade2da70936270eeab2 Mon Sep 17 00:00:00 2001 From: Kroese Date: Sat, 4 May 2024 19:39:48 +0200 Subject: [PATCH 1/5] Update disk.sh --- src/disk.sh | 1 - 1 file changed, 1 deletion(-) diff --git a/src/disk.sh b/src/disk.sh index d34c96d9..f0b29731 100644 --- a/src/disk.sh +++ b/src/disk.sh @@ -10,7 +10,6 @@ set -Eeuo pipefail : "${DISK_DISCARD:="on"}" # Controls whether unmap (TRIM) commands are passed to the host. : "${DISK_ROTATION:="1"}" # Rotation rate, set to 1 for SSD storage and increase for HDD -BOOT="$STORAGE/$BASE" [ ! -f "$BOOT" ] && BOOT="/dev/null" DISK_OPTS="-object iothread,id=io2" From 6719faf4a33a17191c86663db41987c8e5204660 Mon Sep 17 00:00:00 2001 From: Kroese Date: Sat, 4 May 2024 20:10:52 +0200 Subject: [PATCH 2/5] Update install.sh --- src/install.sh | 43 ++++++++++++++++++++++++------------------- 1 file changed, 24 insertions(+), 19 deletions(-) diff --git a/src/install.sh b/src/install.sh index ae36972d..8bbdfee9 100644 --- a/src/install.sh +++ b/src/install.sh @@ -3,36 +3,41 @@ set -Eeuo pipefail # Check if running with interactive TTY or redirected to docker log if [ -t 1 ]; then - PROGRESS="--progress=bar:noscroll" + progress="--progress=bar:noscroll" else - PROGRESS="--progress=dot:giga" + progress="--progress=dot:giga" fi -BASE=$(find "$STORAGE" -maxdepth 1 -type f -iname boot.iso -printf "%f\n" | head -n 1) -[ -z "$BASE" ] && BASE=$(find "$STORAGE" -maxdepth 1 -type f -iname boot.img -printf "%f\n" | head -n 1) +file="/boot.iso" && [ -f "$file" && -s "$file" ] && BOOT="$file" && return 0 +file="/boot.img" && [ -f "$file" && -s "$file" ] && BOOT="$file" && return 0 -[ -f "$STORAGE/$BASE" ] && return 0 +file=$(find "$STORAGE" -maxdepth 1 -type f -iname boot.iso -printf "%f\n" | head -n 1) +[ -z "$file" ] && file=$(find "$STORAGE" -maxdepth 1 -type f -iname boot.img -printf "%f\n" | head -n 1) +[ -n "$file" ] && file="$STORAGE/$file" +[ -f "$file" && -s "$file" ] && BOOT="$file" && return 0 if [ -z "$BOOT" ]; then error "No boot disk specified, set BOOT= to the URL of an ISO file." && exit 64 fi -BASE=$(basename "$BOOT") -[ -f "$STORAGE/$BASE" ] && return 0 +base=$(basename "$BOOT") +[ -n "$base" ] && file="$STORAGE/$base" +[ -f "$file" && -s "$file" ] && BOOT="$file" && return 0 -BASE=$(basename "${BOOT%%\?*}") -: "${BASE//+/ }"; printf -v BASE '%b' "${_//%/\\x}" -BASE=$(echo "$BASE" | sed -e 's/[^A-Za-z0-9._-]/_/g') -[ -f "$STORAGE/$BASE" ] && return 0 +base=$(basename "${BOOT%%\?*}") +: "${base//+/ }"; printf -v base '%b' "${_//%/\\x}" +base=$(echo "$base" | sed -e 's/[^A-Za-z0-9._-]/_/g') +[ -n "$base" ] && file="$STORAGE/$base" +[ -f "$file" && -s "$file" ] && BOOT="$file" && return 0 -TMP="$STORAGE/${BASE%.*}.tmp" +TMP="$STORAGE/${base%.*}.tmp" rm -f "$TMP" -MSG="Downloading $BASE..." -info "$MSG" && html "$MSG" +msg="Downloading $base..." +info "$msg" && html "$msg" -/run/progress.sh "$TMP" "" "Downloading $BASE ([P])..." & -{ wget "$BOOT" -O "$TMP" -q --timeout=10 --show-progress "$PROGRESS"; rc=$?; } || : +/run/progress.sh "$TMP" "" "Downloading $base ([P])..." & +{ wget "$BOOT" -O "$TMP" -q --timeout=10 --show-progress "$progress"; rc=$?; } || : fKill "progress.sh" @@ -41,12 +46,12 @@ fKill "progress.sh" html "Download finished successfully..." -SIZE=$(stat -c%s "$TMP") +size=$(stat -c%s "$TMP") -if ((SIZE<100000)); then +if ((size<100000)); then error "Invalid ISO file: Size is smaller than 100 KB" && exit 62 fi -mv -f "$TMP" "$STORAGE/$BASE" +mv -f "$TMP" "$file" return 0 From 7b9e9f63f418483871ee1518208fa230dd802959 Mon Sep 17 00:00:00 2001 From: Kroese Date: Sat, 4 May 2024 20:15:35 +0200 Subject: [PATCH 3/5] docs: Readme --- readme.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/readme.md b/readme.md index 0865037b..d065f598 100644 --- a/readme.md +++ b/readme.md @@ -90,7 +90,7 @@ docker run -it --rm --name qemu -e "BOOT=http://example.com/image.iso" -p 8006:8 ```yaml volumes: - - /home/user/example.iso:/storage/boot.iso + - /home/user/example.iso:/boot.iso ``` Replace the example path `/home/user/example.iso` with the filename of the desired ISO file. From 53bfcef991806703f77cc076d352b0c9bcfa0218 Mon Sep 17 00:00:00 2001 From: Kroese Date: Sat, 4 May 2024 20:18:07 +0200 Subject: [PATCH 4/5] fix: Shellcheck --- src/install.sh | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/src/install.sh b/src/install.sh index 8bbdfee9..098881ab 100644 --- a/src/install.sh +++ b/src/install.sh @@ -8,13 +8,13 @@ else progress="--progress=dot:giga" fi -file="/boot.iso" && [ -f "$file" && -s "$file" ] && BOOT="$file" && return 0 -file="/boot.img" && [ -f "$file" && -s "$file" ] && BOOT="$file" && return 0 +file="/boot.iso" && [ -f "$file" ] && [ -s "$file" ] && BOOT="$file" && return 0 +file="/boot.img" && [ -f "$file" ] && [ -s "$file" ] && BOOT="$file" && return 0 file=$(find "$STORAGE" -maxdepth 1 -type f -iname boot.iso -printf "%f\n" | head -n 1) [ -z "$file" ] && file=$(find "$STORAGE" -maxdepth 1 -type f -iname boot.img -printf "%f\n" | head -n 1) [ -n "$file" ] && file="$STORAGE/$file" -[ -f "$file" && -s "$file" ] && BOOT="$file" && return 0 +[ -f "$file" ] && [ -s "$file" ] && BOOT="$file" && return 0 if [ -z "$BOOT" ]; then error "No boot disk specified, set BOOT= to the URL of an ISO file." && exit 64 @@ -22,13 +22,13 @@ fi base=$(basename "$BOOT") [ -n "$base" ] && file="$STORAGE/$base" -[ -f "$file" && -s "$file" ] && BOOT="$file" && return 0 +[ -f "$file" ] && [ -s "$file" ] && BOOT="$file" && return 0 base=$(basename "${BOOT%%\?*}") : "${base//+/ }"; printf -v base '%b' "${_//%/\\x}" base=$(echo "$base" | sed -e 's/[^A-Za-z0-9._-]/_/g') [ -n "$base" ] && file="$STORAGE/$base" -[ -f "$file" && -s "$file" ] && BOOT="$file" && return 0 +[ -f "$file" ] && [ -s "$file" ] && BOOT="$file" && return 0 TMP="$STORAGE/${base%.*}.tmp" rm -f "$TMP" From c20db50be98133b8cef23f7dd3467ea94e4b8f6b Mon Sep 17 00:00:00 2001 From: Kroese Date: Sat, 4 May 2024 20:19:41 +0200 Subject: [PATCH 5/5] Update disk.sh --- src/disk.sh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/disk.sh b/src/disk.sh index f0b29731..b32abec8 100644 --- a/src/disk.sh +++ b/src/disk.sh @@ -10,7 +10,7 @@ set -Eeuo pipefail : "${DISK_DISCARD:="on"}" # Controls whether unmap (TRIM) commands are passed to the host. : "${DISK_ROTATION:="1"}" # Rotation rate, set to 1 for SSD storage and increase for HDD -[ ! -f "$BOOT" ] && BOOT="/dev/null" +[ ! -f "$BOOT" ] || [ ! -s "$BOOT" ] && BOOT="/dev/null" DISK_OPTS="-object iothread,id=io2" DISK_OPTS="$DISK_OPTS -drive id=cdrom0,media=cdrom,if=none,format=raw,readonly=on,file=$BOOT" @@ -23,7 +23,7 @@ else fi DRIVERS="$STORAGE/drivers.iso" -[ ! -f "$DRIVERS" ] && DRIVERS="/run/drivers.iso" +[ ! -f "$DRIVERS" ] || [ ! -s "$DRIVERS" ] && DRIVERS="/run/drivers.iso" if [ -f "$DRIVERS" ] && [[ "${MACHINE,,}" != "pc-q35-2"* ]]; then DISK_OPTS="$DISK_OPTS -drive id=cdrom1,media=cdrom,if=none,format=raw,readonly=on,file=$DRIVERS"