| # syntax=docker/dockerfile:1 | |
| FROM debian:trixie-slim | |
| ARG TARGETARCH | |
| ARG VERSION_ARG="0.0" | |
| ARG VERSION_VNC="1.6.0" | |
| ARG VERSION_UTK="1.2.0" | |
| ARG VERSION_PASST="2025_09_19" | |
| ARG DEBCONF_NOWARNINGS="yes" | |
| ARG DEBIAN_FRONTEND="noninteractive" | |
| ARG DEBCONF_NONINTERACTIVE_SEEN="true" | |
| RUN set -eu && \ | |
| apt-get update && \ | |
| apt-get --no-install-recommends -y install \ | |
| bc \ | |
| jq \ | |
| xxd \ | |
| tini \ | |
| wget \ | |
| 7zip \ | |
| curl \ | |
| ovmf \ | |
| fdisk \ | |
| nginx \ | |
| swtpm \ | |
| procps \ | |
| ethtool \ | |
| iptables \ | |
| iproute2 \ | |
| dnsmasq \ | |
| xz-utils \ | |
| apt-utils \ | |
| net-tools \ | |
| e2fsprogs \ | |
| qemu-utils \ | |
| websocketd \ | |
| iputils-ping \ | |
| genisoimage \ | |
| inotify-tools \ | |
| netcat-openbsd \ | |
| ca-certificates \ | |
| qemu-system-x86 && \ | |
| wget "https://github.com/qemus/passt/releases/download/v${VERSION_PASST}/passt_${VERSION_PASST}_${TARGETARCH}.deb" -O /tmp/passt.deb -q && \ | |
| dpkg -i /tmp/passt.deb && \ | |
| apt-get clean && \ | |
| mkdir -p /etc/qemu && \ | |
| echo "allow br0" > /etc/qemu/bridge.conf && \ | |
| mkdir -p /usr/share/novnc && \ | |
| wget "https://github.com/novnc/noVNC/archive/refs/heads/master.tar.gz" -O /tmp/novnc.tar.gz -q --timeout=10 && \ | |
| tar -xf /tmp/novnc.tar.gz -C /tmp/ && \ | |
| cd "/tmp/noVNC-master" && \ | |
| mv app core vendor package.json ./*.html /usr/share/novnc && \ | |
| unlink /etc/nginx/sites-enabled/default && \ | |
| sed -i 's/^worker_processes.*/worker_processes 1;/' /etc/nginx/nginx.conf && \ | |
| echo "$VERSION_ARG" > /run/version && \ | |
| rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/* | |
| RUN set -eu && \ | |
| # Ensure runtime directories exist and are writable by unprivileged users | |
| mkdir -p /run /run/shm /storage && \ | |
| # /run/shm should be a sticky tmpfs-like directory | |
| chmod 1777 /run/shm && \ | |
| chmod 0777 /storage || true && \ | |
| # Prepare nginx config slot so non-root users (e.g. UID 1000 in Spaces) | |
| # can write runtime site configs without permission errors. | |
| mkdir -p /etc/nginx/sites-enabled && \ | |
| chmod 0777 /etc/nginx/sites-enabled || true && \ | |
| # Ensure nginx runtime dirs are writable for unprivileged users | |
| mkdir -p /var/lib/nginx/body /var/log/nginx /var/cache/nginx /var/run && \ | |
| # Prefer setting ownership to the unprivileged UID 1000 used by Spaces; | |
| # if that fails (image built elsewhere), fall back to world-writable modes. | |
| chown -R 1000:1000 /var/lib/nginx /var/log/nginx /var/cache/nginx /var/run 2>/dev/null || \ | |
| chmod -R 0777 /var/lib/nginx /var/log/nginx /var/cache/nginx /var/run || true && \ | |
| mkdir -p /run/shm && touch /run/shm/websocketd.log && chown 1000:1000 /run/shm/websocketd.log 2>/dev/null || \ | |
| chmod 0666 /run/shm/websocketd.log || true && \ | |
| # Ensure nginx can create/open its pid file when running non-root | |
| touch /run/nginx.pid && chown 1000:1000 /run/nginx.pid 2>/dev/null || \ | |
| chmod 0666 /run/nginx.pid || true | |
| COPY --chmod=755 ./src /run/ | |
| COPY --chmod=755 ./web /var/www/ | |
| COPY --chmod=664 ./web/conf/defaults.json /usr/share/novnc | |
| COPY --chmod=664 ./web/conf/mandatory.json /usr/share/novnc | |
| COPY --chmod=744 ./web/conf/nginx.conf /etc/nginx/default.conf | |
| ADD --chmod=755 "https://github.com/qemus/fiano/releases/download/v${VERSION_UTK}/utk_${VERSION_UTK}_${TARGETARCH}.bin" /run/utk.bin | |
| VOLUME /storage | |
| EXPOSE 22 5900 8006 | |
| ENV BOOT="alpine" | |
| ENV CPU_CORES="2" | |
| ENV RAM_SIZE="2G" | |
| ENV DISK_SIZE="64G" | |
| ENTRYPOINT ["/usr/bin/tini", "-s", "/run/entry.sh"] | |