aboutsummaryrefslogtreecommitdiffstats
path: root/p2p/discover/table.go
diff options
context:
space:
mode:
authorFelix Lange <fjl@twurst.com>2015-04-23 18:11:21 +0800
committerFelix Lange <fjl@twurst.com>2015-04-30 21:02:23 +0800
commit72ab6d325555c742c6b70202d865ec23b50734d6 (patch)
tree92522e695c39ab4ee31321b5b469611f001fd684 /p2p/discover/table.go
parentb34a8ef624499e15cc3a2a51bddd94391f9b993e (diff)
downloaddexon-72ab6d325555c742c6b70202d865ec23b50734d6.tar
dexon-72ab6d325555c742c6b70202d865ec23b50734d6.tar.gz
dexon-72ab6d325555c742c6b70202d865ec23b50734d6.tar.bz2
dexon-72ab6d325555c742c6b70202d865ec23b50734d6.tar.lz
dexon-72ab6d325555c742c6b70202d865ec23b50734d6.tar.xz
dexon-72ab6d325555c742c6b70202d865ec23b50734d6.tar.zst
dexon-72ab6d325555c742c6b70202d865ec23b50734d6.zip
p2p/discover: track sha3(ID) in Node
Diffstat (limited to 'p2p/discover/table.go')
-rw-r--r--p2p/discover/table.go11
1 files changed, 6 insertions, 5 deletions
diff --git a/p2p/discover/table.go b/p2p/discover/table.go
index bbd40fde9..ae10fed5b 100644
--- a/p2p/discover/table.go
+++ b/p2p/discover/table.go
@@ -12,6 +12,7 @@ import (
"sync"
"time"
+ "github.com/ethereum/go-ethereum/crypto"
"github.com/ethereum/go-ethereum/logger"
"github.com/ethereum/go-ethereum/logger/glog"
)
@@ -71,7 +72,7 @@ func newTable(t transport, ourID NodeID, ourAddr *net.UDPAddr, nodeDBPath string
tab := &Table{
net: t,
db: db,
- self: newNode(ourID, ourAddr),
+ self: newNode(ourID, ourAddr.IP, uint16(ourAddr.Port), uint16(ourAddr.Port)),
bonding: make(map[NodeID]*bondproc),
bondslots: make(chan struct{}, maxBondingPingPongs),
}
@@ -105,6 +106,7 @@ func (tab *Table) Bootstrap(nodes []*Node) {
tab.nursery = make([]*Node, 0, len(nodes))
for _, n := range nodes {
cpy := *n
+ cpy.sha = crypto.Sha3Hash(n.ID[:])
tab.nursery = append(tab.nursery, &cpy)
}
tab.mutex.Unlock()
@@ -299,7 +301,7 @@ func (tab *Table) pingpong(w *bondproc, pinged bool, id NodeID, addr *net.UDPAdd
tab.net.waitping(id)
}
// Bonding succeeded, update the node database
- w.n = &Node{ID: id, IP: addr.IP, UDP: uint16(addr.Port), TCP: tcpPort}
+ w.n = newNode(id, addr.IP, uint16(addr.Port), tcpPort)
tab.db.updateNode(w.n)
close(w.done)
}
@@ -340,9 +342,8 @@ func (tab *Table) ping(id NodeID, addr *net.UDPAddr) error {
func (tab *Table) add(entries []*Node) {
outer:
for _, n := range entries {
- if n == nil || n.ID == tab.self.ID {
- // skip bad entries. The RLP decoder returns nil for empty
- // input lists.
+ if n.ID == tab.self.ID {
+ // don't add self.
continue
}
bucket := tab.buckets[logdist(tab.self.ID, n.ID)]