diff options
author | cyrus <cyrus@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2012-10-30 07:14:07 +0000 |
---|---|---|
committer | cyrus <cyrus@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2012-10-30 07:14:07 +0000 |
commit | d3309f03fc9e4375e9b45ff31cb0eb513718591a (patch) | |
tree | 3d0f7d15f7f6f63b274f333fffaf41dd3eb5774f /package/network/ipv6/6relayd/files | |
parent | 550a8ae8a930637a6585d5acc59e430a6f513f50 (diff) |
ipv6: add 6relayd (RD-, DHCPv6- & NDP-Proxy)
6relayd is an IPv6-tool that relays IPv6-management protocols like router
discovery, neighbor discovery and DHCPv6 so that clients on routed
(non-bridged) interfaces can use the public address prefix, DHCPv6 and
DNS-service of a master interface. This is useful to avoid NAT in chained
IPv6-routers.
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@34008 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/network/ipv6/6relayd/files')
-rw-r--r-- | package/network/ipv6/6relayd/files/6relayd.hotplug | 2 | ||||
-rw-r--r-- | package/network/ipv6/6relayd/files/6relayd.init | 90 |
2 files changed, 92 insertions, 0 deletions
diff --git a/package/network/ipv6/6relayd/files/6relayd.hotplug b/package/network/ipv6/6relayd/files/6relayd.hotplug new file mode 100644 index 0000000000..e29a34a09e --- /dev/null +++ b/package/network/ipv6/6relayd/files/6relayd.hotplug @@ -0,0 +1,2 @@ +#!/bin/sh +/etc/init.d/6relayd enabled && /etc/init.d/6relayd start diff --git a/package/network/ipv6/6relayd/files/6relayd.init b/package/network/ipv6/6relayd/files/6relayd.init new file mode 100644 index 0000000000..4bf5078410 --- /dev/null +++ b/package/network/ipv6/6relayd/files/6relayd.init @@ -0,0 +1,90 @@ +#!/bin/sh /etc/rc.common +# Copyright (c) 2011-2012 OpenWrt.org +START=80 + +resolve_ifname() { + grep -qs "^ *$1:" /proc/net/dev && { + append ifaces "$1" + } +} + +resolve_network() { + local ifn + fixup_interface "$1" + config_get ifn "$1" ifname + [ -z "$ifn" ] && return 1 + resolve_ifname "$ifn" +} + +start_6relayd() { + local cfg="$1" + + local args="-S" + local ifaces="" + + config_get proto "$cfg" proto + [[ "$proto" == 6relay ]] || return 0 + + SERVICE_DAEMONIZE=1 + SERVICE_WRITE_PID=1 + SERVICE_PID_FILE="/var/run/6relayd-$cfg.pid" + [ -f "$SERVICE_PID_FILE" ] && { + if grep -q 6relayd "/proc/$(cat $SERVICE_PID_FILE)/cmdline"; then + return 0 + else + rm -f "$SERVICE_PID_FILE" + fi + } + + local net networks + config_get networks "$cfg" network + for net in $networks; do + resolve_network "$net" || { + return 1 + } + done + + local ifn ifnames + config_get ifnames "$cfg" ifname + for ifn in $ifnames; do + resolve_ifname "$ifn" + done + + local forward_rd # = 1 + config_get_bool forward_rd "$cfg" forward_rd 1 + [ $forward_rd -eq 1 ] && append args "-R" + + local forward_dhcpv6 # = 1 + local forward_dhcpv6_mode # = relay + config_get_bool forward_dhcpv6 "$cfg" forward_dhcpv6 1 + config_get forward_dhcpv6_mode "$cfg" forward_dhcpv6_mode + [ $forward_dhcpv6 -eq 1 ] && append args "-D$forward_dhcpv6_mode" + + local forward_ndp # = 1 + config_get_bool forward_ndp "$cfg" forward_ndp 1 + [ $forward_ndp -eq 1 ] && append args "-N" + + local configure_routes # = 1 + config_get_bool configure_routes "$cfg" configure_routes 1 + [ $configure_routes -eq 1 ] && append args "-r" + + local always_rewrite_dns # = 0 + config_get_bool always_rewrite_dns "$cfg" always_rewrite_dns 0 + [ $always_rewrite_dns -eq 1 ] && append args "-n" + + service_start /usr/sbin/6relayd $args $ifaces +} + +stop() { + for pid in /var/run/6relayd-*.pid; do + SERVICE_PID_FILE="$pid" + service_stop /usr/sbin/6relayd + rm -f "$SERVICE_PID_FILE" + done +} + +start() { + include /lib/network + config_load network + config_foreach start_6relayd interface +} |