From c4ce6af0a07a0ef041fcfd09125cc0557894722d Mon Sep 17 00:00:00 2001 From: nbd Date: Fri, 2 Mar 2007 15:48:29 +0000 Subject: add support for static routes - based on the patch from #1365 git-svn-id: svn://svn.openwrt.org/openwrt/trunk@6457 3c298f89-4303-0410-b956-a3cf2f4a3e73 --- package/base-files/files/etc/functions.sh | 5 ++- .../base-files/files/etc/hotplug.d/iface/10-routes | 40 ++++++++++++++++++++++ 2 files changed, 44 insertions(+), 1 deletion(-) create mode 100644 package/base-files/files/etc/hotplug.d/iface/10-routes (limited to 'package/base-files/files') diff --git a/package/base-files/files/etc/functions.sh b/package/base-files/files/etc/functions.sh index 931f4be47..1cb365d47 100755 --- a/package/base-files/files/etc/functions.sh +++ b/package/base-files/files/etc/functions.sh @@ -125,10 +125,13 @@ config_set() { config_foreach() { local function="$1" - local section + local type="$2" + local section cfgtype [ -z "$CONFIG_SECTIONS" ] && return 0 for section in ${CONFIG_SECTIONS}; do + config_get cfgtype "$section" TYPE + [ -n "$type" -a "$cfgtype" != "$type" ] && continue eval "$function \"\$section\"" done } diff --git a/package/base-files/files/etc/hotplug.d/iface/10-routes b/package/base-files/files/etc/hotplug.d/iface/10-routes new file mode 100644 index 000000000..4b55f8bb1 --- /dev/null +++ b/package/base-files/files/etc/hotplug.d/iface/10-routes @@ -0,0 +1,40 @@ +add_route() { + local config="$1" + + # is this route intended for the + # $INTERFACE of this hotplug event + config_get interface "$config" interface + [ "$interface" != "$INTERFACE" ] && return 0 + + # get the real interface name from network config + config_get dev "$interface" ifname + + config_get target "$config" target + config_get netmask "$config" netmask + config_get gateway "$config" gateway + config_get metric "$config" metric + + # make sure there is a gateway and a target + [ -n "$target" ] || { + echo "Missing target in route section $config" + return 1 + } + [ -n "$gateway" ] || { + echo "Missing gateway in route section $config" + return 1 + } + + netmask="${netmask:-255.255.255.255}" + dest="${netmask:+-net "$target" netmask "$netmask"}" + dest="${dest:--host "$target"}" + + /sbin/route add $dest gw "$gateway" ${dev:+dev "$dev"} ${metric:+ metric "$metric"} +} + +case "$ACTION" in + ifup) + include /lib/network + scan_interfaces + config_foreach "add_route" route + ;; +esac -- cgit v1.2.3