6 log "github.com/sirupsen/logrus"
8 "github.com/vapor/p2p/discover/dht"
9 "github.com/vapor/toolbar/precog/config"
17 func (m *monitor) discoveryRoutine() {
19 // discvMap maps a node's public key to the node itself
20 discvMap := make(map[string]*dht.Node)
21 ticker := time.NewTicker(time.Duration(discvFreqSec) * time.Second)
23 nodes := make([]*dht.Node, nodesToDiscv)
24 num := m.sw.GetDiscv().ReadRandomNodes(nodes)
25 for _, node := range nodes[:num] {
26 if n, ok := discvMap[node.ID.String()]; ok && n.String() == node.String() {
30 log.WithFields(log.Fields{"new node": node}).Info("discover")
32 if err := m.upsertNode(&config.Node{
33 PublicKey: node.ID.String(),
37 log.WithFields(log.Fields{"node": node, "err": err}).Error("upsertNode")
39 discvMap[node.ID.String()] = node