Struct libp2p::core::transport::OptionalTransport
source · 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§
source§impl<T> OptionalTransport<T>
impl<T> OptionalTransport<T>
sourcepub fn some(inner: T) -> OptionalTransport<T>
pub fn some(inner: T) -> OptionalTransport<T>
Builds an OptionalTransport
with the given transport in an enabled
state.
sourcepub fn none() -> OptionalTransport<T>
pub fn none() -> OptionalTransport<T>
Builds a disabled OptionalTransport
.
Trait Implementations§
source§impl<T> Clone for OptionalTransport<T>where
T: Clone,
impl<T> Clone for OptionalTransport<T>where
T: Clone,
source§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 moresource§impl<T> Debug for OptionalTransport<T>where
T: Debug,
impl<T> Debug for OptionalTransport<T>where
T: Debug,
source§impl<T> From<T> for OptionalTransport<T>
impl<T> From<T> for OptionalTransport<T>
source§fn from(inner: T) -> OptionalTransport<T>
fn from(inner: T) -> OptionalTransport<T>
Converts to this type from the input type.
source§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
source§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
.source§fn remove_listener(&mut self, id: ListenerId) -> bool
fn remove_listener(&mut self, id: ListenerId) -> bool
Remove a listener. Read more
source§fn dial(
&mut self,
addr: Multiaddr
) -> Result<<OptionalTransport<T> as Transport>::Dial, TransportError<<OptionalTransport<T> as Transport>::Error>>
fn dial( &mut self, addr: Multiaddr ) -> Result<<OptionalTransport<T> as Transport>::Dial, TransportError<<OptionalTransport<T> as Transport>::Error>>
source§fn dial_as_listener(
&mut self,
addr: Multiaddr
) -> Result<<OptionalTransport<T> as Transport>::Dial, TransportError<<OptionalTransport<T> as Transport>::Error>>
fn dial_as_listener( &mut self, addr: Multiaddr ) -> Result<<OptionalTransport<T> as Transport>::Dial, TransportError<<OptionalTransport<T> as Transport>::Error>>
As
Transport::dial
but has the local node act as a listener on the outgoing connection. Read moresource§fn address_translation(
&self,
server: &Multiaddr,
observed: &Multiaddr
) -> Option<Multiaddr>
fn address_translation( &self, server: &Multiaddr, observed: &Multiaddr ) -> Option<Multiaddr>
Performs a transport-specific mapping of an address
observed
by a remote onto a
local listen
address to yield an address for the local node that may be reachable
for other peers. Read moresource§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 moresource§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.
source§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.
source§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> 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§
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
§impl<T> FromFd for T
impl<T> FromFd for T
§impl<T> FromFilelike for T
impl<T> FromFilelike for T
§fn from_filelike(owned: OwnedFd) -> T
fn from_filelike(owned: OwnedFd) -> T
Constructs a new instance of
Self
from the given filelike object. Read more§fn from_into_filelike<Owned>(owned: Owned) -> Twhere
Owned: IntoFilelike,
fn from_into_filelike<Owned>(owned: Owned) -> Twhere
Owned: IntoFilelike,
Constructs a new instance of
Self
from the given filelike object
converted from into_owned
. Read more§impl<T> FromSocketlike for T
impl<T> FromSocketlike for T
§fn from_socketlike(owned: OwnedFd) -> T
fn from_socketlike(owned: OwnedFd) -> T
Constructs a new instance of
Self
from the given socketlike object.§fn from_into_socketlike<Owned>(owned: Owned) -> Twhere
Owned: IntoSocketlike,
fn from_into_socketlike<Owned>(owned: Owned) -> Twhere
Owned: IntoSocketlike,
Constructs a new instance of
Self
from the given socketlike object
converted from into_owned
.source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
source§fn in_current_span(self) -> Instrumented<Self> ⓘ
fn in_current_span(self) -> Instrumented<Self> ⓘ
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 trafic that passes through the streams
created by it. Read more