2006-12-05 06:24:30 +00:00
|
|
|
#!/bin/sh /etc/rc.common
|
|
|
|
START=95
|
2008-12-25 03:25:13 +00:00
|
|
|
|
2006-12-05 06:24:30 +00:00
|
|
|
start() {
|
2006-12-08 18:36:31 +00:00
|
|
|
config_load "upnpd"
|
2009-09-23 00:48:24 +00:00
|
|
|
local extiface intiface upload download logging secure
|
|
|
|
|
|
|
|
config_get extiface config external_iface
|
|
|
|
config_get intiface config internal_iface
|
2008-12-25 03:25:13 +00:00
|
|
|
config_get upload config upload
|
|
|
|
config_get download config download
|
|
|
|
config_get_bool logging config log_output 0
|
2009-01-25 14:59:25 +00:00
|
|
|
config_get_bool secure config secure_mode 0
|
2008-12-25 03:25:13 +00:00
|
|
|
|
2009-09-23 00:48:24 +00:00
|
|
|
include /lib/network
|
|
|
|
scan_interfaces
|
|
|
|
|
|
|
|
local ifname
|
|
|
|
config_get ifname ${extiface:-wan} ifname
|
2008-12-25 03:25:13 +00:00
|
|
|
|
2009-09-23 00:48:24 +00:00
|
|
|
if [ -n "$ifname" ]; then
|
|
|
|
local args="-i $ifname"
|
|
|
|
local iface
|
2008-12-25 03:25:13 +00:00
|
|
|
|
2009-09-23 00:48:24 +00:00
|
|
|
for iface in ${intiface:-lan}; do
|
2008-12-25 03:25:13 +00:00
|
|
|
local ipaddr
|
|
|
|
config_get ipaddr "$iface" ipaddr
|
|
|
|
[ -n "$ipaddr" ] && append args "-a $ipaddr"
|
|
|
|
done
|
|
|
|
|
|
|
|
append args "-p 5000 -U"
|
|
|
|
|
|
|
|
[ -n "$upload" -a -n "$download" ] && \
|
2009-01-14 23:18:45 +00:00
|
|
|
append args "-B $(($download * 1024 * 8)) $(($upload * 1024 * 8))"
|
2008-12-25 03:25:13 +00:00
|
|
|
|
2009-01-25 14:59:25 +00:00
|
|
|
[ "$secure" -gt 0 ] && \
|
|
|
|
append args "-S"
|
|
|
|
|
2008-12-25 03:25:13 +00:00
|
|
|
if [ "$logging" = "1" ]; then
|
|
|
|
eval start-stop-daemon -S -x miniupnpd -- $args -d | logger -t miniupnpd &
|
|
|
|
else
|
2008-12-25 03:46:04 +00:00
|
|
|
eval start-stop-daemon -S -x miniupnpd -- $args 2>/dev/null
|
2008-12-25 03:25:13 +00:00
|
|
|
fi
|
2009-09-23 00:48:24 +00:00
|
|
|
|
|
|
|
# start firewall
|
|
|
|
local zone
|
|
|
|
config_load firewall
|
|
|
|
config_get zone core "${extiface:-wan}_zone"
|
|
|
|
[ -n "$zone" ] && \
|
|
|
|
ACTION="add" ZONE="$zone" INTERFACE="${extiface:-wan}" DEVICE="$ifname" \
|
|
|
|
. /etc/hotplug.d/firewall/50-miniupnpd
|
2006-11-26 23:44:09 +00:00
|
|
|
else
|
2008-12-25 03:25:13 +00:00
|
|
|
logger -t "upnp daemon" "external interface not found, not starting"
|
2006-11-26 23:44:09 +00:00
|
|
|
fi
|
2006-12-05 06:24:30 +00:00
|
|
|
}
|
2006-12-08 18:36:31 +00:00
|
|
|
|
2009-09-23 00:48:24 +00:00
|
|
|
clear_rule() {
|
|
|
|
local state="$1"
|
|
|
|
local ifname ipaddr
|
|
|
|
|
|
|
|
config_get ifname "$state" ifname
|
|
|
|
config_get ipaddr "$state" ipaddr
|
|
|
|
|
|
|
|
[ -n "$ifname" ] && [ -n "$ipaddr" ] && {
|
|
|
|
iptables -t nat -D prerouting_rule -i $ifname -d $ipaddr -j MINIUPNPD
|
|
|
|
iptables -t filter -D forwarding_rule -i $ifname ! -o $ifname -j MINIUPNPD
|
|
|
|
uci_revert_state upnpd "$state"
|
|
|
|
unset "CONFIG_${state}_ifname"
|
|
|
|
unset "CONFIG_${state}_ipaddr"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2006-12-05 06:24:30 +00:00
|
|
|
stop() {
|
2008-12-25 03:25:13 +00:00
|
|
|
start-stop-daemon -K -q -x miniupnpd -p /var/run/miniupnpd.pid
|
2009-09-23 00:48:24 +00:00
|
|
|
rm -f /var/run/miniupnpd.pid
|
|
|
|
|
|
|
|
logger -t "upnp" "removing firewall rules"
|
|
|
|
|
|
|
|
config_load upnpd
|
|
|
|
config_foreach clear_rule firewall
|
|
|
|
|
|
|
|
iptables -t nat -F MINIUPNPD 2>/dev/null
|
|
|
|
iptables -t nat -X MINIUPNPD 2>/dev/null
|
|
|
|
iptables -t filter -F MINIUPNPD 2>/dev/null
|
|
|
|
iptables -t filter -X MINIUPNPD 2>/dev/null
|
2006-12-08 18:36:31 +00:00
|
|
|
}
|
2009-09-23 00:48:24 +00:00
|
|
|
|