feat: Windows 11 support (#6)
This commit is contained in:
parent
748bf5f4e7
commit
131fa1379b
|
@ -8,17 +8,23 @@ RUN apt-get update \
|
||||||
&& apt-get --no-install-recommends -y install \
|
&& apt-get --no-install-recommends -y install \
|
||||||
curl \
|
curl \
|
||||||
novnc \
|
novnc \
|
||||||
|
swtpm \
|
||||||
|
p7zip-full \
|
||||||
|
genisoimage \
|
||||||
&& apt-get clean \
|
&& apt-get clean \
|
||||||
&& rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
|
&& rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
|
||||||
|
|
||||||
COPY ./src /run/
|
COPY ./src /run/
|
||||||
|
|
||||||
ADD https://raw.githubusercontent.com/ElliotKillick/Mido/main/Mido.sh /run/mido.sh
|
ADD https://raw.githubusercontent.com/ElliotKillick/Mido/main/Mido.sh /run/mido.sh
|
||||||
|
ADD https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/stable-virtio/virtio-win.iso /run/drivers.iso
|
||||||
|
|
||||||
RUN chmod +x /run/*.sh
|
RUN chmod +x /run/*.sh
|
||||||
|
|
||||||
EXPOSE 8006
|
EXPOSE 8006
|
||||||
VOLUME /storage
|
VOLUME /storage
|
||||||
|
|
||||||
ENV CPU_CORES "1"
|
ENV CPU_CORES "2"
|
||||||
ENV RAM_SIZE "4G"
|
ENV RAM_SIZE "4G"
|
||||||
ENV DISK_SIZE "64G"
|
ENV DISK_SIZE "64G"
|
||||||
|
|
||||||
|
|
|
@ -24,6 +24,9 @@ if [[ "${DISPLAY,,}" == "web" ]]; then
|
||||||
websockify -D --web /usr/share/novnc/ 8006 localhost:5900 2>/dev/null
|
websockify -D --web /usr/share/novnc/ 8006 localhost:5900 2>/dev/null
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
mkdir -p /tmp/emulated_tpm
|
||||||
|
swtpm socket -t -d --tpmstate dir=/tmp/emulated_tpm --ctrl type=unixio,path=/tmp/emulated_tpm/swtpm-sock --log level=1 --tpm2
|
||||||
|
|
||||||
info "Booting Windows using $VERS..."
|
info "Booting Windows using $VERS..."
|
||||||
|
|
||||||
[[ "$DEBUG" == [Yy1]* ]] && set -x
|
[[ "$DEBUG" == [Yy1]* ]] && set -x
|
||||||
|
|
|
@ -1,7 +1,10 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -Eeuo pipefail
|
set -Eeuo pipefail
|
||||||
|
|
||||||
: "${VERSION:="win10x64"}"
|
: "${VERSION:="win11x64"}"
|
||||||
|
|
||||||
|
ARGUMENTS="-chardev socket,id=chrtpm,path=/tmp/emulated_tpm/swtpm-sock $ARGUMENTS"
|
||||||
|
ARGUMENTS="-tpmdev emulator,id=tpm0,chardev=chrtpm -device tpm-tis,tpmdev=tpm0 $ARGUMENTS"
|
||||||
|
|
||||||
BASE="$VERSION.iso"
|
BASE="$VERSION.iso"
|
||||||
[ -f "$STORAGE/$BASE" ] && return 0
|
[ -f "$STORAGE/$BASE" ] && return 0
|
||||||
|
@ -13,28 +16,30 @@ else
|
||||||
PROGRESS="--progress=dot:giga"
|
PROGRESS="--progress=dot:giga"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
SCRIPT="$STORAGE/mido.sh"
|
DEST="$STORAGE/drivers.img"
|
||||||
|
[ ! -f "$DEST" ] && cp /run/drivers.iso $DEST
|
||||||
|
|
||||||
|
rm -rf "$STORAGE/tmp"
|
||||||
|
mkdir -p "$STORAGE/tmp"
|
||||||
|
SCRIPT="$STORAGE/tmp/mido.sh"
|
||||||
|
|
||||||
rm -f "$SCRIPT"
|
|
||||||
cp /run/mido.sh "$SCRIPT"
|
cp /run/mido.sh "$SCRIPT"
|
||||||
chmod +x "$SCRIPT"
|
chmod +x "$SCRIPT"
|
||||||
|
|
||||||
|
cd "$STORAGE/tmp"
|
||||||
bash "$SCRIPT" "$VERSION"
|
bash "$SCRIPT" "$VERSION"
|
||||||
rm -f "$SCRIPT"
|
rm -f "$SCRIPT"
|
||||||
|
|
||||||
[ ! -f "$STORAGE/$BASE" ] && error "Failed to download $VERSION.iso!" && exit 66
|
[ ! -f "$STORAGE/tmp/$BASE" ] && error "Failed to download $VERSION.iso from the Microsoft servers!" && exit 66
|
||||||
|
|
||||||
DEST="$STORAGE/drivers.img"
|
info "Modifying ISO to remove keypress requirement during boot..."
|
||||||
|
|
||||||
if [ ! -f "$DEST" ]; then
|
7z x "$BASE" -ounpack
|
||||||
|
genisoimage -b boot/etfsboot.com -no-emul-boot -c BOOT.CAT -iso-level 4 -J -l -D -N -joliet-long -relaxed-filenames -v -V "Custom" -udf -boot-info-table -eltorito-alt-boot -eltorito-boot efi/microsoft/boot/efisys_noprompt.bin -no-emul-boot -o "$STORAGE/tmp/$BASE.tmp" -allow-limited-size unpack
|
||||||
|
|
||||||
info "Downloading VirtIO drivers for Windows..."
|
mv "$STORAGE/tmp/$BASE.tmp" "$STORAGE/$BASE"
|
||||||
DRIVERS="https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/stable-virtio/virtio-win.iso"
|
rm -rf "$STORAGE/tmp"
|
||||||
|
|
||||||
{ wget "$DRIVERS" -O "$DEST" -q --no-check-certificate --show-progress "$PROGRESS"; rc=$?; } || :
|
cd /run
|
||||||
|
|
||||||
(( rc != 0 )) && info "Failed to download $DRIVERS, reason: $rc" && rm -f "$DEST"
|
|
||||||
|
|
||||||
fi
|
|
||||||
|
|
||||||
return 0
|
return 0
|
||||||
|
|
Loading…
Reference in New Issue