Felix Fietkau 05138fe898
Some checks are pending
Build all core packages / Build all core packages for selected target (push) Waiting to run
umdns: add firewall rule for configured interfaces
Makes it easier to enable MDNS on wan without having to edit the firewall
configuration for it

Signed-off-by: Felix Fietkau <nbd@nbd.name>
2025-02-08 22:31:46 +01:00

73 lines
1.5 KiB
Bash

#!/bin/sh /etc/rc.common
# Copyright (c) 2014 OpenWrt.org
START=80
USE_PROCD=1
PROG=/usr/sbin/umdns
IFACES=""
load_ifaces() {
local network="$(uci -q get umdns.@umdns[-1].network)"
for n in $network; do
local device
json_load "$(ifstatus $n)"
json_get_var device l3_device
echo -n "$device "
done
}
reload_service() {
json_init
json_add_array interfaces
for i in $(load_ifaces); do
json_add_string "" "$i"
done
json_close_array
ubus call umdns set_config "$(json_dump)"
}
start_service() {
local network="$(uci -q get umdns.@umdns[-1].network)"
procd_open_instance
procd_set_param command "$PROG"
[ -f /etc/seccomp/umdns.json ] && procd_set_param seccomp /etc/seccomp/umdns.json
procd_set_param respawn
procd_open_data
json_add_array firewall
for n in $network; do
json_add_object ""
json_add_string type rule
json_add_string proto udp
json_add_string src "$n"
json_add_int dest_port 5353
json_add_string target ACCEPT
json_close_object
done
json_close_array
procd_close_data
procd_open_trigger
procd_add_config_trigger "config.change" "umdns" /etc/init.d/umdns reload
for n in $network; do
procd_add_interface_trigger "interface.*" $n /etc/init.d/umdns reload
done
procd_add_raw_trigger "instance.update" 5000 "/bin/ubus" "call" "umdns" "reload"
procd_close_trigger
[ "$(uci get umdns.@umdns[-1].jail)" = 1 ] && {
procd_add_jail umdns ubus log
[ -d /etc/umdns ] && procd_add_jail_mount "/etc/umdns"
}
procd_close_instance
}
service_started() {
ubus -t 10 wait_for umdns
[ $? = 0 ] && reload_service
}