mirror of
https://github.com/varun-r-mallya/py-libp2p.git
synced 2026-02-12 16:10:57 +00:00
Fix the error due to the breaking change
In multiaddr, `split` is moved to `Multiaddr`'s method.
This commit is contained in:
@ -1,5 +1,4 @@
|
|||||||
import multiaddr
|
import multiaddr
|
||||||
import multiaddr.util
|
|
||||||
|
|
||||||
from .id import id_b58_decode
|
from .id import id_b58_decode
|
||||||
from .peerdata import PeerData
|
from .peerdata import PeerData
|
||||||
@ -12,17 +11,23 @@ class PeerInfo:
|
|||||||
self.addrs = peer_data.get_addrs() if peer_data else None
|
self.addrs = peer_data.get_addrs() if peer_data else None
|
||||||
|
|
||||||
|
|
||||||
def info_from_p2p_addr(addr):
|
def info_from_p2p_addr(addr: multiaddr.Multiaddr) -> PeerInfo:
|
||||||
if not addr:
|
if not addr:
|
||||||
raise InvalidAddrError()
|
raise InvalidAddrError("addr should not be None")
|
||||||
|
|
||||||
parts = multiaddr.util.split(addr)
|
if not isinstance(addr, multiaddr.Multiaddr):
|
||||||
|
raise InvalidAddrError(f"addr={addr} should be in type Multiaddr")
|
||||||
|
|
||||||
|
parts = addr.split()
|
||||||
if not parts:
|
if not parts:
|
||||||
raise InvalidAddrError()
|
raise InvalidAddrError()
|
||||||
|
|
||||||
p2p_part = parts[-1]
|
p2p_part = parts[-1]
|
||||||
if p2p_part.protocols()[0].code != multiaddr.protocols.P_P2P:
|
last_protocol_code = p2p_part.protocols()[0].code
|
||||||
raise InvalidAddrError()
|
if last_protocol_code != multiaddr.protocols.P_P2P:
|
||||||
|
raise InvalidAddrError(
|
||||||
|
f"the last protocol should be P_P2P instead of {last_protocol_code}"
|
||||||
|
)
|
||||||
|
|
||||||
# make sure the /p2p value parses as a peer.ID
|
# make sure the /p2p value parses as a peer.ID
|
||||||
peer_id_str = p2p_part.value_for_protocol(multiaddr.protocols.P_P2P)
|
peer_id_str = p2p_part.value_for_protocol(multiaddr.protocols.P_P2P)
|
||||||
@ -30,7 +35,7 @@ def info_from_p2p_addr(addr):
|
|||||||
|
|
||||||
# we might have received just an / p2p part, which means there's no addr.
|
# we might have received just an / p2p part, which means there's no addr.
|
||||||
if len(parts) > 1:
|
if len(parts) > 1:
|
||||||
addr = multiaddr.util.join(parts[:-1])
|
addr = multiaddr.Multiaddr.join(*parts[:-1])
|
||||||
|
|
||||||
peer_data = PeerData()
|
peer_data = PeerData()
|
||||||
peer_data.addrs = [addr]
|
peer_data.addrs = [addr]
|
||||||
|
|||||||
@ -27,13 +27,11 @@ class TCP(ITransport):
|
|||||||
:param maddr: maddr of peer
|
:param maddr: maddr of peer
|
||||||
:return: return True if successful
|
:return: return True if successful
|
||||||
"""
|
"""
|
||||||
_multiaddr = maddr
|
self.server = await asyncio.start_server(
|
||||||
_multiaddr = _multiaddr.decapsulate('/p2p')
|
self.handler,
|
||||||
|
maddr.value_for_protocol('ip4'),
|
||||||
coroutine = asyncio.start_server(self.handler,
|
maddr.value_for_protocol('tcp'),
|
||||||
_multiaddr.value_for_protocol('ip4'),
|
)
|
||||||
_multiaddr.value_for_protocol('tcp'))
|
|
||||||
self.server = await coroutine
|
|
||||||
socket = self.server.sockets[0]
|
socket = self.server.sockets[0]
|
||||||
self.multiaddrs.append(_multiaddr_from_socket(socket))
|
self.multiaddrs.append(_multiaddr_from_socket(socket))
|
||||||
|
|
||||||
|
|||||||
@ -22,7 +22,7 @@ def test_init_():
|
|||||||
|
|
||||||
def test_init_no_value():
|
def test_init_no_value():
|
||||||
with pytest.raises(Exception) as _:
|
with pytest.raises(Exception) as _:
|
||||||
#pylint: disable=no-value-for-parameter
|
# pylint: disable=no-value-for-parameter
|
||||||
PeerInfo()
|
PeerInfo()
|
||||||
|
|
||||||
def test_invalid_addr_1():
|
def test_invalid_addr_1():
|
||||||
@ -30,10 +30,10 @@ def test_invalid_addr_1():
|
|||||||
info_from_p2p_addr(None)
|
info_from_p2p_addr(None)
|
||||||
|
|
||||||
def test_invalid_addr_2(monkeypatch):
|
def test_invalid_addr_2(monkeypatch):
|
||||||
random_addrs = [random.randint(0, 255) for r in range(4)]
|
random_addr = random.randint(0, 255)
|
||||||
monkeypatch.setattr("multiaddr.util.split", lambda x: None)
|
monkeypatch.setattr("multiaddr.Multiaddr.split", lambda x: None)
|
||||||
with pytest.raises(InvalidAddrError):
|
with pytest.raises(InvalidAddrError):
|
||||||
info_from_p2p_addr(random_addrs)
|
info_from_p2p_addr(random_addr)
|
||||||
|
|
||||||
def test_info_from_p2p_addr():
|
def test_info_from_p2p_addr():
|
||||||
# pylint: disable=line-too-long
|
# pylint: disable=line-too-long
|
||||||
|
|||||||
Reference in New Issue
Block a user