FROM debian:bookworm-slim LABEL maintainer="Josh.5 " # Update package repos ARG DEBIAN_FRONTEND=noninteractive RUN \ echo "**** Update apt database ****" \ && sed -i '/^Components: main/ s/$/ contrib non-free/' /etc/apt/sources.list.d/debian.sources \ && \ echo # Update locale RUN \ echo "**** Update apt database ****" \ && apt-get update \ && \ echo "**** Install and configure locals ****" \ && apt-get install -y --no-install-recommends \ locales \ && echo 'en_US.UTF-8 UTF-8' > /etc/locale.gen \ && locale-gen \ && \ echo "**** Section cleanup ****" \ && apt-get clean autoclean -y \ && apt-get autoremove -y \ && rm -rf \ /var/lib/apt/lists/* \ /var/tmp/* \ /tmp/* \ && \ echo ENV \ LANG=en_US.UTF-8 \ LANGUAGE=en_US:en \ LC_ALL=en_US.UTF-8 # Re-install certificates RUN \ echo "**** Update apt database ****" \ && apt-get update \ && \ echo "**** Install certificates ****" \ && apt-get install -y --reinstall \ ca-certificates \ && \ echo "**** Section cleanup ****" \ && apt-get clean autoclean -y \ && apt-get autoremove -y \ && rm -rf \ /var/lib/apt/lists/* \ /var/tmp/* \ /tmp/* \ && \ echo # Install core packages RUN \ echo "**** Update apt database ****" \ && apt-get update \ && \ echo "**** Install tools ****" \ && apt-get install -y --no-install-recommends \ bash \ bash-completion \ curl \ git \ jq \ less \ man-db \ mlocate \ nano \ net-tools \ p7zip-full \ patch \ pciutils \ pkg-config \ procps \ psmisc \ psutils \ rsync \ screen \ sudo \ unzip \ vim \ wget \ xmlstarlet \ xz-utils \ && \ echo "**** Install python ****" \ && apt-get install -y --no-install-recommends \ python3 \ python3-numpy \ python3-pip \ python3-setuptools \ && \ echo "**** Section cleanup ****" \ && apt-get clean autoclean -y \ && apt-get autoremove -y \ && rm -rf \ /var/lib/apt/lists/* \ /var/tmp/* \ /tmp/* \ && \ echo # Configure default user and set user env ENV \ PUID=99 \ PGID=100 \ UMASK=000 \ USER="default" \ USER_PASSWORD="password" \ USER_HOME="/home/default" \ TZ="Pacific/Auckland" \ USER_LOCALES="en_US.UTF-8 UTF-8" RUN \ echo "**** Configure default user '${USER}' ****" \ && mkdir -p \ ${USER_HOME} \ && useradd -d ${USER_HOME} -s /bin/bash ${USER} \ && chown -R ${USER} \ ${USER_HOME} \ && echo "${USER} ALL=(ALL) NOPASSWD: ALL" >> /etc/sudoers \ && \ echo # Install supervisor RUN \ echo "**** Update apt database ****" \ && apt-get update \ && \ echo "**** Install supervisor ****" \ && apt-get install -y \ supervisor \ && \ echo "**** Section cleanup ****" \ && apt-get clean autoclean -y \ && apt-get autoremove -y \ && rm -rf \ /var/lib/apt/lists/* \ /var/tmp/* \ /tmp/* \ && \ echo # Install mesa and vulkan requirements # TODO: Strip this section back to only what is required for all GPU types. # Anything only required for Intel/AMD/NVIDIA should go in the container init. RUN \ echo "**** Update apt database ****" \ && dpkg --add-architecture i386 \ && apt-get update \ && \ echo "**** Install mesa requirements ****" \ && apt-get install -y --no-install-recommends \ libgl1-mesa-dri \ libgl1-mesa-glx \ libgles2-mesa \ libglu1-mesa \ mesa-utils \ mesa-utils-extra \ && \ echo "**** Install vulkan requirements ****" \ && apt-get install -y --no-install-recommends \ libvulkan1 \ libvulkan1:i386 \ mesa-vulkan-drivers \ mesa-vulkan-drivers:i386 \ vulkan-tools \ && \ echo "**** Install desktop requirements ****" \ && apt-get install -y --no-install-recommends \ libdbus-1-3 \ libegl1 \ libgtk-3-0 \ libgtk2.0-0 \ libsdl2-2.0-0 \ && \ echo "**** Section cleanup ****" \ && apt-get clean autoclean -y \ && apt-get autoremove -y \ && rm -rf \ /var/lib/apt/lists/* \ /var/tmp/* \ /tmp/* \ && \ echo # Install X Server requirements # TODO: Refine this list of packages to only what is required. ENV \ XORG_SOCKET_DIR="/tmp/.X11-unix" \ XDG_RUNTIME_DIR="/tmp/.X11-unix/run" \ XDG_SESSION_TYPE="x11" RUN \ echo "**** Update apt database ****" \ && apt-get update \ && \ echo "**** Install X Server requirements ****" \ && apt-get install -y --no-install-recommends \ avahi-utils \ dbus-x11 \ libxcomposite-dev \ libxcursor1 \ wmctrl \ libfuse2 \ x11-utils \ x11-xfs-utils \ x11-xkb-utils \ x11-xserver-utils \ x11vnc \ xauth \ xbindkeys \ xclip \ xcvt \ xdotool \ xfishtank \ xfonts-base \ xinit \ xorg \ xserver-xorg-core \ xserver-xorg-input-evdev \ xserver-xorg-input-libinput \ xserver-xorg-legacy \ xserver-xorg-video-all \ xserver-xorg-video-dummy \ && \ echo "**** Section cleanup ****" \ && apt-get clean autoclean -y \ && apt-get autoremove -y \ && rm -rf \ /var/lib/apt/lists/* \ /var/tmp/* \ /tmp/* \ && \ echo # Install audio requirements ENV \ PULSE_SOCKET_DIR="/tmp/pulse" \ PULSE_SERVER="unix:/tmp/pulse/pulse-socket" RUN \ echo "**** Update apt database ****" \ && apt-get update \ && \ echo "**** Install X Server requirements ****" \ && apt-get install -y --no-install-recommends \ pulseaudio \ alsa-utils \ libasound2 \ libasound2-plugins \ && \ echo "**** Section cleanup ****" \ && apt-get clean autoclean -y \ && apt-get autoremove -y \ && rm -rf \ /var/lib/apt/lists/* \ /var/tmp/* \ /tmp/* \ && \ echo # Install desktop environment # TODO: Specify all needed packages and add '--no-install-recommends' RUN \ echo "**** Update apt database ****" \ && apt-get update \ && \ echo "**** Install desktop environment ****" \ && apt-get install -y \ fonts-vlgothic \ gedit \ imagemagick \ msttcorefonts \ xdg-utils \ xfce4 \ xfce4-terminal \ # Delete these as they are not needed at all && rm -f \ /usr/share/applications/software-properties-drivers.desktop \ /usr/share/applications/xfce4-about.desktop \ /usr/share/applications/xfce4-session-logout.desktop \ # Hide these apps. They can be displayed if a user really wants them. && sed -i '/[Desktop Entry]/a\NoDisplay=true' /usr/share/applications/xfce4-accessibility-settings.desktop \ && sed -i '/[Desktop Entry]/a\NoDisplay=true' /usr/share/applications/xfce4-color-settings.desktop \ && sed -i '/[Desktop Entry]/a\NoDisplay=true' /usr/share/applications/xfce4-mail-reader.desktop \ && sed -i '/[Desktop Entry]/a\NoDisplay=true' /usr/share/applications/xfce4-web-browser.desktop \ && sed -i '/[Desktop Entry]/a\NoDisplay=true' /usr/share/applications/vim.desktop \ && sed -i '/[Desktop Entry]/a\NoDisplay=true' /usr/share/applications/thunar-settings.desktop \ && sed -i '/[Desktop Entry]/a\NoDisplay=true' /usr/share/applications/thunar.desktop \ && sed -i '/[Desktop Entry]/a\NoDisplay=true' /usr/share/applications/pavucontrol.desktop \ && sed -i '/[Desktop Entry]/a\NoDisplay=true' /usr/share/applications/x11vnc.desktop \ && sed -i '/[Desktop Entry]/a\NoDisplay=true' /usr/share/applications/display-im6.q16.desktop \ # These are named specifically for Debain && sed -i '/[Desktop Entry]/a\NoDisplay=true' /usr/share/applications/debian-xterm.desktop \ && sed -i '/[Desktop Entry]/a\NoDisplay=true' /usr/share/applications/debian-uxterm.desktop \ # Force these apps to be "System" Apps rather than "Categories=System;Utility;Core;GTK;Filesystem;" && sed -i 's/^Categories=.*$/Categories=System;/' /usr/share/applications/xfce4-appfinder.desktop \ && sed -i 's/^Categories=.*$/Categories=System;/' /usr/share/applications/thunar-bulk-rename.desktop \ && sed -i 's/^Categories=.*$/Categories=System;/' /usr/share/applications/org.gnome.gedit.desktop \ && \ echo "**** Install WoL Manager requirements ****" \ && apt-get install -y \ tcpdump \ xprintidle \ && \ echo "**** Section cleanup ****" \ && apt-get clean autoclean -y \ && apt-get autoremove -y \ && rm -rf \ /var/lib/apt/lists/* \ /var/tmp/* \ /tmp/* \ && \ echo # Add support for flatpaks ENV \ XDG_DATA_DIRS="/home/default/.local/share/flatpak/exports/share:/var/lib/flatpak/exports/share:/usr/local/share/:/usr/share/" RUN \ echo "**** Update apt database ****" \ && apt-get update \ && \ echo "**** Install flatpak support ****" \ && apt-get install -y --no-install-recommends \ flatpak \ gnome-software-plugin-flatpak \ && \ echo "**** Configure flatpak ****" \ && flatpak remote-add flathub https://flathub.org/repo/flathub.flatpakrepo \ && dpkg-statoverride --update --add root root 0755 /usr/bin/bwrap \ && \ echo "**** Section cleanup ****" \ && apt-get clean autoclean -y \ && apt-get autoremove -y \ && rm -rf \ /var/lib/apt/lists/* \ /var/tmp/* \ /tmp/* \ && \ echo # TODO: Deprecate neko and noVNC for KasmVNC # Install Neko server COPY --from=m1k1o/neko:base /usr/bin/neko /usr/bin/neko COPY --from=m1k1o/neko:base /var/www /var/www # Install noVNC ARG NOVNC_VERSION=1.2.0 RUN \ echo "**** Fetch noVNC ****" \ && cd /tmp \ && wget -O /tmp/novnc.tar.gz https://github.com/novnc/noVNC/archive/v${NOVNC_VERSION}.tar.gz \ && \ echo "**** Extract noVNC ****" \ && cd /tmp \ && tar -xvf /tmp/novnc.tar.gz \ && \ echo "**** Configure noVNC ****" \ && cd /tmp/noVNC-${NOVNC_VERSION} \ && sed -i 's/credentials: { password: password } });/credentials: { password: password },\n wsProtocols: ["'"binary"'"] });/g' app/ui.js \ && mkdir -p /opt \ && rm -rf /opt/noVNC \ && cd /opt \ && mv -f /tmp/noVNC-${NOVNC_VERSION} /opt/noVNC \ && cd /opt/noVNC \ && ln -s vnc.html index.html \ && chmod -R 755 /opt/noVNC \ && \ echo "**** Modify noVNC title ****" \ && sed -i '/ document.title =/c\ document.title = "Steam Headless - noVNC";' \ /opt/noVNC/app/ui.js \ && \ echo "**** Update apt database ****" \ && apt-get update \ && \ echo "**** Install nginx support ****" \ && apt-get install -y \ nginx \ && \ echo "**** Section cleanup ****" \ && apt-get clean autoclean -y \ && apt-get autoremove -y \ && rm -rf \ /var/lib/apt/lists/* \ /tmp/noVNC* \ /tmp/novnc.tar.gz # Install Websockify ARG WEBSOCKETIFY_VERSION=0.10.0 RUN \ echo "**** Fetch Websockify ****" \ && cd /tmp \ && wget -O /tmp/websockify.tar.gz https://github.com/novnc/websockify/archive/v${WEBSOCKETIFY_VERSION}.tar.gz \ && \ echo "**** Extract Websockify ****" \ && cd /tmp \ && tar -xvf /tmp/websockify.tar.gz \ && \ echo "**** Install Websockify to main ****" \ && cd /tmp/websockify-${WEBSOCKETIFY_VERSION} \ && python3 ./setup.py install \ && \ echo "**** Install Websockify to noVNC path ****" \ && cd /tmp \ && mv -v /tmp/websockify-${WEBSOCKETIFY_VERSION} /opt/noVNC/utils/websockify \ && \ echo "**** Section cleanup ****" \ && rm -rf \ /tmp/websockify-* \ /tmp/websockify.tar.gz # Setup audio streaming deps RUN \ echo "**** Update apt database ****" \ && apt-get update \ && \ echo "**** Install audio streaming deps ****" \ && apt-get install -y --no-install-recommends \ bzip2 \ gstreamer1.0-alsa \ gstreamer1.0-gl \ gstreamer1.0-gtk3 \ gstreamer1.0-libav \ gstreamer1.0-plugins-bad \ gstreamer1.0-plugins-base \ gstreamer1.0-plugins-good \ gstreamer1.0-plugins-ugly \ gstreamer1.0-pulseaudio \ gstreamer1.0-qt5 \ gstreamer1.0-tools \ gstreamer1.0-vaapi \ gstreamer1.0-x \ libgstreamer1.0-0 \ libncursesw5 \ libopenal1 \ libsdl-image1.2 \ libsdl-ttf2.0-0 \ libsdl1.2debian \ libsndfile1 \ ucspi-tcp \ && \ echo "**** Section cleanup ****" \ && apt-get clean autoclean -y \ && apt-get autoremove -y \ && rm -rf \ /var/lib/apt/lists/* \ /var/tmp/* \ /tmp/* \ && \ echo # Setup video streaming deps RUN \ echo "**** Update apt database ****" \ && apt-get update \ && \ echo "**** Install Intel media drivers and VAAPI ****" \ && apt-get install -y --no-install-recommends \ intel-media-va-driver-non-free \ i965-va-driver-shaders \ libva2 \ && \ echo "**** Section cleanup ****" \ && apt-get clean autoclean -y \ && apt-get autoremove -y \ && rm -rf \ /var/lib/apt/lists/* \ /var/tmp/* \ /tmp/* \ && \ echo # Install tools for monitoring hardware RUN \ echo "**** Update apt database ****" \ && apt-get update \ && \ echo "**** Install useful HW monitoring tools ****" \ && apt-get install -y --no-install-recommends \ cpu-x \ htop \ vainfo \ vdpauinfo \ && \ echo "**** Section cleanup ****" \ && apt-get clean autoclean -y \ && apt-get autoremove -y \ && rm -rf \ /var/lib/apt/lists/* \ /var/tmp/* \ /tmp/* \ && \ echo # Install Sunshine COPY --from=lizardbyte/sunshine:b00d7af-debian-bookworm /sunshine.deb /usr/src/sunshine.deb RUN \ echo "**** Update apt database ****" \ && apt-get update \ && \ echo "**** Install Sunshine requirements ****" \ && apt-get install -y \ va-driver-all \ && \ echo "**** Install Sunshine ****" \ && apt-get install -y \ /usr/src/sunshine.deb \ && \ echo "**** Section cleanup ****" \ && apt-get clean autoclean -y \ && apt-get autoremove -y \ && rm -rf \ /var/lib/apt/lists/* \ /var/tmp/* \ /tmp/* \ && \ echo # Install Steam RUN \ echo "**** Update apt database ****" \ && apt-get update \ && \ echo "**** Install Steam ****" \ && apt-get install -y --no-install-recommends \ steam \ && ln -sf /usr/games/steam /usr/bin/steam \ && \ echo "**** Section cleanup ****" \ && apt-get clean autoclean -y \ && apt-get autoremove -y \ && rm -rf \ /var/lib/apt/lists/* \ /var/tmp/* \ /tmp/* \ && \ echo # Various other tools ARG DUMB_INIT_VERSION=1.2.5 RUN \ echo "**** Install dumb-init ****" \ && wget --no-check-certificate --no-cookies --quiet \ -O /usr/bin/dumb-init \ https://github.com/Yelp/dumb-init/releases/download/v${DUMB_INIT_VERSION}/dumb-init_${DUMB_INIT_VERSION}_x86_64 \ && chmod +x /usr/bin/dumb-init \ && \ echo # Add FS overlay COPY overlay / # Set display environment variables ENV \ DISPLAY_CDEPTH="24" \ DISPLAY_REFRESH="120" \ DISPLAY_SIZEH="900" \ DISPLAY_SIZEW="1600" \ DISPLAY_VIDEO_PORT="DFP" \ DISPLAY=":55" ENV \ NVIDIA_DRIVER_CAPABILITIES="all" \ NVIDIA_VISIBLE_DEVICES="all" # Set container configuration environment variables ENV \ MODE="primary" \ WEB_UI_MODE="vnc" \ ENABLE_VNC_AUDIO="true" \ NEKO_PASSWORD=neko \ NEKO_PASSWORD_ADMIN=admin \ ENABLE_STEAM="true" \ STEAM_ARGS="-silent" \ ENABLE_SUNSHINE="true" \ ENABLE_EVDEV_INPUTS="false" \ ENABLE_WOL_POWER_MANAGER="false" # Configure required ports ENV \ PORT_NOVNC_WEB="8083" \ NEKO_NAT1TO1="" # Expose the required ports EXPOSE 8083 # Set entrypoint RUN chmod +x /entrypoint.sh ENTRYPOINT ["/entrypoint.sh"]