[OpenWrt-Devel] [PATCH] [package] 6in4: https support for he.net tunnel api

Andrew Skalski askalski at gmail.com
Tue Oct 21 15:26:06 EDT 2014


HE.net tunnel update API requests are now made via https if an
SSL-capable wget is installed.  Certificate validation is conditionally
enabled if the CA certs are available.

Signed-off-by: Andrew Skalski <askalski at gmail.com>
---
diff --git a/package/network/ipv6/6in4/files/6in4.sh
b/package/network/ipv6/6in4/files/6in4.sh
index 714d629..7ffd40d 100755
--- a/package/network/ipv6/6in4/files/6in4.sh
+++ b/package/network/ipv6/6in4/files/6in4.sh
@@ -66,12 +66,21 @@ proto_6in4_setup() {
     [ -n "$tunnelid" -a -n "$username" -a \( -n "$password" -o -n
"$updatekey" \) ] && {
         [ -n "$updatekey" ] && password="$updatekey"

-        local url="http://ipv4.tunnelbroker.net/nic/update?username=$username&password=$password&hostname=$tunnelid"
+        local http="http"
+        local wget_opts="-qO/dev/null"
+        if wget --version | grep -qF "+https"; then
+            http="https"
+            [ -z "$(find ${SSL_CERT_DIR-/etc/ssl/certs} -name "*.0"
2>/dev/null)" ] && {
+                wget_opts="$wget_opts --no-check-certificate"
+            }
+        fi
+
+        local url="$http://ipv4.tunnelbroker.net/nic/update?username=$username&password=$password&hostname=$tunnelid"
         local try=0
         local max=3

         while [ $((++try)) -le $max ]; do
-            ( exec wget -qO/dev/null "$url" 2>/dev/null ) &
+            ( exec wget $wget_opts "$url" 2>/dev/null ) &
             local pid=$!
             ( sleep 5; kill $pid 2>/dev/null ) &
             wait $pid && break
_______________________________________________
openwrt-devel mailing list
openwrt-devel at lists.openwrt.org
https://lists.openwrt.org/cgi-bin/mailman/listinfo/openwrt-devel



More information about the openwrt-devel mailing list