From 1e1cbc5664d8349b40f9a5703ea035c26d5ba1d6 Mon Sep 17 00:00:00 2001 From: Nate Maninger Date: Fri, 29 Dec 2023 08:00:52 -0800 Subject: [PATCH 1/2] settings: return error for localhost --- host/settings/netaddress_default.go | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/host/settings/netaddress_default.go b/host/settings/netaddress_default.go index c19cf401..1061bf2c 100644 --- a/host/settings/netaddress_default.go +++ b/host/settings/netaddress_default.go @@ -3,6 +3,7 @@ package settings import ( + "errors" "fmt" "net" ) @@ -11,6 +12,10 @@ func validateNetAddress(netaddress string) error { addr, _, err := net.SplitHostPort(netaddress) if err != nil { return fmt.Errorf("invalid net address %q: net addresses must contain an IP and port: %w", netaddress, err) + } else if addr == "" { + return errors.New("empty net address") + } else if addr == "localhost" { + return errors.New("net address cannot be localhost") } ip := net.ParseIP(addr) From 70a53471428c61088dde5064f8685a420a15f0e0 Mon Sep 17 00:00:00 2001 From: Nate Maninger Date: Fri, 29 Dec 2023 08:03:02 -0800 Subject: [PATCH 2/2] settings: add validation to auto-announce --- host/settings/announce.go | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/host/settings/announce.go b/host/settings/announce.go index 8df4361a..e93a0ee0 100644 --- a/host/settings/announce.go +++ b/host/settings/announce.go @@ -159,6 +159,12 @@ func (cm *ConfigManager) ProcessConsensusChange(cc modules.ConsensusChange) { // get the current net address cm.mu.Lock() defer cm.mu.Unlock() + + if err := validateNetAddress(cm.settings.NetAddress); err != nil { + log.Debug("skipping auto announcement for invalid net address", zap.Error(err)) + return + } + currentNetAddress := cm.settings.NetAddress cm.scanHeight = uint64(cc.BlockHeight) timestamp := time.Unix(int64(cc.AppliedBlocks[len(cc.AppliedBlocks)-1].Timestamp), 0) @@ -168,7 +174,7 @@ func (cm *ConfigManager) ProcessConsensusChange(cc modules.ConsensusChange) { // if the address hasn't changed, don't reannounce if cm.scanHeight < nextAnnounceHeight && currentNetAddress == lastAnnouncement.Address { - log.Debug("skipping announcement") + log.Debug("skipping announcement for unchanged address") return }