2019-08-07 18:02:30 +08:00
|
|
|
from libp2p.stream_muxer.abc import IMuxedStream
|
|
|
|
|
2018-11-29 02:51:50 +08:00
|
|
|
from .multiselect_communicator_interface import IMultiselectCommunicator
|
|
|
|
|
2019-01-10 02:38:56 +08:00
|
|
|
|
2018-11-29 02:51:50 +08:00
|
|
|
class MultiselectCommunicator(IMultiselectCommunicator):
|
|
|
|
"""
|
|
|
|
Communicator helper class that ensures both the client
|
|
|
|
and multistream module will follow the same multistream protocol,
|
|
|
|
which is necessary for them to work
|
|
|
|
"""
|
2019-01-10 02:38:56 +08:00
|
|
|
|
2019-08-07 18:02:30 +08:00
|
|
|
reader_writer: IMuxedStream
|
|
|
|
|
|
|
|
def __init__(self, reader_writer: IMuxedStream) -> None:
|
2019-05-07 13:31:54 +08:00
|
|
|
"""
|
|
|
|
MultistreamCommunicator expects a reader_writer object that has
|
|
|
|
an async read and an async write function (this could be a stream,
|
|
|
|
raw connection, or other object implementing those functions)
|
|
|
|
"""
|
|
|
|
self.reader_writer = reader_writer
|
2018-11-29 02:51:50 +08:00
|
|
|
|
2019-08-07 18:02:30 +08:00
|
|
|
async def write(self, msg_str: str) -> None:
|
2018-11-29 02:51:50 +08:00
|
|
|
"""
|
2019-05-07 13:31:54 +08:00
|
|
|
Write message to reader_writer
|
2018-11-29 02:51:50 +08:00
|
|
|
:param msg_str: message to write
|
|
|
|
"""
|
2019-05-07 13:31:54 +08:00
|
|
|
await self.reader_writer.write(msg_str.encode())
|
2018-11-29 02:51:50 +08:00
|
|
|
|
2019-08-07 18:02:30 +08:00
|
|
|
async def read_stream_until_eof(self) -> str:
|
2018-11-29 02:51:50 +08:00
|
|
|
"""
|
2019-05-07 13:31:54 +08:00
|
|
|
Reads message from reader_writer until EOF
|
2018-11-29 02:51:50 +08:00
|
|
|
"""
|
2019-05-07 13:31:54 +08:00
|
|
|
read_str = (await self.reader_writer.read()).decode()
|
2018-11-29 02:51:50 +08:00
|
|
|
return read_str
|