2018-10-31 22:31:00 +01:00
|
|
|
from abc import ABC, abstractmethod
|
|
|
|
|
2018-11-11 18:03:04 -05:00
|
|
|
|
2018-10-31 22:31:00 +01:00
|
|
|
class IMuxedConn(ABC):
|
|
|
|
"""
|
|
|
|
reference: https://github.com/libp2p/go-stream-muxer/blob/master/muxer.go
|
|
|
|
"""
|
|
|
|
|
2019-02-24 20:58:23 -05:00
|
|
|
@abstractmethod
|
2019-03-23 13:52:02 -04:00
|
|
|
def __init__(self, conn, generic_protocol_handler, peer_id):
|
2019-02-24 20:58:23 -05:00
|
|
|
"""
|
|
|
|
create a new muxed connection
|
2019-04-30 03:09:05 -04:00
|
|
|
:param conn: an instance of secured connection
|
2019-02-24 20:58:23 -05:00
|
|
|
:param generic_protocol_handler: generic protocol handler
|
|
|
|
for new muxed streams
|
2019-03-23 13:52:02 -04:00
|
|
|
:param peer_id: peer_id of peer the connection is to
|
2019-02-24 20:58:23 -05:00
|
|
|
"""
|
|
|
|
|
2018-11-11 18:03:04 -05:00
|
|
|
@abstractmethod
|
|
|
|
def close(self):
|
|
|
|
"""
|
|
|
|
close connection
|
|
|
|
:return: true if successful
|
|
|
|
"""
|
2018-10-31 22:31:00 +01:00
|
|
|
|
|
|
|
@abstractmethod
|
|
|
|
def is_closed(self):
|
|
|
|
"""
|
|
|
|
check connection is fully closed
|
|
|
|
:return: true if successful
|
|
|
|
"""
|
|
|
|
|
|
|
|
@abstractmethod
|
2019-02-24 20:58:23 -05:00
|
|
|
def open_stream(self, protocol_id, multi_addr):
|
2018-10-31 22:31:00 +01:00
|
|
|
"""
|
|
|
|
creates a new muxed_stream
|
2018-11-12 13:02:49 -05:00
|
|
|
:param protocol_id: protocol_id of stream
|
|
|
|
:param multi_addr: multi_addr that stream connects to
|
2018-10-31 22:31:00 +01:00
|
|
|
:return: a new stream
|
|
|
|
"""
|
|
|
|
|
|
|
|
@abstractmethod
|
|
|
|
def accept_stream(self):
|
|
|
|
"""
|
|
|
|
accepts a muxed stream opened by the other end
|
|
|
|
:return: the accepted stream
|
|
|
|
"""
|