summaryrefslogtreecommitdiffstats
path: root/package/6in4/files
diff options
context:
space:
mode:
authorjow <jow@3c298f89-4303-0410-b956-a3cf2f4a3e73>2012-06-17 12:18:39 +0000
committerjow <jow@3c298f89-4303-0410-b956-a3cf2f4a3e73>2012-06-17 12:18:39 +0000
commita17b7b615d1034d66ac86a9080c121868f95b3d4 (patch)
tree2bb097f285f92681e045239a73e41ae1c599b53d /package/6in4/files
parentf6a09e69e9cb12ed7b4d06584def1a379bf610ea (diff)
[package] 6in4: use network_find_wan() and network_get_iapddr() to find local ip, use json_get_vars() to read settings
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@32400 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/6in4/files')
-rwxr-xr-xpackage/6in4/files/6in4.sh49
1 files changed, 9 insertions, 40 deletions
diff --git a/package/6in4/files/6in4.sh b/package/6in4/files/6in4.sh
index dd438601f..4341465fe 100755
--- a/package/6in4/files/6in4.sh
+++ b/package/6in4/files/6in4.sh
@@ -1,23 +1,14 @@
#!/bin/sh
# 6in4.sh - IPv6-in-IPv4 tunnel backend
-# Copyright (c) 2010 OpenWrt.org
+# Copyright (c) 2010-2012 OpenWrt.org
[ -n "$INCLUDE_ONLY" ] || {
. /lib/functions.sh
+ . /lib/functions/network.sh
. ../netifd-proto.sh
init_proto "$@"
}
-find_6in4_wanif() {
- local if=$(ip -4 r l e 0.0.0.0/0); if="${if#default* dev }"; if="${if%% *}"
- [ -n "$if" ] && grep -qs "^ *$if:" /proc/net/dev && echo "$if"
-}
-
-find_6in4_wanip() {
- local ip=$(ip -4 a s dev "$1"); ip="${ip#*inet }"
- echo "${ip%%[^0-9.]*}"
-}
-
tun_error() {
local cfg="$1"; shift;
@@ -30,42 +21,20 @@ proto_6in4_setup() {
local iface="$2"
local link="6in4-$cfg"
- json_get_var mtu mtu
- json_get_var ttl ttl
- json_get_var local4 ipaddr
- json_get_var remote4 peeraddr
- json_get_var ip6addr ip6addr
- json_get_var tunnelid tunnelid
- json_get_var username username
- json_get_var password password
+ local mtu ttl local4 peeraddr ip6addr tunnelid username password
+ json_get_vars mtu ttl local4 peeraddr ip6addr tunnelid username password
- [ -z "$ip6addr" -o -z "$remote4" ] && {
+ [ -z "$ip6addr" -o -z "$peeraddr" ] && {
tun_error "$cfg" "MISSING_ADDRESS"
return
}
[ -z "$local4" ] && {
- local wanif=$(find_6in4_wanif)
- [ -z "$wanif" ] && {
- tun_error "$cfg" "NO_WAN_LINK"
- return
- }
-
- . /lib/network/config.sh
- local wancfg="$(find_config "$wanif")"
- [ -z "$wancfg" ] && {
+ local wanif
+ if ! network_find_wan wanif || ! network_get_ipaddr local4 "$wanif"; then
tun_error "$cfg" "NO_WAN_LINK"
return
- }
-
- # If local4 is unset, guess local IPv4 address from the
- # interface used by the default route.
- [ -n "$wanif" ] && local4=$(find_6in4_wanip "$wanif")
-
- [ -z "$local4" ] && {
- tun_error "$cfg" "NO_WAN_LINK"
- return
- }
+ fi
}
local local6="${ip6addr%%/*}"
@@ -81,7 +50,7 @@ proto_6in4_setup() {
json_add_int mtu "${mtu:-1280}"
json_add_int ttl "${ttl:-64}"
json_add_string local "$local4"
- json_add_string remote "$remote4"
+ json_add_string remote "$peeraddr"
proto_close_tunnel
proto_send_update "$cfg"