Merge pull request #43 from ngosang/speedup_find_nodes

optimize find_nodes bencoding and random_bytes generation
This commit is contained in:
Bora M. Alper 2017-04-21 01:11:23 +04:00 committed by GitHub
commit 8063480fe5
2 changed files with 25 additions and 20 deletions

View File

@ -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)

View File

@ -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)
)