Reload resolver on config change

This commit is contained in:
Daniel 2020-05-20 14:57:33 +02:00
parent c71dfaab38
commit 36c60a1e33

View file

@ -2,6 +2,7 @@ package resolver
import (
"context"
"strings"
"time"
"github.com/safing/portbase/log"
@ -30,6 +31,7 @@ func start() error {
// load resolvers from config and environment
loadResolvers()
// reload after network change
err := module.RegisterEventHook(
"netenv",
"network changed",
@ -44,6 +46,27 @@ func start() error {
return err
}
// reload after config change
prevNameservers := strings.Join(configuredNameServers(), " ")
err = module.RegisterEventHook(
"config",
"config change",
"update nameservers",
func(_ context.Context, _ interface{}) error {
newNameservers := strings.Join(configuredNameServers(), " ")
if newNameservers != prevNameservers {
prevNameservers = newNameservers
loadResolvers()
log.Debug("resolver: reloaded nameservers due to config change")
}
return nil
},
)
if err != nil {
return err
}
module.StartServiceWorker(
"mdns handler",
5*time.Second,