aboutsummaryrefslogtreecommitdiff
path: root/net/adguardhome
diff options
context:
space:
mode:
authorStan Grishin <stangri@melmac.ca>2024-03-18 10:21:16 -0600
committerGitHub <noreply@github.com>2024-03-18 10:21:16 -0600
commit0577aa43d6f3db0c4c43764a02dd219f996d6793 (patch)
tree192d65076641f36d2e0f344e83fa3c8b8b7a2a09 /net/adguardhome
parent01e3135023069eb1bee3141c17dd458e9db7c699 (diff)
parentd00131e2a0c8e846b42df22eda6c8356d4fce4a9 (diff)
Merge pull request #22211 from alaviss/adguard-network-wait
adguardhome: wait for interfaces to be up at boot
Diffstat (limited to 'net/adguardhome')
-rw-r--r--net/adguardhome/files/adguardhome.init22
1 files changed, 20 insertions, 2 deletions
diff --git a/net/adguardhome/files/adguardhome.init b/net/adguardhome/files/adguardhome.init
index 802dcdae3..6a29c4e4a 100644
--- a/net/adguardhome/files/adguardhome.init
+++ b/net/adguardhome/files/adguardhome.init
@@ -4,12 +4,22 @@ PROG=/usr/bin/AdGuardHome
USE_PROCD=1
-# starts just after network starts to avoid some network race conditions
-START=25
+# matches dnsmasq
+START=19
# stops before networking stops
STOP=89
+boot() {
+ adguardhome_boot=1
+ start "$@"
+}
+
start_service() {
+ if [ -n "$adguardhome_boot" ]; then
+ # Do not start yet, wait for triggers
+ return 0
+ fi
+
config_load adguardhome
config_get WORK_DIR config workdir
@@ -21,3 +31,11 @@ start_service() {
procd_set_param stderr 1
procd_close_instance
}
+
+service_triggers() {
+ if [ -n "$adguardhome_boot" ]; then
+ # Wait for interfaces to be up before starting AdGuard Home for real.
+ # Prevents issues like https://github.com/openwrt/packages/issues/21868.
+ procd_add_raw_trigger "interface.*.up" 5000 /etc/init.d/adguardhome restart
+ fi
+}