2018-11-01 05:31:00 +08:00
|
|
|
from abc import ABC, abstractmethod
|
|
|
|
|
2018-11-12 07:03:04 +08:00
|
|
|
|
2018-11-01 05:31:00 +08:00
|
|
|
class IMuxedConn(ABC):
|
|
|
|
"""
|
|
|
|
reference: https://github.com/libp2p/go-stream-muxer/blob/master/muxer.go
|
|
|
|
"""
|
|
|
|
|
2018-11-12 07:03:04 +08:00
|
|
|
@abstractmethod
|
|
|
|
def close(self):
|
|
|
|
"""
|
|
|
|
close connection
|
|
|
|
:return: true if successful
|
|
|
|
"""
|
2018-11-01 05:31:00 +08:00
|
|
|
|
|
|
|
@abstractmethod
|
|
|
|
def is_closed(self):
|
|
|
|
"""
|
|
|
|
check connection is fully closed
|
|
|
|
:return: true if successful
|
|
|
|
"""
|
|
|
|
|
|
|
|
@abstractmethod
|
2018-11-26 04:27:54 +08:00
|
|
|
def open_stream(self, protocol_id, peer_id, multi_addr):
|
2018-11-01 05:31:00 +08:00
|
|
|
"""
|
|
|
|
creates a new muxed_stream
|
2018-11-13 02:02:49 +08:00
|
|
|
:param protocol_id: protocol_id of stream
|
|
|
|
:param stream_id: stream_id of stream
|
|
|
|
:param peer_id: peer_id that stream connects to
|
|
|
|
:param multi_addr: multi_addr that stream connects to
|
2018-11-01 05:31:00 +08:00
|
|
|
:return: a new stream
|
|
|
|
"""
|
|
|
|
|
|
|
|
@abstractmethod
|
|
|
|
def accept_stream(self):
|
|
|
|
"""
|
|
|
|
accepts a muxed stream opened by the other end
|
|
|
|
:return: the accepted stream
|
|
|
|
"""
|