Struct libp2p_swarm::behaviour::toggle::ToggleConnectionHandler
source · pub struct ToggleConnectionHandler<TInner> { /* private fields */ }
Expand description
Implementation of ConnectionHandler
that can be in the disabled state.
Trait Implementations§
source§impl<TInner> ConnectionHandler for ToggleConnectionHandler<TInner>where
TInner: ConnectionHandler,
impl<TInner> ConnectionHandler for ToggleConnectionHandler<TInner>where TInner: ConnectionHandler,
§type InEvent = <TInner as ConnectionHandler>::InEvent
type InEvent = <TInner as ConnectionHandler>::InEvent
Custom event that can be received from the outside.
§type OutEvent = <TInner as ConnectionHandler>::OutEvent
type OutEvent = <TInner as ConnectionHandler>::OutEvent
Custom event that can be produced by the handler and that will be returned to the outside.
§type Error = <TInner as ConnectionHandler>::Error
type Error = <TInner as ConnectionHandler>::Error
The type of errors returned by
ConnectionHandler::poll
.§type InboundProtocol = Either<SendWrapper<<TInner as ConnectionHandler>::InboundProtocol>, SendWrapper<DeniedUpgrade>>
type InboundProtocol = Either<SendWrapper<<TInner as ConnectionHandler>::InboundProtocol>, SendWrapper<DeniedUpgrade>>
The inbound upgrade for the protocol(s) used by the handler.
§type OutboundProtocol = <TInner as ConnectionHandler>::OutboundProtocol
type OutboundProtocol = <TInner as ConnectionHandler>::OutboundProtocol
The outbound upgrade for the protocol(s) used by the handler.
§type OutboundOpenInfo = <TInner as ConnectionHandler>::OutboundOpenInfo
type OutboundOpenInfo = <TInner as ConnectionHandler>::OutboundOpenInfo
The type of additional information passed to an
OutboundSubstreamRequest
.§type InboundOpenInfo = Either<<TInner as ConnectionHandler>::InboundOpenInfo, ()>
type InboundOpenInfo = Either<<TInner as ConnectionHandler>::InboundOpenInfo, ()>
The type of additional information returned from
listen_protocol
.source§fn listen_protocol(
&self
) -> SubstreamProtocol<Self::InboundProtocol, Self::InboundOpenInfo>
fn listen_protocol( &self ) -> SubstreamProtocol<Self::InboundProtocol, Self::InboundOpenInfo>
The
InboundUpgrade
to apply on inbound
substreams to negotiate the desired protocols. Read moresource§fn on_behaviour_event(&mut self, event: Self::InEvent)
fn on_behaviour_event(&mut self, event: Self::InEvent)
Informs the handler about an event from the
NetworkBehaviour
.source§fn connection_keep_alive(&self) -> KeepAlive
fn connection_keep_alive(&self) -> KeepAlive
Returns until when the connection should be kept alive. Read more
source§fn poll(
&mut self,
cx: &mut Context<'_>
) -> Poll<ConnectionHandlerEvent<Self::OutboundProtocol, Self::OutboundOpenInfo, Self::OutEvent, Self::Error>>
fn poll( &mut self, cx: &mut Context<'_> ) -> Poll<ConnectionHandlerEvent<Self::OutboundProtocol, Self::OutboundOpenInfo, Self::OutEvent, Self::Error>>
Should behave like
Stream::poll()
.fn on_connection_event( &mut self, event: ConnectionEvent<'_, Self::InboundProtocol, Self::OutboundProtocol, Self::InboundOpenInfo, Self::OutboundOpenInfo> )
source§fn map_in_event<TNewIn, TMap>(self, map: TMap) -> MapInEvent<Self, TNewIn, TMap>where
Self: Sized,
TMap: Fn(&TNewIn) -> Option<&Self::InEvent>,
fn map_in_event<TNewIn, TMap>(self, map: TMap) -> MapInEvent<Self, TNewIn, TMap>where Self: Sized, TMap: Fn(&TNewIn) -> Option<&Self::InEvent>,
Adds a closure that turns the input event into something else.
source§fn map_out_event<TMap, TNewOut>(self, map: TMap) -> MapOutEvent<Self, TMap>where
Self: Sized,
TMap: FnMut(Self::OutEvent) -> TNewOut,
fn map_out_event<TMap, TNewOut>(self, map: TMap) -> MapOutEvent<Self, TMap>where Self: Sized, TMap: FnMut(Self::OutEvent) -> TNewOut,
Adds a closure that turns the output event into something else.
source§fn select<TProto2>(
self,
other: TProto2
) -> ConnectionHandlerSelect<Self, TProto2>where
Self: Sized,
fn select<TProto2>( self, other: TProto2 ) -> ConnectionHandlerSelect<Self, TProto2>where Self: Sized,
Creates a new
ConnectionHandler
that selects either this handler or
other
by delegating methods calls appropriately. Read moreAuto Trait Implementations§
impl<TInner> RefUnwindSafe for ToggleConnectionHandler<TInner>where TInner: RefUnwindSafe,
impl<TInner> Send for ToggleConnectionHandler<TInner>where TInner: Send,
impl<TInner> Sync for ToggleConnectionHandler<TInner>where TInner: Sync,
impl<TInner> Unpin for ToggleConnectionHandler<TInner>where TInner: Unpin,
impl<TInner> UnwindSafe for ToggleConnectionHandler<TInner>where TInner: UnwindSafe,
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
source§impl<T> IntoConnectionHandler for Twhere
T: ConnectionHandler,
impl<T> IntoConnectionHandler for Twhere T: ConnectionHandler,
§type Handler = T
type Handler = T
👎Deprecated: Implement
ConnectionHandler
directly and use NetworkBehaviour::{handle_pending_inbound_connection,handle_pending_outbound_connection}
to handle pending connections.The protocols handler.
source§fn into_handler(self, _: &PeerId, _: &ConnectedPoint) -> T
fn into_handler(self, _: &PeerId, _: &ConnectedPoint) -> T
👎Deprecated: Implement
ConnectionHandler
directly and use NetworkBehaviour::{handle_pending_inbound_connection,handle_pending_outbound_connection}
to handle pending connections.Builds the protocols handler. Read more
source§fn inbound_protocol(
&self
) -> <<T as IntoConnectionHandler>::Handler as ConnectionHandler>::InboundProtocol
fn inbound_protocol( &self ) -> <<T as IntoConnectionHandler>::Handler as ConnectionHandler>::InboundProtocol
👎Deprecated: Implement
ConnectionHandler
directly and use NetworkBehaviour::{handle_pending_inbound_connection,handle_pending_outbound_connection}
to handle pending connections.Return the handler’s inbound protocol.
source§fn select<TProto2>(
self,
other: TProto2
) -> IntoConnectionHandlerSelect<Self, TProto2>where
Self: Sized,
fn select<TProto2>( self, other: TProto2 ) -> IntoConnectionHandlerSelect<Self, TProto2>where Self: Sized,
👎Deprecated: Implement
ConnectionHandler
directly and use NetworkBehaviour::{handle_pending_inbound_connection,handle_pending_outbound_connection}
to handle pending connections.Builds an implementation of
IntoConnectionHandler
that handles both this protocol and the
other one together.