Struct libp2p::swarm::protocols_handler::OneShotHandler
source · [−]pub struct OneShotHandler<TInbound, TOutbound, TEvent> where
TOutbound: OutboundUpgradeSend, { /* private fields */ }
Expand description
A ProtocolsHandler
that opens a new substream for each request.
Implementations
sourceimpl<TInbound, TOutbound, TEvent> OneShotHandler<TInbound, TOutbound, TEvent> where
TOutbound: OutboundUpgradeSend,
impl<TInbound, TOutbound, TEvent> OneShotHandler<TInbound, TOutbound, TEvent> where
TOutbound: OutboundUpgradeSend,
sourcepub fn new(
listen_protocol: SubstreamProtocol<TInbound, ()>,
config: OneShotHandlerConfig
) -> OneShotHandler<TInbound, TOutbound, TEvent>
pub fn new(
listen_protocol: SubstreamProtocol<TInbound, ()>,
config: OneShotHandlerConfig
) -> OneShotHandler<TInbound, TOutbound, TEvent>
Creates a OneShotHandler
.
sourcepub fn pending_requests(&self) -> u32
pub fn pending_requests(&self) -> u32
Returns the number of pending requests.
sourcepub fn listen_protocol_ref(&self) -> &SubstreamProtocol<TInbound, ()>
pub fn listen_protocol_ref(&self) -> &SubstreamProtocol<TInbound, ()>
Returns a reference to the listen protocol configuration.
Note: If you modify the protocol, modifications will only applies to future inbound substreams, not the ones already being negotiated.
sourcepub fn listen_protocol_mut(&mut self) -> &mut SubstreamProtocol<TInbound, ()>
pub fn listen_protocol_mut(&mut self) -> &mut SubstreamProtocol<TInbound, ()>
Returns a mutable reference to the listen protocol configuration.
Note: If you modify the protocol, modifications will only applies to future inbound substreams, not the ones already being negotiated.
sourcepub fn send_request(&mut self, upgrade: TOutbound)
pub fn send_request(&mut self, upgrade: TOutbound)
Opens an outbound substream with upgrade
.
Trait Implementations
sourceimpl<TInbound, TOutbound, TEvent> Default for OneShotHandler<TInbound, TOutbound, TEvent> where
TOutbound: OutboundUpgradeSend,
TInbound: InboundUpgradeSend + Default,
impl<TInbound, TOutbound, TEvent> Default for OneShotHandler<TInbound, TOutbound, TEvent> where
TOutbound: OutboundUpgradeSend,
TInbound: InboundUpgradeSend + Default,
sourcepub fn default() -> OneShotHandler<TInbound, TOutbound, TEvent>
pub fn default() -> OneShotHandler<TInbound, TOutbound, TEvent>
Returns the “default value” for a type. Read more
sourceimpl<TInbound, TOutbound, TEvent> ProtocolsHandler for OneShotHandler<TInbound, TOutbound, TEvent> where
TInbound: 'static + InboundUpgradeSend + Send,
TOutbound: OutboundUpgradeSend,
TEvent: 'static + Send,
<TInbound as InboundUpgradeSend>::Output: Into<TEvent>,
<TOutbound as OutboundUpgradeSend>::Output: Into<TEvent>,
<TOutbound as OutboundUpgradeSend>::Error: 'static,
<TOutbound as OutboundUpgradeSend>::Error: Error,
<TOutbound as OutboundUpgradeSend>::Error: Send,
SubstreamProtocol<TInbound, ()>: Clone,
impl<TInbound, TOutbound, TEvent> ProtocolsHandler for OneShotHandler<TInbound, TOutbound, TEvent> where
TInbound: 'static + InboundUpgradeSend + Send,
TOutbound: OutboundUpgradeSend,
TEvent: 'static + Send,
<TInbound as InboundUpgradeSend>::Output: Into<TEvent>,
<TOutbound as OutboundUpgradeSend>::Output: Into<TEvent>,
<TOutbound as OutboundUpgradeSend>::Error: 'static,
<TOutbound as OutboundUpgradeSend>::Error: Error,
<TOutbound as OutboundUpgradeSend>::Error: Send,
SubstreamProtocol<TInbound, ()>: Clone,
type InEvent = TOutbound
type InEvent = TOutbound
Custom event that can be received from the outside.
type OutEvent = TEvent
type OutEvent = TEvent
Custom event that can be produced by the handler and that will be returned to the outside.
type Error = ProtocolsHandlerUpgrErr<<<OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::OutboundProtocol as OutboundUpgradeSend>::Error>
type Error = ProtocolsHandlerUpgrErr<<<OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::OutboundProtocol as OutboundUpgradeSend>::Error>
The type of errors returned by ProtocolsHandler::poll
.
type InboundProtocol = TInbound
type InboundProtocol = TInbound
The inbound upgrade for the protocol(s) used by the handler.
type OutboundProtocol = TOutbound
type OutboundProtocol = TOutbound
The outbound upgrade for the protocol(s) used by the handler.
type OutboundOpenInfo = ()
type OutboundOpenInfo = ()
The type of additional information passed to an OutboundSubstreamRequest
.
type InboundOpenInfo = ()
type InboundOpenInfo = ()
The type of additional information returned from listen_protocol
.
sourcepub fn listen_protocol(
&self
) -> SubstreamProtocol<<OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::InboundProtocol, <OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::InboundOpenInfo>
pub fn listen_protocol(
&self
) -> SubstreamProtocol<<OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::InboundProtocol, <OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::InboundOpenInfo>
The InboundUpgrade
to apply on inbound
substreams to negotiate the desired protocols. Read more
sourcepub fn inject_fully_negotiated_inbound(
&mut self,
out: <<OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::InboundProtocol as InboundUpgradeSend>::Output,
<OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::InboundOpenInfo
)
pub fn inject_fully_negotiated_inbound(
&mut self,
out: <<OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::InboundProtocol as InboundUpgradeSend>::Output,
<OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::InboundOpenInfo
)
Injects the output of a successful upgrade on a new inbound substream.
sourcepub fn inject_fully_negotiated_outbound(
&mut self,
out: <<OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::OutboundProtocol as OutboundUpgradeSend>::Output,
<OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::OutboundOpenInfo
)
pub fn inject_fully_negotiated_outbound(
&mut self,
out: <<OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::OutboundProtocol as OutboundUpgradeSend>::Output,
<OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::OutboundOpenInfo
)
Injects the output of a successful upgrade on a new outbound substream. Read more
sourcepub fn inject_event(
&mut self,
event: <OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::InEvent
)
pub fn inject_event(
&mut self,
event: <OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::InEvent
)
Injects an event coming from the outside in the handler.
sourcepub fn inject_dial_upgrade_error(
&mut self,
_info: <OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::OutboundOpenInfo,
error: ProtocolsHandlerUpgrErr<<<OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::OutboundProtocol as OutboundUpgradeSend>::Error>
)
pub fn inject_dial_upgrade_error(
&mut self,
_info: <OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::OutboundOpenInfo,
error: ProtocolsHandlerUpgrErr<<<OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::OutboundProtocol as OutboundUpgradeSend>::Error>
)
Indicates to the handler that upgrading an outbound substream to the given protocol has failed.
sourcepub fn connection_keep_alive(&self) -> KeepAlive
pub fn connection_keep_alive(&self) -> KeepAlive
Returns until when the connection should be kept alive. Read more
sourcepub fn poll(
&mut self,
&mut Context<'_>
) -> Poll<ProtocolsHandlerEvent<<OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::OutboundProtocol, <OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::OutboundOpenInfo, <OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::OutEvent, <OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::Error>>
pub fn poll(
&mut self,
&mut Context<'_>
) -> Poll<ProtocolsHandlerEvent<<OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::OutboundProtocol, <OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::OutboundOpenInfo, <OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::OutEvent, <OneShotHandler<TInbound, TOutbound, TEvent> as ProtocolsHandler>::Error>>
Should behave like Stream::poll()
.
sourcefn inject_address_change(&mut self, _new_address: &Multiaddr)
fn inject_address_change(&mut self, _new_address: &Multiaddr)
Notifies the handler of a change in the address of the remote.
sourcefn inject_listen_upgrade_error(
&mut self,
Self::InboundOpenInfo,
ProtocolsHandlerUpgrErr<<Self::InboundProtocol as InboundUpgradeSend>::Error>
)
fn inject_listen_upgrade_error(
&mut self,
Self::InboundOpenInfo,
ProtocolsHandlerUpgrErr<<Self::InboundProtocol as InboundUpgradeSend>::Error>
)
Indicates to the handler that upgrading an inbound substream to the given protocol has failed.
sourcefn map_in_event<TNewIn, TMap>(self, map: TMap) -> MapInEvent<Self, TNewIn, TMap> where
TMap: Fn(&TNewIn) -> Option<&Self::InEvent>,
fn map_in_event<TNewIn, TMap>(self, map: TMap) -> MapInEvent<Self, TNewIn, TMap> where
TMap: Fn(&TNewIn) -> Option<&Self::InEvent>,
Adds a closure that turns the input event into something else.
sourcefn map_out_event<TMap, TNewOut>(self, map: TMap) -> MapOutEvent<Self, TMap> where
TMap: FnMut(Self::OutEvent) -> TNewOut,
fn map_out_event<TMap, TNewOut>(self, map: TMap) -> MapOutEvent<Self, TMap> where
TMap: FnMut(Self::OutEvent) -> TNewOut,
Adds a closure that turns the output event into something else.
sourcefn select<TProto2>(
self,
other: TProto2
) -> ProtocolsHandlerSelect<Self, TProto2>
fn select<TProto2>(
self,
other: TProto2
) -> ProtocolsHandlerSelect<Self, TProto2>
Creates a new ProtocolsHandler
that selects either this handler or
other
by delegating methods calls appropriately. Read more
sourcefn into_node_handler_builder(self) -> NodeHandlerWrapperBuilder<Self>
fn into_node_handler_builder(self) -> NodeHandlerWrapperBuilder<Self>
Creates a builder that allows creating a NodeHandler
that handles this protocol
exclusively. Read more
Auto Trait Implementations
impl<TInbound, TOutbound, TEvent> RefUnwindSafe for OneShotHandler<TInbound, TOutbound, TEvent> where
TEvent: RefUnwindSafe,
TInbound: RefUnwindSafe,
TOutbound: RefUnwindSafe,
<TOutbound as OutboundUpgradeSend>::Error: RefUnwindSafe,
impl<TInbound, TOutbound, TEvent> Send for OneShotHandler<TInbound, TOutbound, TEvent> where
TEvent: Send,
TInbound: Send,
impl<TInbound, TOutbound, TEvent> Sync for OneShotHandler<TInbound, TOutbound, TEvent> where
TEvent: Sync,
TInbound: Sync,
TOutbound: Sync,
<TOutbound as OutboundUpgradeSend>::Error: Sync,
impl<TInbound, TOutbound, TEvent> Unpin for OneShotHandler<TInbound, TOutbound, TEvent> where
TEvent: Unpin,
TInbound: Unpin,
TOutbound: Unpin,
<TOutbound as OutboundUpgradeSend>::Error: Unpin,
impl<TInbound, TOutbound, TEvent> UnwindSafe for OneShotHandler<TInbound, TOutbound, TEvent> where
TEvent: UnwindSafe + RefUnwindSafe,
TInbound: UnwindSafe,
TOutbound: UnwindSafe + RefUnwindSafe,
<TOutbound as OutboundUpgradeSend>::Error: UnwindSafe,
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcepub fn borrow_mut(&mut self) -> &mut T
pub fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> IntoProtocolsHandler for T where
T: ProtocolsHandler,
impl<T> IntoProtocolsHandler for T where
T: ProtocolsHandler,
type Handler = T
type Handler = T
The protocols handler.
sourcepub fn into_handler(self, &PeerId, &ConnectedPoint) -> T
pub fn into_handler(self, &PeerId, &ConnectedPoint) -> T
Builds the protocols handler. Read more
sourcepub fn inbound_protocol(
&self
) -> <<T as IntoProtocolsHandler>::Handler as ProtocolsHandler>::InboundProtocol
pub fn inbound_protocol(
&self
) -> <<T as IntoProtocolsHandler>::Handler as ProtocolsHandler>::InboundProtocol
Return the handler’s inbound protocol.
sourcefn select<TProto2>(
self,
other: TProto2
) -> IntoProtocolsHandlerSelect<Self, TProto2>
fn select<TProto2>(
self,
other: TProto2
) -> IntoProtocolsHandlerSelect<Self, TProto2>
Builds an implementation of IntoProtocolsHandler
that handles both this protocol and the
other one together. Read more
sourcefn into_node_handler_builder(self) -> NodeHandlerWrapperBuilder<Self>
fn into_node_handler_builder(self) -> NodeHandlerWrapperBuilder<Self>
Creates a builder that will allow creating a NodeHandler
that handles this protocol
exclusively. Read more