aboutsummaryrefslogtreecommitdiffstats
path: root/p2p/discover/database.go
diff options
context:
space:
mode:
authorPéter Szilágyi <peterke@gmail.com>2015-05-25 20:04:05 +0800
committerFelix Lange <fjl@twurst.com>2015-05-27 05:30:40 +0800
commit64174f196feb1b7ad58eed329ef5cdbebce9834c (patch)
tree821dac1c126b150cd902c082d23d37be4957e1af /p2p/discover/database.go
parent6a674ffea506aeb9962bb22bc0dbe0d5df72043b (diff)
downloadgo-tangerine-64174f196feb1b7ad58eed329ef5cdbebce9834c.tar
go-tangerine-64174f196feb1b7ad58eed329ef5cdbebce9834c.tar.gz
go-tangerine-64174f196feb1b7ad58eed329ef5cdbebce9834c.tar.bz2
go-tangerine-64174f196feb1b7ad58eed329ef5cdbebce9834c.tar.lz
go-tangerine-64174f196feb1b7ad58eed329ef5cdbebce9834c.tar.xz
go-tangerine-64174f196feb1b7ad58eed329ef5cdbebce9834c.tar.zst
go-tangerine-64174f196feb1b7ad58eed329ef5cdbebce9834c.zip
p2p/discover: add support for counting findnode failures
Diffstat (limited to 'p2p/discover/database.go')
-rw-r--r--p2p/discover/database.go17
1 files changed, 14 insertions, 3 deletions
diff --git a/p2p/discover/database.go b/p2p/discover/database.go
index 3a3f1254b..1b73c3dea 100644
--- a/p2p/discover/database.go
+++ b/p2p/discover/database.go
@@ -44,9 +44,10 @@ var (
nodeDBVersionKey = []byte("version") // Version of the database to flush if changes
nodeDBItemPrefix = []byte("n:") // Identifier to prefix node entries with
- nodeDBDiscoverRoot = ":discover"
- nodeDBDiscoverPing = nodeDBDiscoverRoot + ":lastping"
- nodeDBDiscoverPong = nodeDBDiscoverRoot + ":lastpong"
+ nodeDBDiscoverRoot = ":discover"
+ nodeDBDiscoverPing = nodeDBDiscoverRoot + ":lastping"
+ nodeDBDiscoverPong = nodeDBDiscoverRoot + ":lastpong"
+ nodeDBDiscoverFindFails = nodeDBDiscoverRoot + ":findfail"
)
// newNodeDB creates a new node database for storing and retrieving infos about
@@ -275,6 +276,16 @@ func (db *nodeDB) updateLastPong(id NodeID, instance time.Time) error {
return db.storeInt64(makeKey(id, nodeDBDiscoverPong), instance.Unix())
}
+// findFails retrieves the number of findnode failures since bonding.
+func (db *nodeDB) findFails(id NodeID) int {
+ return int(db.fetchInt64(makeKey(id, nodeDBDiscoverFindFails)))
+}
+
+// updateFindFails updates the number of findnode failures since bonding.
+func (db *nodeDB) updateFindFails(id NodeID, fails int) error {
+ return db.storeInt64(makeKey(id, nodeDBDiscoverFindFails), int64(fails))
+}
+
// querySeeds retrieves a batch of nodes to be used as potential seed servers
// during bootstrapping the node into the network.
//