#!/bin/bash # Entrypoint: VNC setup + DNS fix + systemd # Setup VNC password from environment variable (passed by runtipi) if [ -n "$VNC_PASSWORD" ]; then mkdir -p /root/.vnc echo "$VNC_PASSWORD" | vncpasswd -f > /root/.vnc/passwd chmod 600 /root/.vnc/passwd fi # Backup current DNS config cp /etc/resolv.conf /tmp/resolv.conf.bak 2>/dev/null || true cp /etc/hosts /tmp/hosts.bak 2>/dev/null || true # Unmount Docker's bind mounts (allows VPN to modify DNS) umount /etc/resolv.conf 2>/dev/null || true umount /etc/hosts 2>/dev/null || true # Restore DNS config as regular files cat /tmp/resolv.conf.bak > /etc/resolv.conf 2>/dev/null || echo "nameserver 8.8.8.8" > /etc/resolv.conf cat /tmp/hosts.bak > /etc/hosts 2>/dev/null || echo "127.0.0.1 localhost" > /etc/hosts # Enable IP forwarding echo 1 > /proc/sys/net/ipv4/ip_forward echo "[entrypoint] IP forwarding enabled" # Ensure runtime directory exists (for host trigger files) mkdir -p /runtime echo "[entrypoint] Runtime directory ready" # Start systemd exec /sbin/init