2018-11-29 16:06:40 +01:00
|
|
|
import multiaddr
|
|
|
|
import multiaddr.util
|
2019-01-09 21:38:56 +03:00
|
|
|
|
|
|
|
from .id import id_b58_decode
|
|
|
|
from .peerdata import PeerData
|
2018-11-29 16:06:40 +01:00
|
|
|
|
|
|
|
|
2018-10-29 14:09:47 +01:00
|
|
|
class PeerInfo:
|
2019-01-09 21:38:56 +03:00
|
|
|
# pylint: disable=too-few-public-methods
|
2019-04-19 16:29:15 -04:00
|
|
|
def __init__(self, peer_id, peer_data=None):
|
2018-10-29 14:09:47 +01:00
|
|
|
self.peer_id = peer_id
|
2019-04-19 16:29:15 -04:00
|
|
|
self.addrs = peer_data.get_addrs() if peer_data else None
|
2018-11-29 16:06:40 +01:00
|
|
|
|
|
|
|
|
|
|
|
def info_from_p2p_addr(addr):
|
|
|
|
if not addr:
|
|
|
|
raise InvalidAddrError()
|
|
|
|
|
|
|
|
parts = multiaddr.util.split(addr)
|
|
|
|
if not parts:
|
|
|
|
raise InvalidAddrError()
|
|
|
|
|
2018-12-28 02:01:50 -05:00
|
|
|
p2p_part = parts[-1]
|
|
|
|
if p2p_part.protocols()[0].code != multiaddr.protocols.P_P2P:
|
2018-11-29 16:06:40 +01:00
|
|
|
raise InvalidAddrError()
|
|
|
|
|
2018-12-28 01:56:00 -05:00
|
|
|
# make sure the /p2p value parses as a peer.ID
|
2018-12-28 02:01:50 -05:00
|
|
|
peer_id_str = p2p_part.value_for_protocol(multiaddr.protocols.P_P2P)
|
2018-11-29 16:06:40 +01:00
|
|
|
peer_id = id_b58_decode(peer_id_str)
|
|
|
|
|
2018-12-28 01:56:00 -05:00
|
|
|
# we might have received just an / p2p part, which means there's no addr.
|
2018-11-29 16:06:40 +01:00
|
|
|
if len(parts) > 1:
|
|
|
|
addr = multiaddr.util.join(parts[:-1])
|
|
|
|
|
|
|
|
peer_data = PeerData()
|
|
|
|
peer_data.addrs = [addr]
|
|
|
|
peer_data.protocols = [p.code for p in addr.protocols()]
|
|
|
|
|
|
|
|
return PeerInfo(peer_id, peer_data)
|
|
|
|
|
|
|
|
|
|
|
|
class InvalidAddrError(ValueError):
|
|
|
|
pass
|