diff options
author | Stan Grishin <stangri@melmac.ca> | 2023-12-11 13:18:21 +0000 |
---|---|---|
committer | Stan Grishin <stangri@melmac.ca> | 2023-12-11 13:18:36 +0000 |
commit | 8b6635bae9717babbc3dcf1347cf4727fc15f9bd (patch) | |
tree | 880e17fcc35717499922067ea09a490d110b543b /net/https-dns-proxy/files/etc | |
parent | 90300e54ef0dbd19c2a6cb0985e7d957f6c89b33 (diff) |
https-dns-proxy: only restart firewall when needed
* only restart firewall when needed
Signed-off-by: Stan Grishin <stangri@melmac.ca>
Diffstat (limited to 'net/https-dns-proxy/files/etc')
-rwxr-xr-x | net/https-dns-proxy/files/etc/init.d/https-dns-proxy | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/net/https-dns-proxy/files/etc/init.d/https-dns-proxy b/net/https-dns-proxy/files/etc/init.d/https-dns-proxy index c9e38cca9..0a11111c5 100755 --- a/net/https-dns-proxy/files/etc/init.d/https-dns-proxy +++ b/net/https-dns-proxy/files/etc/init.d/https-dns-proxy @@ -31,6 +31,7 @@ readonly canaryDomainsiCloud='mask.icloud.com mask-h2.icloud.com' on_boot_trigger= dnsmasq_restart() { [ -x /etc/init.d/dnsmasq ] || return 1; /etc/init.d/dnsmasq restart >/dev/null 2>&1; } +is_fw4_restart_needed() { [ "$(uci_get "$packageName" 'config' 'force_dns' '1')" = '1' ]; } is_mac_address() { expr "$1" : '[0-9A-F][0-9A-F]:[0-9A-F][0-9A-F]:[0-9A-F][0-9A-F]:[0-9A-F][0-9A-F]:[0-9A-F][0-9A-F]:[0-9A-F][0-9A-F]$' >/dev/null; } is_ipv4() { expr "$1" : '[0-9][0-9]*\.[0-9][0-9]*\.[0-9][0-9]*\.[0-9][0-9]*$' >/dev/null; } is_ipv6() { ! is_mac_address "$1" && str_contains "$1" ":"; } @@ -168,7 +169,7 @@ start_instance() { json_add_object mdns procd_add_mdns_service "$packageName" 'udp' "$port" "DNS over HTTPS proxy" json_close_object - if [ "$force_dns" -ne 0 ]; then + if [ "$force_dns" -ne '0' ]; then json_add_array firewall for iface in $procd_fw_src_interfaces; do for p in $force_dns_port; do @@ -218,7 +219,7 @@ start_instance() { fi output_ok port="$((port+1))" - force_dns=0 + force_dns='0' else output_fail fi @@ -318,8 +319,8 @@ service_triggers() { procd_add_config_trigger "config.change" "$packageName" "/etc/init.d/${packageName}" reload 'on_config_change' } -service_started() { procd_set_config_changed firewall; } -service_stopped() { procd_set_config_changed firewall; } +service_started() { is_fw4_restart_needed && procd_set_config_changed firewall; } +service_stopped() { is_fw4_restart_needed && procd_set_config_changed firewall; } restart() { procd_send_signal "$packageName"; rc_procd start_service "$*"; } dnsmasq_doh_server() { @@ -339,7 +340,7 @@ dnsmasq_doh_server() { uci_add_list_if_new 'dhcp' "$cfg" 'doh_server' "${address}#${port}" ;; remove) - for i in $(uci -q get "dhcp.$cfg.doh_server"); do + for i in $(uci_get 'dhcp' "$cfg" 'doh_server'); do uci_remove_list 'dhcp' "$cfg" 'server' "$i" uci_remove_list 'dhcp' "$cfg" 'doh_server' "$i" done |