py-libp2p/libp2p/stream_muxer/muxed_stream_interface.py

52 lines
985 B
Python
Raw Normal View History

2019-07-30 17:31:08 +08:00
from abc import (
ABC,
abstractmethod,
)
from typing import (
TYPE_CHECKING,
)
2018-11-12 07:03:04 +08:00
2019-07-30 17:31:08 +08:00
if TYPE_CHECKING:
from libp2p.stream_muxer.mplex.mplex import Mplex
2019-07-30 15:31:02 +08:00
2019-01-10 02:38:56 +08:00
2018-11-01 05:31:00 +08:00
class IMuxedStream(ABC):
2019-07-30 17:31:08 +08:00
mplex_conn: 'Mplex'
2019-07-30 15:31:02 +08:00
2018-11-12 07:03:04 +08:00
@abstractmethod
def read(self):
"""
reads from the underlying muxed_conn
2018-11-12 07:03:04 +08:00
:return: bytes of input
"""
@abstractmethod
def write(self, _bytes):
"""
writes to the underlying muxed_conn
2018-11-12 07:03:04 +08:00
:return: number of bytes written
"""
@abstractmethod
def close(self):
"""
close the underlying muxed_conn
2018-11-12 07:03:04 +08:00
:return: true if successful
"""
2018-11-01 05:31:00 +08:00
@abstractmethod
def reset(self):
"""
closes both ends of the stream
tells this remote side to hang up
:return: error/exception
"""
@abstractmethod
def set_deadline(self, ttl):
"""
set deadline for muxed stream
:return: a new stream
"""