Merge pull request #43 from ngosang/speedup_find_nodes
optimize find_nodes bencoding and random_bytes generation
This commit is contained in:
commit
8063480fe5
@ -19,6 +19,7 @@ import math
|
|||||||
import socket
|
import socket
|
||||||
import random
|
import random
|
||||||
import typing
|
import typing
|
||||||
|
import os
|
||||||
|
|
||||||
from . import bencode
|
from . import bencode
|
||||||
|
|
||||||
@ -287,4 +288,4 @@ class DisposablePeer:
|
|||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def __random_bytes(n: int) -> bytes:
|
def __random_bytes(n: int) -> bytes:
|
||||||
return random.getrandbits(n * 8).to_bytes(n, "big")
|
return os.urandom(n)
|
||||||
|
@ -19,6 +19,7 @@ import logging
|
|||||||
import random
|
import random
|
||||||
import socket
|
import socket
|
||||||
import typing
|
import typing
|
||||||
|
import os
|
||||||
|
|
||||||
from . import bencode
|
from . import bencode
|
||||||
|
|
||||||
@ -211,27 +212,11 @@ class SybilNode:
|
|||||||
|
|
||||||
def __bootstrap(self) -> None:
|
def __bootstrap(self) -> None:
|
||||||
for addr in BOOTSTRAPPING_NODES:
|
for addr in BOOTSTRAPPING_NODES:
|
||||||
self.__outgoing_queue.append((addr, bencode.dumps({
|
self.__outgoing_queue.append((addr, self.__build_FIND_NODE_query(self.__true_id)))
|
||||||
b"y": b"q",
|
|
||||||
b"q": b"find_node",
|
|
||||||
b"t": self.__random_bytes(2),
|
|
||||||
b"a": {
|
|
||||||
b"id": self.__true_id,
|
|
||||||
b"target": self.__random_bytes(20)
|
|
||||||
}
|
|
||||||
})))
|
|
||||||
|
|
||||||
def __make_neighbours(self) -> None:
|
def __make_neighbours(self) -> None:
|
||||||
for node_id, addr in self.__routing_table.items():
|
for node_id, addr in self.__routing_table.items():
|
||||||
self.__outgoing_queue.append((addr, bencode.dumps({
|
self.__outgoing_queue.append((addr, self.__build_FIND_NODE_query(node_id[:15] + self.__true_id[:5])))
|
||||||
b"y": b"q",
|
|
||||||
b"q": b"find_node",
|
|
||||||
b"t": self.__random_bytes(2),
|
|
||||||
b"a": {
|
|
||||||
b"id": node_id[:15] + self.__true_id[:5],
|
|
||||||
b"target": self.__random_bytes(20)
|
|
||||||
}
|
|
||||||
})))
|
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def __decode_nodes(infos: bytes) -> typing.List[typing.Tuple[NodeID, NodeAddress]]:
|
def __decode_nodes(infos: bytes) -> typing.List[typing.Tuple[NodeID, NodeAddress]]:
|
||||||
@ -260,4 +245,23 @@ class SybilNode:
|
|||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def __random_bytes(n: int) -> bytes:
|
def __random_bytes(n: int) -> bytes:
|
||||||
return random.getrandbits(n * 8).to_bytes(n, "big")
|
return os.urandom(n)
|
||||||
|
|
||||||
|
def __build_FIND_NODE_query(self, id_: bytes) -> bytes:
|
||||||
|
""" BENCODE IMPLEMENTATION
|
||||||
|
bencode.dumps({
|
||||||
|
b"y": b"q",
|
||||||
|
b"q": b"find_node",
|
||||||
|
b"t": self.__random_bytes(2),
|
||||||
|
b"a": {
|
||||||
|
b"id": id_,
|
||||||
|
b"target": self.__random_bytes(20)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
"""
|
||||||
|
|
||||||
|
""" Optimized Version """
|
||||||
|
return b"d1:ad2:id20:%s6:target20:%se1:q9:find_node1:t2:aa1:y1:qe" % (
|
||||||
|
id_,
|
||||||
|
self.__random_bytes(20)
|
||||||
|
)
|
||||||
|
Loading…
Reference in New Issue
Block a user