2020-05-21 20:24:20 +00:00
|
|
|
import random
|
2019-12-06 02:16:18 +00:00
|
|
|
import chronos
|
2019-12-08 21:06:58 +00:00
|
|
|
import ../../libp2p/standard_setup
|
|
|
|
export standard_setup
|
2019-12-06 02:16:18 +00:00
|
|
|
|
2020-05-21 20:24:20 +00:00
|
|
|
randomize()
|
|
|
|
|
2019-12-06 02:16:18 +00:00
|
|
|
proc generateNodes*(num: Natural, gossip: bool = false): seq[Switch] =
|
|
|
|
for i in 0..<num:
|
2019-12-08 21:06:58 +00:00
|
|
|
result.add(newStandardSwitch(gossip = gossip))
|
2019-12-06 02:16:18 +00:00
|
|
|
|
|
|
|
proc subscribeNodes*(nodes: seq[Switch]) {.async.} =
|
2020-02-25 22:13:05 +00:00
|
|
|
var dials: seq[Future[void]]
|
2019-12-06 02:16:18 +00:00
|
|
|
for dialer in nodes:
|
|
|
|
for node in nodes:
|
|
|
|
if dialer.peerInfo.peerId != node.peerInfo.peerId:
|
2020-02-25 22:13:05 +00:00
|
|
|
dials.add(dialer.connect(node.peerInfo))
|
2020-01-07 08:06:27 +00:00
|
|
|
await allFutures(dials)
|
2020-05-21 20:24:20 +00:00
|
|
|
|
2020-06-02 23:53:38 +00:00
|
|
|
proc subscribeSparseNodes*(nodes: seq[Switch], degree: int = 2) {.async.} =
|
|
|
|
if nodes.len < degree:
|
|
|
|
raise (ref CatchableError)(msg: "nodes count needs to be greater or equal to degree!")
|
|
|
|
|
|
|
|
var dials: seq[Future[void]]
|
|
|
|
for i, dialer in nodes:
|
|
|
|
if (i mod degree) != 0:
|
|
|
|
continue
|
|
|
|
|
|
|
|
for node in nodes:
|
|
|
|
if dialer.peerInfo.peerId != node.peerInfo.peerId:
|
|
|
|
dials.add(dialer.connect(node.peerInfo))
|
|
|
|
await allFutures(dials)
|
|
|
|
|
2020-05-21 20:24:20 +00:00
|
|
|
proc subscribeRandom*(nodes: seq[Switch]) {.async.} =
|
|
|
|
var dials: seq[Future[void]]
|
|
|
|
for dialer in nodes:
|
|
|
|
var dialed: seq[string]
|
|
|
|
while dialed.len < nodes.len - 1:
|
|
|
|
let node = sample(nodes)
|
|
|
|
if node.peerInfo.id notin dialed:
|
|
|
|
if dialer.peerInfo.id != node.peerInfo.id:
|
|
|
|
dials.add(dialer.connect(node.peerInfo))
|
|
|
|
dialed &= node.peerInfo.id
|
|
|
|
await allFutures(dials)
|