diff --git a/Dockerfile b/Dockerfile index 58b98d7..357ea4a 100644 --- a/Dockerfile +++ b/Dockerfile @@ -19,6 +19,7 @@ RUN apt-get update && apt-get -y upgrade && \ wget \ fdisk \ unzip \ + socat \ procps \ dnsmasq \ xz-utils \ diff --git a/run/network.sh b/run/network.sh index 4781009..000d870 100644 --- a/run/network.sh +++ b/run/network.sh @@ -228,24 +228,8 @@ if [[ "${DHCP}" == [Yy1]* ]]; then { pkill -f server.sh || true; } 2>/dev/null - SH_SCRIPT="/run/ipinfo.sh" - - { echo "#!/bin/bash" - echo "INFO=\$(curl -s -m 5 -S http://127.0.0.1:2210/read?command=10 2>/dev/null)" - echo "rest=\${INFO#*http_port}; rest=\${rest#*:}; rest=\${rest%%,*}; PORT=\${rest%%\\\"*}" - echo "rest=\${INFO#*eth0}; rest=\${rest#*ip}; rest=\${rest#*:}; rest=\${rest#*\\\"}; IP=\${rest%%\\\"*}" - echo "BODY=\"The location of DSM is http://\${IP}:\${PORT}\"" - echo "HTML=\"VirtualDSM

\$BODY

\"" - echo "LENGTH=\"\${#HTML}\"; RESPONSE=\"HTTP/1.1 200 OK\\nContent-Length: \${LENGTH}\\nConnection: close\\n\\n\$HTML\"" - echo "echo -e \"\$RESPONSE\"" - } > "$SH_SCRIPT" - - chmod +x "$SH_SCRIPT" - - /run/server.sh 80 "$SH_SCRIPT" & - /run/server.sh 5000 "$SH_SCRIPT" & + /run/server.sh 80 /run/ip.sh & + /run/server.sh 5000 /run/ip.sh & else diff --git a/run/server.sh b/run/server.sh index 26c7722..950c9a1 100644 --- a/run/server.sh +++ b/run/server.sh @@ -1,7 +1,7 @@ #!/usr/bin/env bash set -eu -TMP_FILE="" +TMP_FILE=$(mktemp -q /tmp/server.XXXXXX) stop() { trap - SIGINT EXIT @@ -13,17 +13,34 @@ trap 'stop' EXIT SIGINT SIGTERM SIGHUP if [[ "$2" == "/"* ]]; then - socat TCP4-LISTEN:"${1:-5000}",reuseaddr,fork,crlf SYSTEM:"$2" 2> /dev/null & wait $! + if [[ "$2" == "/run/ip.sh" ]]; then + + { echo "#!/bin/bash" + echo "INFO=\$(curl -s -m 5 -S http://127.0.0.1:2210/read?command=10 2>/dev/null)" + echo "rest=\${INFO#*http_port}; rest=\${rest#*:}; rest=\${rest%%,*}; PORT=\${rest%%\\\"*}" + echo "rest=\${INFO#*eth0}; rest=\${rest#*ip}; rest=\${rest#*:}; rest=\${rest#*\\\"}; IP=\${rest%%\\\"*}" + echo "BODY=\"The location of DSM is http://\${IP}:\${PORT}\"" + echo "HTML=\"VirtualDSM

\$BODY

\"" + echo "echo -e \"\HTTP/1.1 200 OK\\nContent-Length: \${#HTML}\\nConnection: close\\n\\n\$HTML\"" + } > "$TMP_FILE" + + else + + cp "$2" "$TMP_FILE" + + fi + + chmod +x "$TMP_FILE" + socat TCP4-LISTEN:"${1:-5000}",reuseaddr,fork,crlf SYSTEM:"$TMP_FILE" 2> /dev/null & wait $! else HTML="VirtualDSM

$2

" - LENGTH="${#HTML}" - TMP_FILE=$(mktemp -q /tmp/server.XXXXXX) - - echo -en "HTTP/1.1 200 OK\nContent-Length: ${LENGTH}\nConnection: close\n\n$HTML" > "$TMP_FILE" + echo -en "HTTP/1.1 200 OK\nContent-Length: ${#HTML}\nConnection: close\n\n$HTML" > "$TMP_FILE" socat TCP4-LISTEN:"${1:-5000}",reuseaddr,fork,crlf SYSTEM:"cat ${TMP_FILE}" 2> /dev/null & wait $! fi