pub struct WsConfig<T>{ /* private fields */ }
Expand description
A Websocket transport.
DO NOT wrap this transport with a DNS transport if you want Secure Websockets to work.
A Secure Websocket transport needs to wrap DNS transport to resolve domain names after they are checked against the remote certificates. Use a combination of DNS and TCP transports to build a Secure Websocket transport.
If you don’t need Secure Websocket’s support, use a plain TCP transport as an inner transport.
§Dependencies
This transport requires the zlib
shared library to be installed on the system.
Future releases might lift this requirement, see https://github.com/paritytech/soketto/issues/72.
§Examples
Secure Websocket transport:
let mut transport = websocket::WsConfig::new(dns::async_std::Transport::system(
tcp::async_io::Transport::new(tcp::Config::default()),
).await.unwrap());
let rcgen_cert = generate_simple_self_signed(vec!["localhost".to_string()]).unwrap();
let priv_key = websocket::tls::PrivateKey::new(rcgen_cert.serialize_private_key_der());
let cert = websocket::tls::Certificate::new(rcgen_cert.serialize_der().unwrap());
transport.set_tls_config(websocket::tls::Config::new(priv_key, vec![cert]).unwrap());
let id = transport.listen_on(ListenerId::next(), "/ip4/127.0.0.1/tcp/0/wss".parse().unwrap()).unwrap();
let addr = future::poll_fn(|cx| Pin::new(&mut transport).poll(cx)).await.into_new_address().unwrap();
println!("Listening on {addr}");
Plain Websocket transport:
let mut transport = websocket::WsConfig::new(
tcp::async_io::Transport::new(tcp::Config::default()),
);
let id = transport.listen_on(ListenerId::next(), "/ip4/127.0.0.1/tcp/0/ws".parse().unwrap()).unwrap();
let addr = future::poll_fn(|cx| Pin::new(&mut transport).poll(cx)).await.into_new_address().unwrap();
println!("Listening on {addr}");
Implementations§
source§impl<T> WsConfig<T>
impl<T> WsConfig<T>
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.
Trait Implementations§
source§impl<T> Transport for WsConfig<T>
impl<T> Transport for WsConfig<T>
§type Output = RwStreamSink<BytesConnection<<T as Transport>::Output>>
type Output = 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>>, 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>>, 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>>, 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>>, fn(_: Connection<<T as Transport>::Output>, _: ConnectedPoint) -> RwStreamSink<BytesConnection<<T as Transport>::Output>>>
source§fn listen_on(
&mut self,
id: ListenerId,
addr: Multiaddr,
) -> Result<(), TransportError<<WsConfig<T> as Transport>::Error>>
fn listen_on( &mut self, id: ListenerId, addr: Multiaddr, ) -> Result<(), TransportError<<WsConfig<T> as Transport>::Error>>
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
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>>
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>
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>>
TransportEvent
s. Read moresource§fn map<F, O>(self, f: F) -> Map<Self, F>
fn map<F, O>(self, f: F) -> Map<Self, F>
source§fn map_err<F, E>(self, f: F) -> MapErr<Self, F>
fn map_err<F, E>(self, f: F) -> MapErr<Self, F>
source§fn or_transport<U>(self, other: U) -> OrTransport<Self, U>
fn or_transport<U>(self, other: U) -> OrTransport<Self, U>
Auto Trait Implementations§
impl<T> Freeze for WsConfig<T>
impl<T> !RefUnwindSafe for WsConfig<T>
impl<T> Send for WsConfig<T>where
T: Send,
impl<T> Sync for WsConfig<T>where
T: Send,
impl<T> Unpin for WsConfig<T>
impl<T> !UnwindSafe for WsConfig<T>
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
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<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> ⓘ
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> ⓘ
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 moresource§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>)
Transport
that logs all trafic that passes through the streams
created by it. Read more