avoid peer mutability

Mutability can be harmful here, specially on fields used for __hash__
It can also make the cache less efficient
This commit is contained in:
Victor Shyba 2019-10-01 18:02:23 -03:00
parent 8cd18e47e7
commit 91a9957918
3 changed files with 4 additions and 12 deletions

View file

@ -233,7 +233,7 @@ class Node:
if not peer.udp_port: if not peer.udp_port:
udp_port_to_try = peer.tcp_port udp_port_to_try = peer.tcp_port
if not peer.udp_port: if not peer.udp_port:
peer.update_udp_port(udp_port_to_try) peer = make_kademlia_peer(peer.node_id, peer.address, udp_port_to_try, peer.tcp_port)
self.loop.create_task(ping(peer)) self.loop.create_task(ping(peer))
else: else:
log.debug("skip bad peer %s:%i for %s", peer.address, peer.tcp_port, blob_hash) log.debug("skip bad peer %s:%i for %s", peer.address, peer.tcp_port, blob_hash)

View file

@ -147,8 +147,8 @@ class KademliaPeer:
address: str = field(hash=True) address: str = field(hash=True)
_node_id: typing.Optional[bytes] = field(hash=True) _node_id: typing.Optional[bytes] = field(hash=True)
udp_port: typing.Optional[int] = field(hash=True) udp_port: typing.Optional[int] = field(hash=True)
tcp_port: typing.Optional[int] = field(compare=False) tcp_port: typing.Optional[int] = field(compare=False, hash=False)
protocol_version: typing.Optional[int] = field(default=1, compare=False) protocol_version: typing.Optional[int] = field(default=1, compare=False, hash=False)
def __post_init__(self): def __post_init__(self):
if self._node_id is not None: if self._node_id is not None:
@ -164,13 +164,6 @@ class KademliaPeer:
def update_tcp_port(self, tcp_port: int): def update_tcp_port(self, tcp_port: int):
self.tcp_port = tcp_port self.tcp_port = tcp_port
def update_udp_port(self, udp_port: int):
self.udp_port = udp_port
def set_id(self, node_id):
if not self._node_id:
self._node_id = node_id
@property @property
def node_id(self) -> bytes: def node_id(self) -> bytes:
return self._node_id return self._node_id

View file

@ -495,8 +495,7 @@ class KademliaProtocol(DatagramProtocol):
elif response_datagram.node_id == self.node_id: elif response_datagram.node_id == self.node_id:
df.set_exception(RemoteException("incoming message is from our node id")) df.set_exception(RemoteException("incoming message is from our node id"))
return return
peer.set_id(response_datagram.node_id) peer = make_kademlia_peer(response_datagram.node_id, address[0], address[1])
peer.update_udp_port(address[1])
self.peer_manager.report_last_replied(address[0], address[1]) self.peer_manager.report_last_replied(address[0], address[1])
self.peer_manager.update_contact_triple(peer.node_id, address[0], address[1]) self.peer_manager.update_contact_triple(peer.node_id, address[0], address[1])
if not df.cancelled(): if not df.cancelled():