2018-05-08 17:58:45 +00:00
|
|
|
import ../ethp2p/[discovery, kademlia, peer_pool, enode]
|
|
|
|
import eth_keys, net, asyncdispatch, sequtils
|
2018-03-30 13:58:06 +00:00
|
|
|
|
2018-05-08 17:58:45 +00:00
|
|
|
import logging, byteutils
|
|
|
|
|
|
|
|
addHandler(newConsoleLogger())
|
|
|
|
|
|
|
|
proc startDiscoveryNode(privKey: PrivateKey, address: Address, bootnodes: seq[ENode]): Future[DiscoveryProtocol] {.async.} =
|
|
|
|
result = newDiscoveryProtocol(privKey, address, bootnodes)
|
|
|
|
result.open()
|
|
|
|
await result.bootstrap()
|
|
|
|
|
|
|
|
proc localAddress(port: int): Address =
|
|
|
|
let port = Port(port)
|
|
|
|
result = Address(udpPort: port, tcpPort: port, ip: parseIpAddress("127.0.0.1"))
|
|
|
|
|
|
|
|
let
|
|
|
|
bootNodeKey = initPrivateKey("a2b50376a79b1a8c8a3296485572bdfbf54708bb46d3c25d73d2723aaaf6a617")
|
|
|
|
bootNodeAddr = localAddress(20301)
|
|
|
|
bootENode = initENode(bootNodeKey.getPublicKey, bootNodeAddr)
|
|
|
|
|
|
|
|
nodeKeys = [
|
|
|
|
initPrivateKey("a2b50376a79b1a8c8a3296485572bdfbf54708bb46d3c25d73d2723aaaf6a618"),
|
|
|
|
initPrivateKey("a2b50376a79b1a8c8a3296485572bdfbf54708bb46d3c25d73d2723aaaf6a619"),
|
|
|
|
initPrivateKey("a2b50376a79b1a8c8a3296485572bdfbf54708bb46d3c25d73d2723aaaf6a620")
|
|
|
|
]
|
|
|
|
|
|
|
|
proc nodeIdInNodes(id: NodeId, nodes: openarray[Node]): bool =
|
|
|
|
for n in nodes:
|
|
|
|
if id == n.id: return true
|
|
|
|
|
|
|
|
proc test() {.async.} =
|
|
|
|
let bootNode = await startDiscoveryNode(bootNodeKey, bootNodeAddr, @[])
|
|
|
|
|
|
|
|
var nodeAddrs = newSeqOfCap[Address](nodeKeys.len)
|
|
|
|
for i in 0 ..< nodeKeys.len: nodeAddrs.add(localAddress(20302 + i))
|
|
|
|
|
|
|
|
var nodes = await all(zip(nodeKeys, nodeAddrs).mapIt(startDiscoveryNode(it.a, it.b, @[bootENode])))
|
|
|
|
nodes.add(bootNode)
|
|
|
|
|
|
|
|
for i in nodes:
|
|
|
|
for j in nodes:
|
|
|
|
if j != i:
|
|
|
|
doAssert(nodeIdInNodes(i.thisNode.id, j.randomNodes(nodes.len - 1)))
|
|
|
|
|
|
|
|
waitFor test()
|