diff options
author | Jo-Philipp Wich <jow@openwrt.org> | 2010-05-28 22:03:30 +0000 |
---|---|---|
committer | Jo-Philipp Wich <jow@openwrt.org> | 2010-05-28 22:03:30 +0000 |
commit | 68d5d01a4a375ec121dfd940b86208bd44d2f1ef (patch) | |
tree | 6c408919a9689baa494d4f0b0295682c9d30642b /package/6in4/files/6in4.hotplug | |
parent | e61aabfce64440f963ae660aaeb636e8411278b3 (diff) | |
download | upstream-68d5d01a4a375ec121dfd940b86208bd44d2f1ef.tar.gz upstream-68d5d01a4a375ec121dfd940b86208bd44d2f1ef.tar.bz2 upstream-68d5d01a4a375ec121dfd940b86208bd44d2f1ef.zip |
[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.hotplug | 44 |
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 0000000000..0a196c25b0 --- /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 |