Struct libp2p::swarm::protocols_handler::multi::MultiHandler    [−][src]
pub struct MultiHandler<K, H> { /* fields omitted */ }Expand description
A ProtocolsHandler for multiple ProtocolsHandlers of the same type.
Implementations
pub fn try_from_iter<I>(
    iter: I
) -> Result<MultiHandler<K, H>, DuplicateProtonameError> where
    I: IntoIterator<Item = (K, H)>, [src]
pub fn try_from_iter<I>(
    iter: I
) -> Result<MultiHandler<K, H>, DuplicateProtonameError> where
    I: IntoIterator<Item = (K, H)>, [src]Create and populate a MultiHandler from the given handler iterator.
It is an error for any two protocols handlers to share the same protocol name.
Trait Implementations
impl<K, H> ProtocolsHandler for MultiHandler<K, H> where
    K: Clone + Hash + Eq + Send + 'static,
    H: ProtocolsHandler,
    <H as ProtocolsHandler>::InboundProtocol: InboundUpgradeSend,
    <H as ProtocolsHandler>::OutboundProtocol: OutboundUpgradeSend, [src]
impl<K, H> ProtocolsHandler for MultiHandler<K, H> where
    K: Clone + Hash + Eq + Send + 'static,
    H: ProtocolsHandler,
    <H as ProtocolsHandler>::InboundProtocol: InboundUpgradeSend,
    <H as ProtocolsHandler>::OutboundProtocol: OutboundUpgradeSend, [src]type InEvent = (K, <H as ProtocolsHandler>::InEvent)
type InEvent = (K, <H as ProtocolsHandler>::InEvent)Custom event that can be received from the outside.
type OutEvent = (K, <H as ProtocolsHandler>::OutEvent)
type OutEvent = (K, <H as ProtocolsHandler>::OutEvent)Custom event that can be produced by the handler and that will be returned to the outside.
type Error = <H as ProtocolsHandler>::Error
type Error = <H as ProtocolsHandler>::ErrorThe type of errors returned by ProtocolsHandler::poll.
type InboundProtocol = Upgrade<K, <H as ProtocolsHandler>::InboundProtocol>
type InboundProtocol = Upgrade<K, <H as ProtocolsHandler>::InboundProtocol>The inbound upgrade for the protocol(s) used by the handler.
type OutboundProtocol = <H as ProtocolsHandler>::OutboundProtocol
type OutboundProtocol = <H as ProtocolsHandler>::OutboundProtocolThe outbound upgrade for the protocol(s) used by the handler.
type InboundOpenInfo = Info<K, <H as ProtocolsHandler>::InboundOpenInfo>
type InboundOpenInfo = Info<K, <H as ProtocolsHandler>::InboundOpenInfo>The type of additional information returned from listen_protocol.
type OutboundOpenInfo = (K, <H as ProtocolsHandler>::OutboundOpenInfo)
type OutboundOpenInfo = (K, <H as ProtocolsHandler>::OutboundOpenInfo)The type of additional information passed to an OutboundSubstreamRequest.
pub fn listen_protocol(
    &self
) -> SubstreamProtocol<<MultiHandler<K, H> as ProtocolsHandler>::InboundProtocol, <MultiHandler<K, H> as ProtocolsHandler>::InboundOpenInfo>[src]
pub fn listen_protocol(
    &self
) -> SubstreamProtocol<<MultiHandler<K, H> as ProtocolsHandler>::InboundProtocol, <MultiHandler<K, H> as ProtocolsHandler>::InboundOpenInfo>[src]The InboundUpgrade to apply on inbound
substreams to negotiate the desired protocols. Read more
pub fn inject_fully_negotiated_outbound(
    &mut self, 
    protocol: <<MultiHandler<K, H> as ProtocolsHandler>::OutboundProtocol as OutboundUpgradeSend>::Output, 
    <MultiHandler<K, H> as ProtocolsHandler>::OutboundOpenInfo
)[src]
pub fn inject_fully_negotiated_outbound(
    &mut self, 
    protocol: <<MultiHandler<K, H> as ProtocolsHandler>::OutboundProtocol as OutboundUpgradeSend>::Output, 
    <MultiHandler<K, H> as ProtocolsHandler>::OutboundOpenInfo
)[src]Injects the output of a successful upgrade on a new outbound substream. Read more
pub fn inject_fully_negotiated_inbound(
    &mut self, 
    <<MultiHandler<K, H> as ProtocolsHandler>::InboundProtocol as InboundUpgradeSend>::Output, 
    info: <MultiHandler<K, H> as ProtocolsHandler>::InboundOpenInfo
)[src]
pub fn inject_fully_negotiated_inbound(
    &mut self, 
    <<MultiHandler<K, H> as ProtocolsHandler>::InboundProtocol as InboundUpgradeSend>::Output, 
    info: <MultiHandler<K, H> as ProtocolsHandler>::InboundOpenInfo
)[src]Injects the output of a successful upgrade on a new inbound substream.
Injects an event coming from the outside in the handler.
Notifies the handler of a change in the address of the remote.
pub fn inject_dial_upgrade_error(
    &mut self, 
    <MultiHandler<K, H> as ProtocolsHandler>::OutboundOpenInfo, 
    error: ProtocolsHandlerUpgrErr<<<MultiHandler<K, H> as ProtocolsHandler>::OutboundProtocol as OutboundUpgradeSend>::Error>
)[src]
pub fn inject_dial_upgrade_error(
    &mut self, 
    <MultiHandler<K, H> as ProtocolsHandler>::OutboundOpenInfo, 
    error: ProtocolsHandlerUpgrErr<<<MultiHandler<K, H> as ProtocolsHandler>::OutboundProtocol as OutboundUpgradeSend>::Error>
)[src]Indicates to the handler that upgrading an outbound substream to the given protocol has failed.
pub fn inject_listen_upgrade_error(
    &mut self, 
    info: <MultiHandler<K, H> as ProtocolsHandler>::InboundOpenInfo, 
    error: ProtocolsHandlerUpgrErr<<<MultiHandler<K, H> as ProtocolsHandler>::InboundProtocol as InboundUpgradeSend>::Error>
)[src]
pub fn inject_listen_upgrade_error(
    &mut self, 
    info: <MultiHandler<K, H> as ProtocolsHandler>::InboundOpenInfo, 
    error: ProtocolsHandlerUpgrErr<<<MultiHandler<K, H> as ProtocolsHandler>::InboundProtocol as InboundUpgradeSend>::Error>
)[src]Indicates to the handler that upgrading an inbound substream to the given protocol has failed.
Returns until when the connection should be kept alive. Read more
pub fn poll(
    &mut self, 
    cx: &mut Context<'_>
) -> Poll<ProtocolsHandlerEvent<<MultiHandler<K, H> as ProtocolsHandler>::OutboundProtocol, <MultiHandler<K, H> as ProtocolsHandler>::OutboundOpenInfo, <MultiHandler<K, H> as ProtocolsHandler>::OutEvent, <MultiHandler<K, H> as ProtocolsHandler>::Error>>[src]
pub fn poll(
    &mut self, 
    cx: &mut Context<'_>
) -> Poll<ProtocolsHandlerEvent<<MultiHandler<K, H> as ProtocolsHandler>::OutboundProtocol, <MultiHandler<K, H> as ProtocolsHandler>::OutboundOpenInfo, <MultiHandler<K, H> as ProtocolsHandler>::OutEvent, <MultiHandler<K, H> as ProtocolsHandler>::Error>>[src]Should behave like Stream::poll().
fn map_in_event<TNewIn, TMap>(self, map: TMap) -> MapInEvent<Self, TNewIn, TMap> where
    TMap: Fn(&TNewIn) -> Option<&Self::InEvent>, [src]
fn map_in_event<TNewIn, TMap>(self, map: TMap) -> MapInEvent<Self, TNewIn, TMap> where
    TMap: Fn(&TNewIn) -> Option<&Self::InEvent>, [src]Adds a closure that turns the input event into something else.
fn map_out_event<TMap, TNewOut>(self, map: TMap) -> MapOutEvent<Self, TMap> where
    TMap: FnMut(Self::OutEvent) -> TNewOut, [src]
fn map_out_event<TMap, TNewOut>(self, map: TMap) -> MapOutEvent<Self, TMap> where
    TMap: FnMut(Self::OutEvent) -> TNewOut, [src]Adds a closure that turns the output event into something else.
Creates a new ProtocolsHandler that selects either this handler or
other by delegating methods calls appropriately. Read more
Creates a builder that allows creating a NodeHandler that handles this protocol
exclusively. Read more
Auto Trait Implementations
impl<K, H> RefUnwindSafe for MultiHandler<K, H> where
    H: RefUnwindSafe,
    K: RefUnwindSafe, impl<K, H> Send for MultiHandler<K, H> where
    H: Send,
    K: Send, impl<K, H> Sync for MultiHandler<K, H> where
    H: Sync,
    K: Sync, impl<K, H> Unpin for MultiHandler<K, H> where
    H: Unpin,
    K: Unpin, impl<K, H> UnwindSafe for MultiHandler<K, H> where
    H: UnwindSafe,
    K: UnwindSafe, Blanket Implementations
Mutably borrows from an owned value. Read more
type Handler = T
type Handler = TThe protocols handler.
Builds the protocols handler. Read more
pub fn inbound_protocol(
    &self
) -> <<T as IntoProtocolsHandler>::Handler as ProtocolsHandler>::InboundProtocol[src]
pub fn inbound_protocol(
    &self
) -> <<T as IntoProtocolsHandler>::Handler as ProtocolsHandler>::InboundProtocol[src]Return the handler’s inbound protocol.
Builds an implementation of IntoProtocolsHandler that handles both this protocol and the
other one together. Read more
Creates a builder that will allow creating a NodeHandler that handles this protocol
exclusively. Read more
pub fn vzip(self) -> V