openwrt/package/6in4/files/6in4.sh
2010-05-28 00:27:01 +00:00

80 lines
1.9 KiB
Bash
Executable File

# 6in4.sh - IPv6-in-IPv4 tunnel backend
# Copyright (c) 2010 OpenWrt.org
# Hook into scan_interfaces() to synthesize a .device option
# This is needed for /sbin/ifup to properly dispatch control
# to setup_interface_6in4() even if no .ifname is set in
# the configuration.
scan_6in4() {
config_set "$1" device "6in4-$1"
}
coldplug_interface_6in4() {
setup_interface_6in4 "6in4-$1" "$1"
}
setup_interface_6in4() {
local iface="$1"
local cfg="$2"
local link="6in4-$cfg"
local local4
config_get local4 "$cfg" ipaddr
local remote4
config_get remote4 "$cfg" peeraddr
local local6
config_get local6 "$cfg" ip6addr
local mtu
config_get mtu "$cfg" mtu
local ttl
config_get ttl "$cfg" ttl
local defaultroute
config_get_bool defaultroute "$cfg" defaultroute 1
# creating the tunnel below will trigger a net subsystem event
# prevent it from touching or iface by disabling .auto here
uci_set_state network "$cfg" ifname $link
uci_set_state network "$cfg" auto 0
ip tunnel add $link mode sit remote $remote4 local $local4 ttl 255
ip link set $link up
ip link set mtu ${mtu:-1280} dev $link
ip tunnel change $link ttl ${ttl:-64}
ip addr add $local6 dev $link
uci_set_state network "$cfg" ip6addr $local6
[ "$defaultroute" = 1 ] && {
ip -6 route add ::/0 dev $link
uci_set_state network "$cfg" defaultroute 1
}
env -i ACTION="ifup" INTERFACE="$cfg" DEVICE="$link" PROTO=6in4 /sbin/hotplug-call "iface" &
}
stop_interface_6in4() {
local cfg="$1"
local link="6in4-$cfg"
local local6=$(uci_get_state network "$cfg" ip6addr)
local defaultroute=$(uci_get_state network "$cfg" defaultroute)
grep -qs "^ *$link:" /proc/net/dev && {
env -i ACTION="ifdown" INTERFACE="$cfg" DEVICE="$link" PROTO=6in4 /sbin/hotplug-call "iface" &
[ "$defaultroute" = "1" ] && {
ip -6 route del ::/0 dev $link
}
ip addr del $local6 dev $link
ip link set $link down
ip tunnel del $link
}
}