diff --git a/Dockerfile.debian b/Dockerfile.debian index 7ba075e..7c06e32 100644 --- a/Dockerfile.debian +++ b/Dockerfile.debian @@ -340,55 +340,45 @@ RUN \ && \ echo -# TODO: Deprecate neko and noVNC for KasmVNC +# TODO: Deprecate neko # 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 +# Install Web Frontend +ARG FRONTEND_VERSION=0a6ab20 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 \ + echo "**** Fetch Web Frontend ****" \ && 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 \ + && rm -rf /opt/frontend \ + && git clone https://github.com/Steam-Headless/frontend.git --branch master /opt/frontend \ + && cd /opt/frontend \ + && git checkout ${FRONTEND_VERSION} 2> /dev/null \ + && git submodule init \ + && git submodule update --depth 1 --recursive \ + && rm -rf /opt/frontend/.git \ && \ - echo "**** Modify noVNC title ****" \ - && sed -i '/ document.title =/c\ document.title = "Steam Headless - noVNC";' \ - /opt/noVNC/app/ui.js \ + echo "**** Configure Web Frontend ****" \ + && echo '' > /opt/frontend/index.html \ + && echo '
If you are not redirected, click here.
' >> /opt/frontend/index.html \ + && chmod -R 755 /opt/frontend \ && \ + echo + +# Install Websockify +ARG WEBSOCKETIFY_VERSION=0.11.0 +RUN \ echo "**** Update apt database ****" \ && apt-get update \ && \ - echo "**** Install nginx support ****" \ + echo "**** Install Websockify dependencies ****" \ && apt-get install -y \ - nginx \ + python3-numpy \ + python3-requests \ + python3-jwcrypto \ + python3-redis \ && \ - 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 \ @@ -397,16 +387,15 @@ RUN \ && 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 ****" \ + echo "**** Install Websockify to Web Frontend path ****" \ && cd /tmp \ - && mv -v /tmp/websockify-${WEBSOCKETIFY_VERSION} /opt/noVNC/utils/websockify \ + && mv -v /tmp/websockify-${WEBSOCKETIFY_VERSION} /opt/frontend/utils/websockify \ && \ echo "**** Section cleanup ****" \ + && apt-get clean autoclean -y \ + && apt-get autoremove -y \ && rm -rf \ + /var/lib/apt/lists/* \ /tmp/websockify-* \ /tmp/websockify.tar.gz diff --git a/overlay/etc/cont-init.d/90-configure_vnc.sh b/overlay/etc/cont-init.d/90-configure_vnc.sh index 060c375..67007f9 100644 --- a/overlay/etc/cont-init.d/90-configure_vnc.sh +++ b/overlay/etc/cont-init.d/90-configure_vnc.sh @@ -15,15 +15,9 @@ function get_next_unused_port() { # Note: Ports 32035-32248 are unallocated port ranges. We should be able to find something in here that we can use # REF: https://www.iana.org/assignments/service-names-port-numbers/service-names-port-numbers.xhtml?&page=130 DYNAMIC_PORT_VNC=$(get_next_unused_port 32035) -DYNAMIC_PORT_NOVNC_SERVICE=$(get_next_unused_port ${DYNAMIC_PORT_VNC}) -DYNAMIC_PORT_AUDIO_WEBSOCKET=$(get_next_unused_port ${DYNAMIC_PORT_NOVNC_SERVICE}) -DYNAMIC_PORT_AUDIO_STREAM=$(get_next_unused_port ${DYNAMIC_PORT_AUDIO_WEBSOCKET}) export PORT_VNC=${PORT_VNC:-$DYNAMIC_PORT_VNC} echo "Configure VNC service port '${PORT_VNC}'" -export PORT_NOVNC_SERVICE=${PORT_NOVNC_SERVICE:-$DYNAMIC_PORT_NOVNC_SERVICE} -echo "Configure noVNC service port '${PORT_NOVNC_SERVICE}'" -export PORT_AUDIO_WEBSOCKET=${PORT_AUDIO_WEBSOCKET:-$DYNAMIC_PORT_AUDIO_WEBSOCKET} -echo "Configure audio websocket port '${PORT_AUDIO_WEBSOCKET}'" +DYNAMIC_PORT_AUDIO_STREAM=$(get_next_unused_port ${DYNAMIC_PORT_VNC}) export PORT_AUDIO_STREAM=${PORT_AUDIO_STREAM:-$DYNAMIC_PORT_AUDIO_STREAM} echo "Configure pulseaudio encoded stream port '${PORT_AUDIO_STREAM}'" @@ -32,38 +26,11 @@ if ([ "${MODE}" != "s" ] && [ "${MODE}" != "secondary" ]); then if [ "${WEB_UI_MODE:-}" = "vnc" ]; then echo "Enable VNC server" sed -i 's|^autostart.*=.*$|autostart=true|' /etc/supervisor.d/vnc.ini - - # Configure Nginx proxy for the websocket and VNC - cp -f /opt/noVNC/nginx.template.conf /opt/noVNC/nginx.conf - sed -i "s|