relayd: use an init script instead of a legacy network proto handler (fixes #11276)
SVN-Revision: 31542
This commit is contained in:
parent
cbfce53831
commit
8a790d9730
4 changed files with 100 additions and 137 deletions
|
@ -35,8 +35,8 @@ define Package/relayd/install
|
|||
$(INSTALL_BIN) $(PKG_BUILD_DIR)/relayd $(1)/usr/sbin/relayd
|
||||
$(INSTALL_DIR) $(1)/etc/hotplug.d/iface
|
||||
$(INSTALL_DATA) ./files/relay.hotplug $(1)/etc/hotplug.d/iface/30-relay
|
||||
$(INSTALL_DIR) $(1)/lib/network
|
||||
$(INSTALL_DATA) ./files/relay.sh $(1)/lib/network/relay.sh
|
||||
$(INSTALL_DIR) $(1)/etc/init.d
|
||||
$(INSTALL_BIN) ./files/relay.init $(1)/etc/init.d/relayd
|
||||
endef
|
||||
|
||||
$(eval $(call BuildPackage,relayd))
|
||||
|
|
|
@ -1,36 +1,2 @@
|
|||
#!/bin/sh
|
||||
|
||||
# Break recursion
|
||||
[ "$PROTO" = "relay" ] && exit 0
|
||||
|
||||
include /lib/network
|
||||
scan_interfaces
|
||||
|
||||
restart_relayd() {
|
||||
local cfg="$1"
|
||||
|
||||
local proto
|
||||
config_get proto "$1" proto
|
||||
[ "$proto" = "relay" ] || return 0
|
||||
|
||||
local net networks
|
||||
config_get networks "$cfg" network
|
||||
for net in $networks; do
|
||||
[ "$net" = "$INTERFACE" ] && {
|
||||
env -i /sbin/ifup "$cfg" &
|
||||
return 0
|
||||
}
|
||||
done
|
||||
|
||||
local ifn ifnames
|
||||
config_get ifnames "$cfg" ifname
|
||||
for ifn in $ifnames; do
|
||||
[ "$ifn" = "$DEVICE" ] && {
|
||||
env -i /sbin/ifup "$cfg" &
|
||||
return 0
|
||||
}
|
||||
done
|
||||
}
|
||||
|
||||
config_foreach restart_relayd interface
|
||||
|
||||
/etc/init.d/relayd enabled && /etc/init.d/relayd start
|
||||
|
|
97
package/relayd/files/relay.init
Normal file
97
package/relayd/files/relay.init
Normal file
|
@ -0,0 +1,97 @@
|
|||
#!/bin/sh /etc/rc.common
|
||||
# Copyright (c) 2011-2012 OpenWrt.org
|
||||
START=80
|
||||
|
||||
resolve_ifname() {
|
||||
grep -qs "^ *$1:" /proc/net/dev && {
|
||||
append args "-I $1"
|
||||
append ifaces "$1"
|
||||
}
|
||||
}
|
||||
|
||||
resolve_network() {
|
||||
local ifn
|
||||
config_get ifn "$1" ifname
|
||||
[ -z "$ifn" ] && return 1
|
||||
resolve_ifname "$ifn"
|
||||
return 0
|
||||
}
|
||||
|
||||
start_relay() {
|
||||
local cfg="$1"
|
||||
|
||||
local args=""
|
||||
local ifaces=""
|
||||
|
||||
config_get proto "$cfg" proto
|
||||
[[ "$proto" == relay ]] || return 0
|
||||
|
||||
SERVICE_DAEMONIZE=1
|
||||
SERVICE_WRITE_PID=1
|
||||
SERVICE_PID_FILE="/var/run/relay-$cfg.pid"
|
||||
[ -f "$SERVICE_PID_FILE" ] && {
|
||||
if grep -q relayd "/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 ipaddr
|
||||
config_get ipaddr "$cfg" ipaddr
|
||||
[ -n "$ipaddr" ] && append args "-L $ipaddr"
|
||||
|
||||
local gateway
|
||||
config_get gateway "$cfg" gateway
|
||||
[ -n "$gateway" ] && append args "-G $gateway"
|
||||
|
||||
local expiry # = 30
|
||||
config_get expiry "$cfg" expiry
|
||||
[ -n "$expiry" ] && append args "-t $expiry"
|
||||
|
||||
local retry # = 5
|
||||
config_get retry "$cfg" retry
|
||||
[ -n "$retry" ] && append args "-p $retry"
|
||||
|
||||
local table # = 16800
|
||||
config_get table "$cfg" table
|
||||
[ -n "$table" ] && append args "-T $table"
|
||||
|
||||
local fwd_bcast # = 1
|
||||
config_get_bool fwd_bcast "$cfg" forward_bcast 1
|
||||
[ $fwd_bcast -eq 1 ] && append args "-B"
|
||||
|
||||
local fwd_dhcp # = 1
|
||||
config_get_bool fwd_dhcp "$cfg" forward_dhcp 1
|
||||
[ $fwd_dhcp -eq 1 ] && append args "-D"
|
||||
|
||||
service_start /usr/sbin/relayd $args
|
||||
}
|
||||
|
||||
stop() {
|
||||
for pid in /var/run/relay-*.pid; do
|
||||
SERVICE_PID_FILE="$pid"
|
||||
service_stop /usr/sbin/relayd
|
||||
rm -f "$SERVICE_PID_FILE"
|
||||
done
|
||||
}
|
||||
|
||||
start() {
|
||||
include /lib/network
|
||||
scan_interfaces
|
||||
config_foreach start_relay interface
|
||||
}
|
|
@ -1,100 +0,0 @@
|
|||
# relay.sh - Abstract relayd protocol backend
|
||||
# Copyright (c) 2011 OpenWrt.org
|
||||
|
||||
# Hook into scan_interfaces() to synthesize a .device option
|
||||
# This is needed for /sbin/ifup to properly dispatch control
|
||||
# to setup_interface_relay() even if no .ifname is set in
|
||||
# the configuration.
|
||||
scan_relay() {
|
||||
config_set "$1" device "relay-$1"
|
||||
}
|
||||
|
||||
# No coldplugging needed, relayd will be restarted if one of
|
||||
# the member interfaces goes up or down
|
||||
#coldplug_interface_relay() {
|
||||
# setup_interface_relay "relay-$1" "$1"
|
||||
#}
|
||||
|
||||
setup_interface_relay() {
|
||||
local iface="$1"
|
||||
local cfg="$2"
|
||||
local link="relay-$cfg"
|
||||
|
||||
local args=""
|
||||
local ifaces=""
|
||||
|
||||
resolve_ifname() {
|
||||
grep -qs "^ *$1:" /proc/net/dev && {
|
||||
append args "-I $1"
|
||||
append ifaces "$1"
|
||||
}
|
||||
}
|
||||
|
||||
resolve_network() {
|
||||
local ifn
|
||||
config_get ifn "$1" ifname
|
||||
resolve_ifname "$ifn"
|
||||
}
|
||||
|
||||
local net networks
|
||||
config_get networks "$cfg" network
|
||||
for net in $networks; do
|
||||
resolve_network "$net"
|
||||
done
|
||||
|
||||
local ifn ifnames
|
||||
config_get ifnames "$cfg" ifname
|
||||
for ifn in $ifnames; do
|
||||
resolve_ifname "$ifn"
|
||||
done
|
||||
|
||||
local ipaddr
|
||||
config_get ipaddr "$cfg" ipaddr
|
||||
[ -n "$ipaddr" ] && append args "-L $ipaddr"
|
||||
|
||||
local gateway
|
||||
config_get gateway "$cfg" gateway
|
||||
[ -n "$gateway" ] && append args "-G $gateway"
|
||||
|
||||
local expiry # = 30
|
||||
config_get expiry "$cfg" expiry
|
||||
[ -n "$expiry" ] && append args "-t $expiry"
|
||||
|
||||
local retry # = 5
|
||||
config_get retry "$cfg" retry
|
||||
[ -n "$retry" ] && append args "-p $retry"
|
||||
|
||||
local table # = 16800
|
||||
config_get table "$cfg" table
|
||||
[ -n "$table" ] && append args "-T $table"
|
||||
|
||||
local fwd_bcast # = 1
|
||||
config_get_bool fwd_bcast "$cfg" forward_bcast 1
|
||||
[ $fwd_bcast -eq 1 ] && append args "-B"
|
||||
|
||||
local fwd_dhcp # = 1
|
||||
config_get_bool fwd_dhcp "$cfg" forward_dhcp 1
|
||||
[ $fwd_dhcp -eq 1 ] && append args "-D"
|
||||
|
||||
SERVICE_DAEMONIZE=1 \
|
||||
SERVICE_WRITE_PID=1 \
|
||||
SERVICE_PID_FILE="/var/run/$link.pid" \
|
||||
service_start /usr/sbin/relayd $args
|
||||
|
||||
uci_set_state network "$cfg" device "$ifaces"
|
||||
|
||||
env -i ACTION="ifup" DEVICE="$link" INTERFACE="$cfg" PROTO="relay" \
|
||||
/sbin/hotplug-call iface
|
||||
}
|
||||
|
||||
stop_interface_relay() {
|
||||
local cfg="$1"
|
||||
local link="relay-$cfg"
|
||||
|
||||
env -i ACTION="ifdown" DEVICE="$link" INTERFACE="$cfg" PROTO="relay" \
|
||||
/sbin/hotplug-call iface
|
||||
|
||||
SERVICE_PID_FILE="/var/run/$link.pid" \
|
||||
service_stop /usr/sbin/relayd
|
||||
}
|
||||
|
Loading…
Reference in a new issue