Skip to content
This repository has been archived by the owner on Jul 21, 2023. It is now read-only.

Commit

Permalink
chore: use new peer store api
Browse files Browse the repository at this point in the history
BREAKING CHANGE: uses new peer-store api
  • Loading branch information
vasco-santos committed Apr 1, 2020
1 parent 6456cc8 commit 5656d6b
Show file tree
Hide file tree
Showing 11 changed files with 36 additions and 55 deletions.
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -76,14 +76,14 @@
"delay": "^4.3.0",
"dirty-chai": "^2.0.1",
"it-pair": "^1.0.0",
"libp2p": "libp2p/js-libp2p#chore/deprecate-old-peer-store-api",
"lodash": "^4.17.11",
"lodash.random": "^3.2.0",
"lodash.range": "^3.2.0",
"p-defer": "^3.0.0",
"p-each-series": "^2.1.0",
"p-map-series": "^2.1.0",
"p-retry": "^4.2.0",
"peer-book": "~0.9.2",
"sinon": "^9.0.0"
},
"contributors": [
Expand Down
9 changes: 2 additions & 7 deletions src/content-routing/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -80,12 +80,7 @@ module.exports = (dht) => {
const provs = await dht.providers.getProviders(key)

provs.forEach((id) => {
let info
if (dht.peerStore.has(id)) {
info = dht.peerStore.get(id)
} else {
info = dht.peerStore.put(new PeerInfo(id))
}
const info = dht.peerStore.find(id) || new PeerInfo(id)
out.push(info)
})

Expand Down Expand Up @@ -113,7 +108,7 @@ module.exports = (dht) => {
dht._log('(%s) found %s provider entries', dht.peerInfo.id.toB58String(), provs.length)

provs.forEach((prov) => {
pathProviders.push(dht.peerStore.put(prov))
pathProviders.push(prov)
})

// hooray we have all that we want
Expand Down
8 changes: 1 addition & 7 deletions src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -321,15 +321,9 @@ class KadDHT extends EventEmitter {
*/
async _nearestPeersToQuery (msg) {
const key = await utils.convertBuffer(msg.key)

const ids = this.routingTable.closestPeers(key, this.kBucketSize)

return ids.map((p) => {
if (this.peerStore.has(p)) {
return this.peerStore.get(p)
}
return this.peerStore.put(new PeerInfo(p))
})
return ids.map((p) => new PeerInfo(p))
}

/**
Expand Down
44 changes: 21 additions & 23 deletions src/peer-routing/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@ const errcode = require('err-code')
const pTimeout = require('p-timeout')

const PeerId = require('peer-id')
const PeerInfo = require('peer-info')
const crypto = require('libp2p-crypto')

const c = require('../constants')
Expand All @@ -24,11 +23,7 @@ module.exports = (dht) => {
dht._log('findPeerLocal %s', peer.toB58String())
const p = await dht.routingTable.find(peer)

if (!p || !dht.peerStore.has(p)) {
return
}

return dht.peerStore.get(p)
return p && dht.peerStore.find(p)
}

/**
Expand Down Expand Up @@ -57,7 +52,12 @@ module.exports = (dht) => {

return msg.closerPeers
.filter((pInfo) => !dht._isSelf(pInfo.id))
.map((pInfo) => dht.peerStore.put(pInfo))
.map((pInfo) => {
// Add known address to peer store
dht.peerStore.addressBook.set(pInfo.id, pInfo.multiaddrs.toArray(), { replace: false })

return pInfo
})
}

/**
Expand Down Expand Up @@ -128,9 +128,13 @@ module.exports = (dht) => {

// sanity check
const match = peers.find((p) => p.isEqual(id))
if (match && dht.peerStore.has(id)) {
dht._log('found in peerStore')
return dht.peerStore.get(id)
if (match) {
const peer = dht.peerStore.find(id)

if (peer) {
dht._log('found in peerStore')
return peer
}
}

// query the network
Expand Down Expand Up @@ -169,15 +173,15 @@ module.exports = (dht) => {
result.paths.forEach((result) => {
if (result.success) {
success = true
dht.peerStore.put(result.peer)
dht.peerStore.addressBook.set(result.peer.id, result.peer.multiaddrs.toArray(), { replace: false })
}
})
dht._log('findPeer %s: %s', id.toB58String(), success)

if (!success) {
throw errcode(new Error('No peer found'), 'ERR_NOT_FOUND')
}
return dht.peerStore.get(id)
return dht.peerStore.find(id)
},

/**
Expand Down Expand Up @@ -228,16 +232,10 @@ module.exports = (dht) => {
dht._log('getPublicKey %s', peer.toB58String())

// local check
let info
if (dht.peerStore.has(peer)) {
info = dht.peerStore.get(peer)

if (info && info.id.pubKey) {
dht._log('getPublicKey: found local copy')
return info.id.pubKey
}
} else {
info = dht.peerStore.put(new PeerInfo(peer))
const info = dht.peerStore.find(peer)
if (info && info.id.pubKey) {
dht._log('getPublicKey: found local copy')
return info.id.pubKey
}

// try the node directly
Expand All @@ -252,7 +250,7 @@ module.exports = (dht) => {
}

info.id = new PeerId(peer.id, null, pk)
dht.peerStore.put(info)
dht.peerStore.addressBook.set(info.id, info.multiaddrs.toArray(), { replace: false })

return pk
}
Expand Down
1 change: 0 additions & 1 deletion src/query/workerQueue.js
Original file line number Diff line number Diff line change
Expand Up @@ -244,7 +244,6 @@ class WorkerQueue {
if (this.dht._isSelf(closer.id)) {
return
}
closer = this.dht.peerStore.put(closer)
this.dht._peerDiscovered(closer)
await this.path.addPeerToQuery(closer.id)
}))
Expand Down
3 changes: 2 additions & 1 deletion src/rpc/handlers/add-provider.js
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,8 @@ module.exports = (dht) => {
log('received provider %s for %s (addrs %s)', peer.id.toB58String(), cid.toBaseEncodedString(), pi.multiaddrs.toArray().map((m) => m.toString()))

if (!dht._isSelf(pi.id)) {
dht.peerStore.put(pi)
// Add known address to peer store
dht.peerStore.addressBook.set(pi.id, pi.multiaddrs.toArray(), { replace: false })
return dht.providers.addProvider(cid, pi.id)
}
})
Expand Down
8 changes: 1 addition & 7 deletions src/rpc/handlers/get-providers.js
Original file line number Diff line number Diff line change
Expand Up @@ -34,13 +34,7 @@ module.exports = (dht) => {
dht._betterPeersToQuery(msg, peer)
])

const providers = peers.map((p) => {
if (dht.peerStore.has(p)) {
return dht.peerStore.get(p)
}

return dht.peerStore.put(new PeerInfo(p))
})
const providers = peers.map((p) => new PeerInfo(p))

if (has) {
providers.push(dht.peerInfo)
Expand Down
4 changes: 2 additions & 2 deletions src/rpc/handlers/get-value.js
Original file line number Diff line number Diff line change
Expand Up @@ -35,8 +35,8 @@ module.exports = (dht) => {

if (dht._isSelf(id)) {
info = dht.peerInfo
} else if (dht.peerStore.has(id)) {
info = dht.peerStore.get(id)
} else {
info = dht.peerStore.find(id)
}

if (info && info.id.pubKey) {
Expand Down
4 changes: 2 additions & 2 deletions test/query/index.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ chai.use(require('chai-checkmark'))
const expect = chai.expect
const sinon = require('sinon')
const delay = require('delay')
const PeerBook = require('peer-book')
const PeerStore = require('libp2p/src/peer-store')

const Query = require('../../src/query')
const Path = require('../../src/query/path')
Expand Down Expand Up @@ -46,7 +46,7 @@ describe('Query', () => {
})

before('create a dht', () => {
const peerStore = new PeerBook()
const peerStore = new PeerStore()
dht = new DHT({
dialer: {},
peerStore,
Expand Down
4 changes: 2 additions & 2 deletions test/simulation/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
/* eslint-disable no-console */

'use strict'
const PeerBook = require('peer-book')
const PeerStore = require('libp2p/src/peer-store')
const PeerId = require('peer-id')
const PeerInfo = require('peer-info')
const multihashes = require('multihashes')
Expand Down Expand Up @@ -85,7 +85,7 @@ async function setup () {
async function GetClosestPeersSimulation () {
const dht = new DHT({
_peerInfo: ourPeerInfo,
_peerBook: new PeerBook(),
_peerBook: new PeerStore(),
handle: () => {},
on: () => {}
}, {
Expand Down
4 changes: 2 additions & 2 deletions test/utils/test-dht.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
'use strict'

const PeerBook = require('peer-book')
const PeerStore = require('libp2p/src/peer-store')
const pRetry = require('p-retry')
const delay = require('delay')

Expand All @@ -27,7 +27,7 @@ class TestDHT {

async _spawnOne (index, options = {}) {
const regRecord = {}
const peerStore = new PeerBook()
const peerStore = new PeerStore()

// Disable random walk by default for more controlled testing
options = {
Expand Down

0 comments on commit 5656d6b

Please sign in to comment.