Struct OptionalTransport
pub struct OptionalTransport<T>(/* private fields */);
Expand description
Transport that is possibly disabled.
An OptionalTransport<T>
is a wrapper around an Option<T>
. If it is disabled (read: contains
None
), then any attempt to dial or listen will return MultiaddrNotSupported
. If it is
enabled (read: contains Some
), then dialing and listening will be handled by the inner
transport.
Implementations§
§impl<T> OptionalTransport<T>
impl<T> OptionalTransport<T>
pub fn some(inner: T) -> OptionalTransport<T>
pub fn some(inner: T) -> OptionalTransport<T>
Builds an OptionalTransport
with the given transport in an enabled
state.
pub fn none() -> OptionalTransport<T>
pub fn none() -> OptionalTransport<T>
Builds a disabled OptionalTransport
.
Trait Implementations§
§impl<T> Clone for OptionalTransport<T>where
T: Clone,
impl<T> Clone for OptionalTransport<T>where
T: Clone,
§fn clone(&self) -> OptionalTransport<T>
fn clone(&self) -> OptionalTransport<T>
Returns a copy of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read more§impl<T> Debug for OptionalTransport<T>where
T: Debug,
impl<T> Debug for OptionalTransport<T>where
T: Debug,
§impl<T> From<T> for OptionalTransport<T>
impl<T> From<T> for OptionalTransport<T>
§fn from(inner: T) -> OptionalTransport<T>
fn from(inner: T) -> OptionalTransport<T>
Converts to this type from the input type.
§impl<T> Transport for OptionalTransport<T>where
T: Transport,
impl<T> Transport for OptionalTransport<T>where
T: Transport,
§type Output = <T as Transport>::Output
type Output = <T as Transport>::Output
The result of a connection setup process, including protocol upgrades. Read more
§type ListenerUpgrade = <T as Transport>::ListenerUpgrade
type ListenerUpgrade = <T as Transport>::ListenerUpgrade
§fn listen_on(
&mut self,
id: ListenerId,
addr: Multiaddr,
) -> Result<(), TransportError<<OptionalTransport<T> as Transport>::Error>>
fn listen_on( &mut self, id: ListenerId, addr: Multiaddr, ) -> Result<(), TransportError<<OptionalTransport<T> as Transport>::Error>>
Listens on the given
Multiaddr
for inbound connections with a provided ListenerId
.§fn remove_listener(&mut self, id: ListenerId) -> bool
fn remove_listener(&mut self, id: ListenerId) -> bool
Remove a listener. Read more
§fn dial(
&mut self,
addr: Multiaddr,
opts: DialOpts,
) -> Result<<OptionalTransport<T> as Transport>::Dial, TransportError<<OptionalTransport<T> as Transport>::Error>>
fn dial( &mut self, addr: Multiaddr, opts: DialOpts, ) -> Result<<OptionalTransport<T> as Transport>::Dial, TransportError<<OptionalTransport<T> as Transport>::Error>>
§fn poll(
self: Pin<&mut OptionalTransport<T>>,
cx: &mut Context<'_>,
) -> Poll<TransportEvent<<OptionalTransport<T> as Transport>::ListenerUpgrade, <OptionalTransport<T> as Transport>::Error>>
fn poll( self: Pin<&mut OptionalTransport<T>>, cx: &mut Context<'_>, ) -> Poll<TransportEvent<<OptionalTransport<T> as Transport>::ListenerUpgrade, <OptionalTransport<T> as Transport>::Error>>
Poll for
TransportEvent
s. Read more§fn map<F, O>(self, f: F) -> Map<Self, F>
fn map<F, O>(self, f: F) -> Map<Self, F>
Applies a function on the connections created by the transport.
§fn map_err<F, E>(self, f: F) -> MapErr<Self, F>
fn map_err<F, E>(self, f: F) -> MapErr<Self, F>
Applies a function on the errors generated by the futures of the transport.
§fn or_transport<U>(self, other: U) -> OrTransport<Self, U>
fn or_transport<U>(self, other: U) -> OrTransport<Self, U>
Adds a fallback transport that is used when encountering errors
while establishing inbound or outbound connections. Read more
impl<T> Copy for OptionalTransport<T>where
T: Copy,
impl<'pin, T> Unpin for OptionalTransport<T>where
__OptionalTransport<'pin, T>: Unpin,
Auto Trait Implementations§
impl<T> Freeze for OptionalTransport<T>where
T: Freeze,
impl<T> RefUnwindSafe for OptionalTransport<T>where
T: RefUnwindSafe,
impl<T> Send for OptionalTransport<T>where
T: Send,
impl<T> Sync for OptionalTransport<T>where
T: Sync,
impl<T> UnwindSafe for OptionalTransport<T>where
T: UnwindSafe,
Blanket Implementations§
§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<TTransport> TransportExt for TTransportwhere
TTransport: Transport,
impl<TTransport> TransportExt for TTransportwhere
TTransport: Transport,
Source§fn with_bandwidth_logging<S>(
self,
) -> (Boxed<(PeerId, StreamMuxerBox)>, Arc<BandwidthSinks>)
fn with_bandwidth_logging<S>( self, ) -> (Boxed<(PeerId, StreamMuxerBox)>, Arc<BandwidthSinks>)
👎Deprecated: Use
libp2p::SwarmBuilder::with_bandwidth_metrics
or libp2p_metrics::BandwidthTransport
instead.Adds a layer on the
Transport
that logs all traffic that passes through the streams
created by it. Read more