miniupnpd: improve hotplug & interface handling
The existing interface selection/detection code was incomprehensible at worst and convoluted at best. The uci config file suggested it understood an external ipv6 interface but in reality the init script took no notice. Re-work it so it is at least comprehendible and takes notice of ipv6 interface details if specified. Update the hotplug script to use the same interface selection/detection code as the init script and take note of ipv6 interface selection, only restarting miniupnpd on interface up events and only if that interface isn't already known (for that ip class) by miniupnpd. For me this has solved numerous 'flaky' startup problems, especially with regard to ipv6. Signed-off-by: Kevin Darbyshire-Bryant <ldir@darbyshire-bryant.me.uk>
This commit is contained in:
parent
c2c91ea99e
commit
295d77943c
3 changed files with 50 additions and 23 deletions
|
@ -9,7 +9,7 @@ include $(TOPDIR)/rules.mk
|
||||||
|
|
||||||
PKG_NAME:=miniupnpd
|
PKG_NAME:=miniupnpd
|
||||||
PKG_VERSION:=2.1.20191006
|
PKG_VERSION:=2.1.20191006
|
||||||
PKG_RELEASE:=4
|
PKG_RELEASE:=5
|
||||||
|
|
||||||
PKG_SOURCE_URL:=https://miniupnp.tuxfamily.org/files
|
PKG_SOURCE_URL:=https://miniupnp.tuxfamily.org/files
|
||||||
PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz
|
PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz
|
||||||
|
|
|
@ -12,18 +12,35 @@
|
||||||
[ "$ACTION" != "ifup" ] && procd_running "miniupnpd" "*" && exit 0
|
[ "$ACTION" != "ifup" ] && procd_running "miniupnpd" "*" && exit 0
|
||||||
|
|
||||||
tmpconf="/var/etc/miniupnpd.conf"
|
tmpconf="/var/etc/miniupnpd.conf"
|
||||||
extiface=$(uci get upnpd.config.external_iface)
|
external_iface=$(uci get upnpd.config.external_iface)
|
||||||
extzone=$(uci get upnpd.config.external_zone)
|
external_iface6=$(uci get upnpd.config.external_iface6)
|
||||||
|
external_zone=$(uci get upnpd.config.external_zone)
|
||||||
|
|
||||||
. /lib/functions/network.sh
|
. /lib/functions/network.sh
|
||||||
|
|
||||||
[ -z "$extiface" ] && {
|
if [ -n "$external_iface" ] ; then
|
||||||
# manual external zone (if dynamically find interfaces
|
network_get_device ifname "$external_iface"
|
||||||
# belonging to it) overrides network_find_wan*
|
else
|
||||||
[ -n "$extzone" ] && ifname=$(fw3 -q zone "$extzone" | head -1)
|
if [ -n "$external_zone" ] ; then
|
||||||
[ -z "$extiface" ] && network_find_wan extiface
|
ifname=$(fw3 -q zone "$external_zone" 2>/dev/null | head -1)
|
||||||
[ -z "$extiface" ] && network_find_wan6 extiface
|
else
|
||||||
}
|
network_find_wan external_iface && \
|
||||||
|
network_get_device ifname "$external_iface"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
if [ -n "$external_iface6" ] ; then
|
||||||
|
network_get_device ifname6 "$external_iface6"
|
||||||
|
else
|
||||||
|
if [ -n "$external_zone" ] ; then
|
||||||
|
ifname6=$(fw3 -q zone "$external_zone" 2>/dev/null | head -1)
|
||||||
|
else
|
||||||
|
network_find_wan6 external_iface6 && \
|
||||||
|
network_get_device ifname6 "$external_iface6"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
[ -z "$ifname" ] && network_get_device ifname "$extiface"
|
[ "$DEVICE" != "$ifname" ] && [ "$DEVICE" != "$ifname6" ] && exit 0
|
||||||
grep -q "ext_ifname=$ifname" "$tmpconf" || /etc/init.d/miniupnpd restart
|
|
||||||
|
grep -q "^ext_ifname=$ifname" "$tmpconf" && grep -q "^ext_ifname6=$ifname6" "$tmpconf" && exit 0
|
||||||
|
|
||||||
|
/etc/init.d/miniupnpd restart
|
||||||
|
|
|
@ -67,6 +67,7 @@ upnpd() {
|
||||||
[ "$enabled" -eq 0 ] && return 1
|
[ "$enabled" -eq 0 ] && return 1
|
||||||
|
|
||||||
config_get external_iface config external_iface
|
config_get external_iface config external_iface
|
||||||
|
config_get external_iface6 config external_iface6
|
||||||
config_get external_zone config external_zone
|
config_get external_zone config external_zone
|
||||||
config_get external_ip config external_ip
|
config_get external_ip config external_ip
|
||||||
config_get internal_iface config internal_iface
|
config_get internal_iface config internal_iface
|
||||||
|
@ -91,17 +92,26 @@ upnpd() {
|
||||||
|
|
||||||
. /lib/functions/network.sh
|
. /lib/functions/network.sh
|
||||||
|
|
||||||
# manual external interface overrides everything
|
if [ -n "$external_iface" ] ; then
|
||||||
[ -z "$external_iface" ] && {
|
network_get_device ifname "$external_iface"
|
||||||
# manual external zone (if dynamically find interfaces
|
else
|
||||||
# belonging to it) overrides network_find_wan*
|
if [ -n "$external_zone" ] ; then
|
||||||
[ -n "$external_zone" ] && ifname=$(fw3 -q zone "$external_zone" | head -1)
|
ifname=$(fw3 -q zone "$external_zone" 2>/dev/null | head -1)
|
||||||
[ -z "$external_iface" ] && network_find_wan external_iface
|
else
|
||||||
[ -z "$external_iface6" ] && network_find_wan6 external_iface6
|
network_find_wan external_iface && \
|
||||||
}
|
network_get_device ifname "$external_iface"
|
||||||
|
fi
|
||||||
[ -z "$ifname" ] && network_get_device ifname "$external_iface"
|
fi
|
||||||
[ -z "$ifname6" ] && network_get_device ifname6 "$external_iface6"
|
if [ -n "$external_iface6" ] ; then
|
||||||
|
network_get_device ifname6 "$external_iface6"
|
||||||
|
else
|
||||||
|
if [ -n "$external_zone" ] ; then
|
||||||
|
ifname6=$(fw3 -q zone "$external_zone" 2>/dev/null | head -1)
|
||||||
|
else
|
||||||
|
network_find_wan6 external_iface6 && \
|
||||||
|
network_get_device ifname6 "$external_iface6"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
if [ -n "$config_file" ]; then
|
if [ -n "$config_file" ]; then
|
||||||
conf="$config_file"
|
conf="$config_file"
|
||||||
|
|
Loading…
Reference in a new issue