2019-08-15 23:31:26 +08:00
|
|
|
from libp2p.network.connection.raw_connection_interface import IRawConnection
|
|
|
|
from libp2p.stream_muxer.abc import IMuxedStream
|
|
|
|
from libp2p.stream_muxer.mplex.utils import decode_uvarint_from_stream, encode_uvarint
|
|
|
|
from libp2p.typing import StreamReader
|
2019-08-07 18:02:30 +08:00
|
|
|
|
2018-11-28 13:51:50 -05:00
|
|
|
from .multiselect_communicator_interface import IMultiselectCommunicator
|
|
|
|
|
2019-01-09 21:38:56 +03:00
|
|
|
|
2019-08-15 23:31:26 +08:00
|
|
|
def delim_encode(msg_str: str) -> bytes:
|
|
|
|
msg_bytes = msg_str.encode()
|
|
|
|
varint_len_msg = encode_uvarint(len(msg_bytes) + 1)
|
|
|
|
return varint_len_msg + msg_bytes + b"\n"
|
2019-01-09 21:38:56 +03:00
|
|
|
|
2019-08-07 18:02:30 +08:00
|
|
|
|
2019-08-15 23:31:26 +08:00
|
|
|
async def delim_read(reader: StreamReader, timeout: int = 10) -> str:
|
|
|
|
len_msg = await decode_uvarint_from_stream(reader, timeout)
|
|
|
|
msg_bytes = await reader.read(len_msg)
|
|
|
|
return msg_bytes.decode().rstrip()
|
|
|
|
|
|
|
|
|
|
|
|
class RawConnectionCommunicator(IMultiselectCommunicator):
|
|
|
|
conn: IRawConnection
|
|
|
|
|
|
|
|
def __init__(self, conn: IRawConnection) -> None:
|
|
|
|
self.conn = conn
|
|
|
|
|
|
|
|
async def write(self, msg_str: str) -> None:
|
|
|
|
msg_bytes = delim_encode(msg_str)
|
|
|
|
self.conn.writer.write(msg_bytes)
|
|
|
|
await self.conn.writer.drain()
|
|
|
|
|
|
|
|
async def read(self) -> str:
|
|
|
|
return await delim_read(self.conn.reader)
|
|
|
|
|
|
|
|
|
|
|
|
class StreamCommunicator(IMultiselectCommunicator):
|
|
|
|
stream: IMuxedStream
|
|
|
|
|
|
|
|
def __init__(self, stream: IMuxedStream) -> None:
|
|
|
|
self.stream = stream
|
2018-11-28 13:51:50 -05:00
|
|
|
|
2019-08-07 18:02:30 +08:00
|
|
|
async def write(self, msg_str: str) -> None:
|
2019-08-15 23:31:26 +08:00
|
|
|
msg_bytes = delim_encode(msg_str)
|
|
|
|
await self.stream.write(msg_bytes)
|
|
|
|
|
|
|
|
async def read(self) -> str:
|
|
|
|
return await delim_read(self.stream)
|