2018-11-28 13:51:50 -05:00
|
|
|
from abc import ABC, abstractmethod
|
2019-08-07 18:02:30 +08:00
|
|
|
from typing import Sequence
|
|
|
|
|
|
|
|
from libp2p.stream_muxer.abc import IMuxedStream
|
|
|
|
from libp2p.typing import TProtocol
|
2018-11-28 13:51:50 -05:00
|
|
|
|
2019-01-09 21:38:56 +03:00
|
|
|
|
2018-11-28 13:51:50 -05:00
|
|
|
class IMultiselectClient(ABC):
|
|
|
|
"""
|
|
|
|
Client for communicating with receiver's multiselect
|
|
|
|
module in order to select a protocol id to communicate over
|
|
|
|
"""
|
|
|
|
|
|
|
|
@abstractmethod
|
2019-08-13 14:36:42 -07:00
|
|
|
async def select_protocol_or_fail(
|
|
|
|
self, protocol: TProtocol, stream: IMuxedStream
|
|
|
|
) -> TProtocol:
|
2018-11-28 13:51:50 -05:00
|
|
|
"""
|
|
|
|
Send message to multiselect selecting protocol
|
|
|
|
and fail if multiselect does not return same protocol
|
|
|
|
:param protocol: protocol to select
|
|
|
|
:param stream: stream to communicate with multiselect over
|
|
|
|
:return: selected protocol
|
|
|
|
"""
|
|
|
|
|
|
|
|
@abstractmethod
|
2019-08-07 18:02:30 +08:00
|
|
|
async def select_one_of(
|
|
|
|
self, protocols: Sequence[TProtocol], stream: IMuxedStream
|
|
|
|
) -> TProtocol:
|
2018-11-28 13:51:50 -05:00
|
|
|
"""
|
|
|
|
For each protocol, send message to multiselect selecting protocol
|
|
|
|
and fail if multiselect does not return same protocol. Returns first
|
|
|
|
protocol that multiselect agrees on (i.e. that multiselect selects)
|
|
|
|
:param protocol: protocol to select
|
|
|
|
:param stream: stream to communicate with multiselect over
|
|
|
|
:return: selected protocol
|
|
|
|
"""
|