summaryrefslogtreecommitdiffstats
path: root/package/6in4/files/6in4.hotplug
diff options
context:
space:
mode:
authorjow <jow@3c298f89-4303-0410-b956-a3cf2f4a3e73>2010-05-28 22:03:30 +0000
committerjow <jow@3c298f89-4303-0410-b956-a3cf2f4a3e73>2010-05-28 22:03:30 +0000
commit8c69d5f95c0721ffbe9d72e1f7187d60784a2cb9 (patch)
tree6c408919a9689baa494d4f0b0295682c9d30642b /package/6in4/files/6in4.hotplug
parent98e5d71d12ba3ef766b9c26c301fe0d781ddafae (diff)
[package] 6in4:
- support to automatically determine the local endpoint address from the current IPv4 default gateway - support updating the tunnel endpoint for he.net git-svn-id: svn://svn.openwrt.org/openwrt/trunk@21612 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/6in4/files/6in4.hotplug')
-rw-r--r--package/6in4/files/6in4.hotplug44
1 files changed, 44 insertions, 0 deletions
diff --git a/package/6in4/files/6in4.hotplug b/package/6in4/files/6in4.hotplug
new file mode 100644
index 000000000..0a196c25b
--- /dev/null
+++ b/package/6in4/files/6in4.hotplug
@@ -0,0 +1,44 @@
+#!/bin/sh
+
+if [ "$ACTION" = ifup ]; then
+ . /etc/functions.sh
+
+ include /lib/network
+ scan_interfaces
+
+ update_tunnel() {
+ local cfg="$1"
+
+ local proto
+ config_get proto "$cfg" proto
+ [ "$proto" = 6in4 ] || return 0
+
+ local wandev
+ config_get wandev "$cfg" wan_device
+ [ "$wandev" = "$DEVICE" ] || return 0
+
+ local oldip
+ local wanip=$(find_6in4_wanip "$wandev")
+ config_get oldip "$cfg" ipaddr
+
+ [ -n "$wanip" ] && [ "$oldip" != "$wanip" ] && {
+ local tunnelid
+ config_get tunnelid "$cfg" tunnelid
+
+ local username
+ config_get username "$cfg" username
+
+ local password
+ config_get password "$cfg" password
+
+ [ -n "$tunnelid" ] && [ -n "$username" ] && [ -n "$password" ] && {
+ password="$(echo -n "$password" | md5sum)"; password="${password%% *}"
+ uci_set_state network "$cfg" ipaddr "$wanip"
+
+ ( wget -qO/dev/null "http://ipv4.tunnelbroker.net/ipv4_end.php?ipv4b=AUTO&user_id=$username&pass=$password&tunnel_id=$tunnelid" && ifup "$cfg" )&
+ }
+ }
+ }
+
+ config_foreach update_tunnel interface
+fi