mirror of
git://projects.qi-hardware.com/openwrt-xburst.git
synced 2025-01-12 01:00:16 +02:00
relayd: use an init script instead of a legacy network proto handler (fixes #11276)
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@31542 3c298f89-4303-0410-b956-a3cf2f4a3e73
This commit is contained in:
parent
e51f7c5d1b
commit
5bae60a024
@ -35,8 +35,8 @@ define Package/relayd/install
|
|||||||
$(INSTALL_BIN) $(PKG_BUILD_DIR)/relayd $(1)/usr/sbin/relayd
|
$(INSTALL_BIN) $(PKG_BUILD_DIR)/relayd $(1)/usr/sbin/relayd
|
||||||
$(INSTALL_DIR) $(1)/etc/hotplug.d/iface
|
$(INSTALL_DIR) $(1)/etc/hotplug.d/iface
|
||||||
$(INSTALL_DATA) ./files/relay.hotplug $(1)/etc/hotplug.d/iface/30-relay
|
$(INSTALL_DATA) ./files/relay.hotplug $(1)/etc/hotplug.d/iface/30-relay
|
||||||
$(INSTALL_DIR) $(1)/lib/network
|
$(INSTALL_DIR) $(1)/etc/init.d
|
||||||
$(INSTALL_DATA) ./files/relay.sh $(1)/lib/network/relay.sh
|
$(INSTALL_BIN) ./files/relay.init $(1)/etc/init.d/relayd
|
||||||
endef
|
endef
|
||||||
|
|
||||||
$(eval $(call BuildPackage,relayd))
|
$(eval $(call BuildPackage,relayd))
|
||||||
|
@ -1,36 +1,2 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
/etc/init.d/relayd enabled && /etc/init.d/relayd start
|
||||||
# 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
|
|
||||||
|
|
||||||
|
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 New Issue
Block a user