mirror of
https://github.com/status-im/status-go.git
synced 2025-01-29 07:57:07 +00:00
40359f9c1b
* Adding wakunode module * Adding wakuv2 fleet files * Add waku fleets to update-fleet-config script * Adding config items for waku v2 * Conditionally start waku v2 node depending on config * Adapting common code to use go-waku * Setting log level to info * update dependencies * update fleet config to use WakuNodes instead of BootNodes * send and receive messages * use hash returned when publishing a message * add waku store protocol * trigger signal after receiving store messages * exclude linting rule SA1019 to check deprecated packages
73 lines
1.9 KiB
Go
73 lines
1.9 KiB
Go
package swarm
|
|
|
|
import (
|
|
"time"
|
|
|
|
addrutil "github.com/libp2p/go-addr-util"
|
|
ma "github.com/multiformats/go-multiaddr"
|
|
)
|
|
|
|
// ListenAddresses returns a list of addresses at which this swarm listens.
|
|
func (s *Swarm) ListenAddresses() []ma.Multiaddr {
|
|
s.listeners.RLock()
|
|
defer s.listeners.RUnlock()
|
|
return s.listenAddressesNoLock()
|
|
}
|
|
|
|
func (s *Swarm) listenAddressesNoLock() []ma.Multiaddr {
|
|
addrs := make([]ma.Multiaddr, 0, len(s.listeners.m))
|
|
for l := range s.listeners.m {
|
|
addrs = append(addrs, l.Multiaddr())
|
|
}
|
|
return addrs
|
|
}
|
|
|
|
const ifaceAddrsCacheDuration = 1 * time.Minute
|
|
|
|
// InterfaceListenAddresses returns a list of addresses at which this swarm
|
|
// listens. It expands "any interface" addresses (/ip4/0.0.0.0, /ip6/::) to
|
|
// use the known local interfaces.
|
|
func (s *Swarm) InterfaceListenAddresses() ([]ma.Multiaddr, error) {
|
|
s.listeners.RLock() // RLock start
|
|
|
|
ifaceListenAddres := s.listeners.ifaceListenAddres
|
|
isEOL := time.Now().After(s.listeners.cacheEOL)
|
|
s.listeners.RUnlock() // RLock end
|
|
|
|
if !isEOL {
|
|
// Cache is valid, clone the slice
|
|
return append(ifaceListenAddres[:0:0], ifaceListenAddres...), nil
|
|
}
|
|
|
|
// Cache is not valid
|
|
// Perfrom double checked locking
|
|
|
|
s.listeners.Lock() // Lock start
|
|
|
|
ifaceListenAddres = s.listeners.ifaceListenAddres
|
|
isEOL = time.Now().After(s.listeners.cacheEOL)
|
|
if isEOL {
|
|
// Cache is still invalid
|
|
listenAddres := s.listenAddressesNoLock()
|
|
if len(listenAddres) > 0 {
|
|
// We're actually listening on addresses.
|
|
var err error
|
|
ifaceListenAddres, err = addrutil.ResolveUnspecifiedAddresses(listenAddres, nil)
|
|
|
|
if err != nil {
|
|
s.listeners.Unlock() // Lock early exit
|
|
return nil, err
|
|
}
|
|
} else {
|
|
ifaceListenAddres = nil
|
|
}
|
|
|
|
s.listeners.ifaceListenAddres = ifaceListenAddres
|
|
s.listeners.cacheEOL = time.Now().Add(ifaceAddrsCacheDuration)
|
|
}
|
|
|
|
s.listeners.Unlock() // Lock end
|
|
|
|
return append(ifaceListenAddres[:0:0], ifaceListenAddres...), nil
|
|
}
|