From a0327af8a00c83dc80787efc66e0a182ab1cd543 Mon Sep 17 00:00:00 2001 From: John Maguire Date: Fri, 25 Oct 2024 13:21:17 -0400 Subject: [PATCH] Don't overwrite old DNS results with empty list --- lighthouse.go | 2 +- remote_list.go | 41 ++++++++++++++++++++++++----------------- 2 files changed, 25 insertions(+), 18 deletions(-) diff --git a/lighthouse.go b/lighthouse.go index 62f406560..0f154fc3e 100644 --- a/lighthouse.go +++ b/lighthouse.go @@ -545,7 +545,7 @@ func (lh *LightHouse) addStaticRemotes(i int, d time.Duration, network string, t ctx := lh.ctx lh.Unlock() - hr, err := NewHostnameResults(ctx, lh.l, d, network, timeout, toAddrs, func() { + hr, err := NewHostnamesResults(ctx, lh.l, d, vpnIp, network, timeout, toAddrs, func() { // This callback runs whenever the DNS hostname resolver finds a different set of IP's // in its resolution for hostnames. am.Lock() diff --git a/remote_list.go b/remote_list.go index 94db8f2f8..8f75f795e 100644 --- a/remote_list.go +++ b/remote_list.go @@ -68,11 +68,12 @@ type hostnamesResults struct { network string lookupTimeout time.Duration cancelFn func() - l *logrus.Logger + l logrus.FieldLogger ips atomic.Pointer[map[netip.AddrPort]struct{}] } -func NewHostnameResults(ctx context.Context, l *logrus.Logger, d time.Duration, network string, timeout time.Duration, hostPorts []string, onUpdate func()) (*hostnamesResults, error) { +func NewHostnamesResults(ctx context.Context, l logrus.FieldLogger, d time.Duration, vpnIp netip.Addr, network string, timeout time.Duration, hostPorts []string, onUpdate func()) (*hostnamesResults, error) { + l = l.WithField("vpnIp", vpnIp) r := &hostnamesResults{ hostnames: make([]hostnamePort, len(hostPorts)), network: network, @@ -130,27 +131,33 @@ func NewHostnameResults(ctx context.Context, l *logrus.Logger, d time.Duration, netipAddrs[netip.AddrPortFrom(a.Unmap(), hostPort.port)] = struct{}{} } } + origSet := r.ips.Load() - different := false - for a := range *origSet { - if _, ok := netipAddrs[a]; !ok { - different = true - break - } - } - if !different { - for a := range netipAddrs { - if _, ok := (*origSet)[a]; !ok { + if len(netipAddrs) == 0 && len(*origSet) != 0 { + l.WithFields(logrus.Fields{"hostnames": r.hostnames}).Info("No IPs resolved for hostnames, refusing to overwrite existing IPs") + } else { + different := false + for a := range *origSet { + if _, ok := netipAddrs[a]; !ok { different = true break } } + if !different { + for a := range netipAddrs { + if _, ok := (*origSet)[a]; !ok { + different = true + break + } + } + } + if different { + l.WithFields(logrus.Fields{"origSet": origSet, "newSet": netipAddrs}).Info("DNS results changed for host list") + r.ips.Store(&netipAddrs) + onUpdate() + } } - if different { - l.WithFields(logrus.Fields{"origSet": origSet, "newSet": netipAddrs}).Info("DNS results changed for host list") - r.ips.Store(&netipAddrs) - onUpdate() - } + select { case <-newCtx.Done(): return