Change IMuxedConn
to INetConn
in Notifee
This commit is contained in:
parent
0356380996
commit
5307c0506b
|
@ -77,7 +77,7 @@ class SwarmConn(INetConn):
|
||||||
|
|
||||||
async def _notify_disconnected(self) -> None:
|
async def _notify_disconnected(self) -> None:
|
||||||
for notifee in self.swarm.notifees:
|
for notifee in self.swarm.notifees:
|
||||||
await notifee.disconnected(self.swarm, self.conn)
|
await notifee.disconnected(self.swarm, self)
|
||||||
|
|
||||||
async def start(self) -> None:
|
async def start(self) -> None:
|
||||||
await self.run_task(self._handle_new_streams())
|
await self.run_task(self._handle_new_streams())
|
||||||
|
|
|
@ -3,8 +3,8 @@ from typing import TYPE_CHECKING
|
||||||
|
|
||||||
from multiaddr import Multiaddr
|
from multiaddr import Multiaddr
|
||||||
|
|
||||||
|
from libp2p.network.connection.net_connection_interface import INetConn
|
||||||
from libp2p.network.stream.net_stream_interface import INetStream
|
from libp2p.network.stream.net_stream_interface import INetStream
|
||||||
from libp2p.stream_muxer.abc import IMuxedConn
|
|
||||||
|
|
||||||
if TYPE_CHECKING:
|
if TYPE_CHECKING:
|
||||||
from .network_interface import INetwork # noqa: F401
|
from .network_interface import INetwork # noqa: F401
|
||||||
|
@ -26,14 +26,14 @@ class INotifee(ABC):
|
||||||
"""
|
"""
|
||||||
|
|
||||||
@abstractmethod
|
@abstractmethod
|
||||||
async def connected(self, network: "INetwork", conn: IMuxedConn) -> None:
|
async def connected(self, network: "INetwork", conn: INetConn) -> None:
|
||||||
"""
|
"""
|
||||||
:param network: network the connection was opened on
|
:param network: network the connection was opened on
|
||||||
:param conn: connection that was opened
|
:param conn: connection that was opened
|
||||||
"""
|
"""
|
||||||
|
|
||||||
@abstractmethod
|
@abstractmethod
|
||||||
async def disconnected(self, network: "INetwork", conn: IMuxedConn) -> None:
|
async def disconnected(self, network: "INetwork", conn: INetConn) -> None:
|
||||||
"""
|
"""
|
||||||
:param network: network the connection was closed on
|
:param network: network the connection was closed on
|
||||||
:param conn: connection that was closed
|
:param conn: connection that was closed
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
from libp2p.stream_muxer.abc import IMuxedConn, IMuxedStream
|
from libp2p.stream_muxer.abc import IMuxedStream
|
||||||
from libp2p.stream_muxer.exceptions import (
|
from libp2p.stream_muxer.exceptions import (
|
||||||
MuxedStreamClosed,
|
MuxedStreamClosed,
|
||||||
MuxedStreamEOF,
|
MuxedStreamEOF,
|
||||||
|
@ -16,13 +16,11 @@ from .net_stream_interface import INetStream
|
||||||
class NetStream(INetStream):
|
class NetStream(INetStream):
|
||||||
|
|
||||||
muxed_stream: IMuxedStream
|
muxed_stream: IMuxedStream
|
||||||
# TODO: Why we expose `mplex_conn` here?
|
|
||||||
mplex_conn: IMuxedConn
|
|
||||||
protocol_id: TProtocol
|
protocol_id: TProtocol
|
||||||
|
|
||||||
def __init__(self, muxed_stream: IMuxedStream) -> None:
|
def __init__(self, muxed_stream: IMuxedStream) -> None:
|
||||||
self.muxed_stream = muxed_stream
|
self.muxed_stream = muxed_stream
|
||||||
self.mplex_conn = muxed_stream.mplex_conn
|
self.muxed_conn = muxed_stream.muxed_conn
|
||||||
self.protocol_id = None
|
self.protocol_id = None
|
||||||
|
|
||||||
def get_protocol(self) -> TProtocol:
|
def get_protocol(self) -> TProtocol:
|
||||||
|
|
|
@ -7,7 +7,7 @@ from libp2p.typing import TProtocol
|
||||||
|
|
||||||
class INetStream(ReadWriteCloser):
|
class INetStream(ReadWriteCloser):
|
||||||
|
|
||||||
mplex_conn: IMuxedConn
|
muxed_conn: IMuxedConn
|
||||||
|
|
||||||
@abstractmethod
|
@abstractmethod
|
||||||
def get_protocol(self) -> TProtocol:
|
def get_protocol(self) -> TProtocol:
|
||||||
|
|
|
@ -278,8 +278,7 @@ class Swarm(INetwork):
|
||||||
self.connections[muxed_conn.peer_id] = swarm_conn
|
self.connections[muxed_conn.peer_id] = swarm_conn
|
||||||
# Call notifiers since event occurred
|
# Call notifiers since event occurred
|
||||||
for notifee in self.notifees:
|
for notifee in self.notifees:
|
||||||
# TODO: Call with other type of conn?
|
await notifee.connected(self, swarm_conn)
|
||||||
await notifee.connected(self, muxed_conn)
|
|
||||||
await swarm_conn.start()
|
await swarm_conn.start()
|
||||||
return swarm_conn
|
return swarm_conn
|
||||||
|
|
||||||
|
|
|
@ -151,7 +151,7 @@ class Pubsub:
|
||||||
messages from other nodes
|
messages from other nodes
|
||||||
:param stream: stream to continously read from
|
:param stream: stream to continously read from
|
||||||
"""
|
"""
|
||||||
peer_id = stream.mplex_conn.peer_id
|
peer_id = stream.muxed_conn.peer_id
|
||||||
|
|
||||||
while True:
|
while True:
|
||||||
incoming: bytes = await read_varint_prefixed_bytes(stream)
|
incoming: bytes = await read_varint_prefixed_bytes(stream)
|
||||||
|
|
|
@ -2,10 +2,10 @@ from typing import TYPE_CHECKING
|
||||||
|
|
||||||
from multiaddr import Multiaddr
|
from multiaddr import Multiaddr
|
||||||
|
|
||||||
|
from libp2p.network.connection.net_connection_interface import INetConn
|
||||||
from libp2p.network.network_interface import INetwork
|
from libp2p.network.network_interface import INetwork
|
||||||
from libp2p.network.notifee_interface import INotifee
|
from libp2p.network.notifee_interface import INotifee
|
||||||
from libp2p.network.stream.net_stream_interface import INetStream
|
from libp2p.network.stream.net_stream_interface import INetStream
|
||||||
from libp2p.stream_muxer.abc import IMuxedConn
|
|
||||||
|
|
||||||
if TYPE_CHECKING:
|
if TYPE_CHECKING:
|
||||||
import asyncio # noqa: F401
|
import asyncio # noqa: F401
|
||||||
|
@ -29,16 +29,16 @@ class PubsubNotifee(INotifee):
|
||||||
async def closed_stream(self, network: INetwork, stream: INetStream) -> None:
|
async def closed_stream(self, network: INetwork, stream: INetStream) -> None:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
async def connected(self, network: INetwork, conn: IMuxedConn) -> None:
|
async def connected(self, network: INetwork, conn: INetConn) -> None:
|
||||||
"""
|
"""
|
||||||
Add peer_id to initiator_peers_queue, so that this peer_id can be used to
|
Add peer_id to initiator_peers_queue, so that this peer_id can be used to
|
||||||
create a stream and we only want to have one pubsub stream with each peer.
|
create a stream and we only want to have one pubsub stream with each peer.
|
||||||
:param network: network the connection was opened on
|
:param network: network the connection was opened on
|
||||||
:param conn: connection that was opened
|
:param conn: connection that was opened
|
||||||
"""
|
"""
|
||||||
await self.initiator_peers_queue.put(conn.peer_id)
|
await self.initiator_peers_queue.put(conn.conn.peer_id)
|
||||||
|
|
||||||
async def disconnected(self, network: INetwork, conn: IMuxedConn) -> None:
|
async def disconnected(self, network: INetwork, conn: INetConn) -> None:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
async def listen(self, network: INetwork, multiaddr: Multiaddr) -> None:
|
async def listen(self, network: INetwork, multiaddr: Multiaddr) -> None:
|
||||||
|
|
|
@ -55,7 +55,7 @@ class IMuxedConn(ABC):
|
||||||
|
|
||||||
class IMuxedStream(ReadWriteCloser):
|
class IMuxedStream(ReadWriteCloser):
|
||||||
|
|
||||||
mplex_conn: IMuxedConn
|
muxed_conn: IMuxedConn
|
||||||
|
|
||||||
@abstractmethod
|
@abstractmethod
|
||||||
async def reset(self) -> None:
|
async def reset(self) -> None:
|
||||||
|
|
|
@ -18,7 +18,7 @@ class MplexStream(IMuxedStream):
|
||||||
|
|
||||||
name: str
|
name: str
|
||||||
stream_id: StreamID
|
stream_id: StreamID
|
||||||
mplex_conn: "Mplex"
|
muxed_conn: "Mplex"
|
||||||
read_deadline: int
|
read_deadline: int
|
||||||
write_deadline: int
|
write_deadline: int
|
||||||
|
|
||||||
|
@ -32,15 +32,15 @@ class MplexStream(IMuxedStream):
|
||||||
|
|
||||||
_buf: bytearray
|
_buf: bytearray
|
||||||
|
|
||||||
def __init__(self, name: str, stream_id: StreamID, mplex_conn: "Mplex") -> None:
|
def __init__(self, name: str, stream_id: StreamID, muxed_conn: "Mplex") -> None:
|
||||||
"""
|
"""
|
||||||
create new MuxedStream in muxer
|
create new MuxedStream in muxer
|
||||||
:param stream_id: stream id of this stream
|
:param stream_id: stream id of this stream
|
||||||
:param mplex_conn: muxed connection of this muxed_stream
|
:param muxed_conn: muxed connection of this muxed_stream
|
||||||
"""
|
"""
|
||||||
self.name = name
|
self.name = name
|
||||||
self.stream_id = stream_id
|
self.stream_id = stream_id
|
||||||
self.mplex_conn = mplex_conn
|
self.muxed_conn = muxed_conn
|
||||||
self.read_deadline = None
|
self.read_deadline = None
|
||||||
self.write_deadline = None
|
self.write_deadline = None
|
||||||
self.event_local_closed = asyncio.Event()
|
self.event_local_closed = asyncio.Event()
|
||||||
|
@ -147,7 +147,7 @@ class MplexStream(IMuxedStream):
|
||||||
if self.is_initiator
|
if self.is_initiator
|
||||||
else HeaderTags.MessageReceiver
|
else HeaderTags.MessageReceiver
|
||||||
)
|
)
|
||||||
return await self.mplex_conn.send_message(flag, data, self.stream_id)
|
return await self.muxed_conn.send_message(flag, data, self.stream_id)
|
||||||
|
|
||||||
async def close(self) -> None:
|
async def close(self) -> None:
|
||||||
"""
|
"""
|
||||||
|
@ -163,8 +163,8 @@ class MplexStream(IMuxedStream):
|
||||||
flag = (
|
flag = (
|
||||||
HeaderTags.CloseInitiator if self.is_initiator else HeaderTags.CloseReceiver
|
HeaderTags.CloseInitiator if self.is_initiator else HeaderTags.CloseReceiver
|
||||||
)
|
)
|
||||||
# TODO: Raise when `mplex_conn.send_message` fails and `Mplex` isn't shutdown.
|
# TODO: Raise when `muxed_conn.send_message` fails and `Mplex` isn't shutdown.
|
||||||
await self.mplex_conn.send_message(flag, None, self.stream_id)
|
await self.muxed_conn.send_message(flag, None, self.stream_id)
|
||||||
|
|
||||||
_is_remote_closed: bool
|
_is_remote_closed: bool
|
||||||
async with self.close_lock:
|
async with self.close_lock:
|
||||||
|
@ -173,8 +173,8 @@ class MplexStream(IMuxedStream):
|
||||||
|
|
||||||
if _is_remote_closed:
|
if _is_remote_closed:
|
||||||
# Both sides are closed, we can safely remove the buffer from the dict.
|
# Both sides are closed, we can safely remove the buffer from the dict.
|
||||||
async with self.mplex_conn.streams_lock:
|
async with self.muxed_conn.streams_lock:
|
||||||
del self.mplex_conn.streams[self.stream_id]
|
del self.muxed_conn.streams[self.stream_id]
|
||||||
|
|
||||||
async def reset(self) -> None:
|
async def reset(self) -> None:
|
||||||
"""
|
"""
|
||||||
|
@ -196,19 +196,19 @@ class MplexStream(IMuxedStream):
|
||||||
else HeaderTags.ResetReceiver
|
else HeaderTags.ResetReceiver
|
||||||
)
|
)
|
||||||
asyncio.ensure_future(
|
asyncio.ensure_future(
|
||||||
self.mplex_conn.send_message(flag, None, self.stream_id)
|
self.muxed_conn.send_message(flag, None, self.stream_id)
|
||||||
)
|
)
|
||||||
await asyncio.sleep(0)
|
await asyncio.sleep(0)
|
||||||
|
|
||||||
self.event_local_closed.set()
|
self.event_local_closed.set()
|
||||||
self.event_remote_closed.set()
|
self.event_remote_closed.set()
|
||||||
|
|
||||||
async with self.mplex_conn.streams_lock:
|
async with self.muxed_conn.streams_lock:
|
||||||
if (
|
if (
|
||||||
self.mplex_conn.streams is not None
|
self.muxed_conn.streams is not None
|
||||||
and self.stream_id in self.mplex_conn.streams
|
and self.stream_id in self.muxed_conn.streams
|
||||||
):
|
):
|
||||||
del self.mplex_conn.streams[self.stream_id]
|
del self.muxed_conn.streams[self.stream_id]
|
||||||
|
|
||||||
# TODO deadline not in use
|
# TODO deadline not in use
|
||||||
def set_deadline(self, ttl: int) -> bool:
|
def set_deadline(self, ttl: int) -> bool:
|
||||||
|
|
|
@ -34,7 +34,7 @@ class MyNotifee(INotifee):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
async def connected(self, network, conn):
|
async def connected(self, network, conn):
|
||||||
self.events.append(["connected" + self.val_to_append_to_event, conn])
|
self.events.append(["connected" + self.val_to_append_to_event, conn.conn])
|
||||||
|
|
||||||
async def disconnected(self, network, conn):
|
async def disconnected(self, network, conn):
|
||||||
pass
|
pass
|
||||||
|
@ -79,7 +79,7 @@ async def test_one_notifier():
|
||||||
# Ensure the connected and opened_stream events were hit in MyNotifee obj
|
# Ensure the connected and opened_stream events were hit in MyNotifee obj
|
||||||
# and that stream passed into opened_stream matches the stream created on
|
# and that stream passed into opened_stream matches the stream created on
|
||||||
# node_a
|
# node_a
|
||||||
assert events == [["connected0", stream.mplex_conn], ["opened_stream0", stream]]
|
assert events == [["connected0", stream.muxed_conn], ["opened_stream0", stream]]
|
||||||
|
|
||||||
messages = ["hello", "hello"]
|
messages = ["hello", "hello"]
|
||||||
for message in messages:
|
for message in messages:
|
||||||
|
@ -103,7 +103,7 @@ async def test_one_notifier_on_two_nodes():
|
||||||
# and that the stream passed into opened_stream matches the stream created on
|
# and that the stream passed into opened_stream matches the stream created on
|
||||||
# node_b
|
# node_b
|
||||||
assert events_b == [
|
assert events_b == [
|
||||||
["connectedb", stream.mplex_conn],
|
["connectedb", stream.muxed_conn],
|
||||||
["opened_streamb", stream],
|
["opened_streamb", stream],
|
||||||
]
|
]
|
||||||
for message in messages:
|
for message in messages:
|
||||||
|
@ -126,7 +126,7 @@ async def test_one_notifier_on_two_nodes():
|
||||||
# Ensure the connected and opened_stream events were hit in MyNotifee obj
|
# Ensure the connected and opened_stream events were hit in MyNotifee obj
|
||||||
# and that stream passed into opened_stream matches the stream created on
|
# and that stream passed into opened_stream matches the stream created on
|
||||||
# node_a
|
# node_a
|
||||||
assert events_a == [["connecteda", stream.mplex_conn], ["opened_streama", stream]]
|
assert events_a == [["connecteda", stream.muxed_conn], ["opened_streama", stream]]
|
||||||
|
|
||||||
for message in messages:
|
for message in messages:
|
||||||
expected_resp = ACK + message
|
expected_resp = ACK + message
|
||||||
|
@ -164,7 +164,7 @@ async def test_one_notifier_on_two_nodes_with_listen():
|
||||||
# node_b
|
# node_b
|
||||||
assert events_b == [
|
assert events_b == [
|
||||||
["listenedb", node_b_multiaddr],
|
["listenedb", node_b_multiaddr],
|
||||||
["connectedb", stream.mplex_conn],
|
["connectedb", stream.muxed_conn],
|
||||||
["opened_streamb", stream],
|
["opened_streamb", stream],
|
||||||
]
|
]
|
||||||
for message in messages:
|
for message in messages:
|
||||||
|
@ -190,7 +190,7 @@ async def test_one_notifier_on_two_nodes_with_listen():
|
||||||
# Ensure the connected and opened_stream events were hit in MyNotifee obj
|
# Ensure the connected and opened_stream events were hit in MyNotifee obj
|
||||||
# and that stream passed into opened_stream matches the stream created on
|
# and that stream passed into opened_stream matches the stream created on
|
||||||
# node_a
|
# node_a
|
||||||
assert events_a == [["connecteda", stream.mplex_conn], ["opened_streama", stream]]
|
assert events_a == [["connecteda", stream.muxed_conn], ["opened_streama", stream]]
|
||||||
|
|
||||||
for message in messages:
|
for message in messages:
|
||||||
expected_resp = ACK + message
|
expected_resp = ACK + message
|
||||||
|
@ -219,8 +219,8 @@ async def test_two_notifiers():
|
||||||
# Ensure the connected and opened_stream events were hit in both Notifee objs
|
# Ensure the connected and opened_stream events were hit in both Notifee objs
|
||||||
# and that the stream passed into opened_stream matches the stream created on
|
# and that the stream passed into opened_stream matches the stream created on
|
||||||
# node_a
|
# node_a
|
||||||
assert events0 == [["connected0", stream.mplex_conn], ["opened_stream0", stream]]
|
assert events0 == [["connected0", stream.muxed_conn], ["opened_stream0", stream]]
|
||||||
assert events1 == [["connected1", stream.mplex_conn], ["opened_stream1", stream]]
|
assert events1 == [["connected1", stream.muxed_conn], ["opened_stream1", stream]]
|
||||||
|
|
||||||
messages = ["hello", "hello"]
|
messages = ["hello", "hello"]
|
||||||
for message in messages:
|
for message in messages:
|
||||||
|
@ -253,7 +253,7 @@ async def test_ten_notifiers():
|
||||||
# node_a
|
# node_a
|
||||||
for i in range(num_notifiers):
|
for i in range(num_notifiers):
|
||||||
assert events_lst[i] == [
|
assert events_lst[i] == [
|
||||||
["connected" + str(i), stream.mplex_conn],
|
["connected" + str(i), stream.muxed_conn],
|
||||||
["opened_stream" + str(i), stream],
|
["opened_stream" + str(i), stream],
|
||||||
]
|
]
|
||||||
|
|
||||||
|
@ -280,7 +280,7 @@ async def test_ten_notifiers_on_two_nodes():
|
||||||
# node_b
|
# node_b
|
||||||
for i in range(num_notifiers):
|
for i in range(num_notifiers):
|
||||||
assert events_lst_b[i] == [
|
assert events_lst_b[i] == [
|
||||||
["connectedb" + str(i), stream.mplex_conn],
|
["connectedb" + str(i), stream.muxed_conn],
|
||||||
["opened_streamb" + str(i), stream],
|
["opened_streamb" + str(i), stream],
|
||||||
]
|
]
|
||||||
while True:
|
while True:
|
||||||
|
@ -306,7 +306,7 @@ async def test_ten_notifiers_on_two_nodes():
|
||||||
# node_a
|
# node_a
|
||||||
for i in range(num_notifiers):
|
for i in range(num_notifiers):
|
||||||
assert events_lst_a[i] == [
|
assert events_lst_a[i] == [
|
||||||
["connecteda" + str(i), stream.mplex_conn],
|
["connecteda" + str(i), stream.muxed_conn],
|
||||||
["opened_streama" + str(i), stream],
|
["opened_streama" + str(i), stream],
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
|
@ -233,7 +233,7 @@ class FakeNetStream:
|
||||||
class FakeMplexConn(NamedTuple):
|
class FakeMplexConn(NamedTuple):
|
||||||
peer_id: ID = ID(b"\x12\x20" + b"\x00" * 32)
|
peer_id: ID = ID(b"\x12\x20" + b"\x00" * 32)
|
||||||
|
|
||||||
mplex_conn = FakeMplexConn()
|
muxed_conn = FakeMplexConn()
|
||||||
|
|
||||||
def __init__(self) -> None:
|
def __init__(self) -> None:
|
||||||
self._queue = asyncio.Queue()
|
self._queue = asyncio.Queue()
|
||||||
|
|
Loading…
Reference in New Issue
Block a user