pub struct WsConfig<T>where
T: Transport,
<T as Transport>::Output: 'static + AsyncRead + AsyncWrite + Send + Unpin,{ /* private fields */ }
Expand description
A Websocket transport.
Implementations§
source§impl<T> WsConfig<T>where
T: Transport + 'static + Send + Unpin,
<T as Transport>::Error: 'static + Send,
<T as Transport>::Dial: 'static + Send,
<T as Transport>::ListenerUpgrade: 'static + Send,
<T as Transport>::Output: 'static + AsyncRead + AsyncWrite + Send + Unpin,
impl<T> WsConfig<T>where
T: Transport + 'static + Send + Unpin,
<T as Transport>::Error: 'static + Send,
<T as Transport>::Dial: 'static + Send,
<T as Transport>::ListenerUpgrade: 'static + Send,
<T as Transport>::Output: 'static + AsyncRead + AsyncWrite + Send + Unpin,
sourcepub fn new(transport: T) -> WsConfig<T>
pub fn new(transport: T) -> WsConfig<T>
Create a new websocket transport based on the given transport.
*Note: The given transport must be based on TCP/IP and should usually incorporate DNS resolution, though the latter is not strictly necessary if one wishes to only use the
Ws
protocol with known IP addresses and ports. Seelibp2p-tcp
andlibp2p-dns
for constructing the inner transport.
sourcepub fn max_redirects(&self) -> u8
pub fn max_redirects(&self) -> u8
Return the configured maximum number of redirects.
sourcepub fn set_max_redirects(&mut self, max: u8) -> &mut WsConfig<T>
pub fn set_max_redirects(&mut self, max: u8) -> &mut WsConfig<T>
Set max. number of redirects to follow.
sourcepub fn max_data_size(&self) -> usize
pub fn max_data_size(&self) -> usize
Get the max. frame data size we support.
sourcepub fn set_max_data_size(&mut self, size: usize) -> &mut WsConfig<T>
pub fn set_max_data_size(&mut self, size: usize) -> &mut WsConfig<T>
Set the max. frame data size we support.
sourcepub fn set_tls_config(&mut self, c: Config) -> &mut WsConfig<T>
pub fn set_tls_config(&mut self, c: Config) -> &mut WsConfig<T>
Set the TLS configuration if TLS support is desired.
sourcepub fn use_deflate(&mut self, flag: bool) -> &mut WsConfig<T>
pub fn use_deflate(&mut self, flag: bool) -> &mut WsConfig<T>
Should the deflate extension (RFC 7692) be used if supported?
Trait Implementations§
source§impl<T> Debug for WsConfig<T>where
T: Debug + Transport,
<T as Transport>::Output: 'static + AsyncRead + AsyncWrite + Send + Unpin + Debug,
impl<T> Debug for WsConfig<T>where
T: Debug + Transport,
<T as Transport>::Output: 'static + AsyncRead + AsyncWrite + Send + Unpin + Debug,
source§impl<T> Transport for WsConfig<T>where
T: 'static + Transport + Send + Unpin,
<T as Transport>::Error: 'static + Send,
<T as Transport>::Dial: 'static + Send,
<T as Transport>::ListenerUpgrade: 'static + Send,
<T as Transport>::Output: 'static + AsyncRead + AsyncWrite + Unpin + Send,
impl<T> Transport for WsConfig<T>where
T: 'static + Transport + Send + Unpin,
<T as Transport>::Error: 'static + Send,
<T as Transport>::Dial: 'static + Send,
<T as Transport>::ListenerUpgrade: 'static + Send,
<T as Transport>::Output: 'static + AsyncRead + AsyncWrite + Unpin + Send,
§type Output = RwStreamSink<BytesConnection<<T as Transport>::Output>>
type Output = RwStreamSink<BytesConnection<<T as Transport>::Output>>
The result of a connection setup process, including protocol upgrades. Read more
§type ListenerUpgrade = MapFuture<Pin<Box<dyn Future<Output = Result<Connection<<T as Transport>::Output>, Error<<T as Transport>::Error>>> + Send + 'static, Global>>, fn(_: Connection<<T as Transport>::Output>, _: ConnectedPoint) -> RwStreamSink<BytesConnection<<T as Transport>::Output>>>
type ListenerUpgrade = MapFuture<Pin<Box<dyn Future<Output = Result<Connection<<T as Transport>::Output>, Error<<T as Transport>::Error>>> + Send + 'static, Global>>, fn(_: Connection<<T as Transport>::Output>, _: ConnectedPoint) -> RwStreamSink<BytesConnection<<T as Transport>::Output>>>
§type Dial = MapFuture<Pin<Box<dyn Future<Output = Result<Connection<<T as Transport>::Output>, Error<<T as Transport>::Error>>> + Send + 'static, Global>>, fn(_: Connection<<T as Transport>::Output>, _: ConnectedPoint) -> RwStreamSink<BytesConnection<<T as Transport>::Output>>>
type Dial = MapFuture<Pin<Box<dyn Future<Output = Result<Connection<<T as Transport>::Output>, Error<<T as Transport>::Error>>> + Send + 'static, Global>>, fn(_: Connection<<T as Transport>::Output>, _: ConnectedPoint) -> RwStreamSink<BytesConnection<<T as Transport>::Output>>>
source§fn listen_on(
&mut self,
addr: Multiaddr
) -> Result<ListenerId, TransportError<<WsConfig<T> as Transport>::Error>>
fn listen_on(
&mut self,
addr: Multiaddr
) -> Result<ListenerId, TransportError<<WsConfig<T> as Transport>::Error>>
Listens on the given
Multiaddr
for inbound connections.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<<WsConfig<T> as Transport>::Dial, TransportError<<WsConfig<T> as Transport>::Error>>
fn dial(
&mut self,
addr: Multiaddr
) -> Result<<WsConfig<T> as Transport>::Dial, TransportError<<WsConfig<T> as Transport>::Error>>
source§fn dial_as_listener(
&mut self,
addr: Multiaddr
) -> Result<<WsConfig<T> as Transport>::Dial, TransportError<<WsConfig<T> as Transport>::Error>>
fn dial_as_listener(
&mut self,
addr: Multiaddr
) -> Result<<WsConfig<T> as Transport>::Dial, TransportError<<WsConfig<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 WsConfig<T>>,
cx: &mut Context<'_>
) -> Poll<TransportEvent<<WsConfig<T> as Transport>::ListenerUpgrade, <WsConfig<T> as Transport>::Error>>
fn poll(
self: Pin<&mut WsConfig<T>>,
cx: &mut Context<'_>
) -> Poll<TransportEvent<<WsConfig<T> as Transport>::ListenerUpgrade, <WsConfig<T> as Transport>::Error>>
Poll for
TransportEvent
s. Read moresource§fn map<F, O>(self, f: F) -> Map<Self, F>where
Self: Sized,
F: FnOnce(Self::Output, ConnectedPoint) -> O,
fn map<F, O>(self, f: F) -> Map<Self, F>where
Self: Sized,
F: FnOnce(Self::Output, ConnectedPoint) -> O,
Applies a function on the connections created by the transport.
source§fn map_err<F, E>(self, f: F) -> MapErr<Self, F>where
Self: Sized,
F: FnOnce(Self::Error) -> E,
fn map_err<F, E>(self, f: F) -> MapErr<Self, F>where
Self: Sized,
F: FnOnce(Self::Error) -> E,
Applies a function on the errors generated by the futures of the transport.
source§fn or_transport<U>(self, other: U) -> OrTransport<Self, U>where
Self: Sized,
U: Transport,
<U as Transport>::Error: 'static,
fn or_transport<U>(self, other: U) -> OrTransport<Self, U>where
Self: Sized,
U: Transport,
<U as Transport>::Error: 'static,
Adds a fallback transport that is used when encountering errors
while establishing inbound or outbound connections. Read more