pub struct WsConfig<T>{ /* private fields */ }
websocket
and non-WebAssembly only.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/tls/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}");
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>
Source§type Output = RwStreamSink<BytesConnection<<T as Transport>::Output>>
type Output = RwStreamSink<BytesConnection<<T as Transport>::Output>>
Source§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>>>
Source§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,
opts: DialOpts,
) -> Result<<WsConfig<T> as Transport>::Dial, TransportError<<WsConfig<T> as Transport>::Error>>
fn dial( &mut self, addr: Multiaddr, opts: DialOpts, ) -> Result<<WsConfig<T> as Transport>::Dial, TransportError<<WsConfig<T> as Transport>::Error>>
Source§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 more§fn map<F, O>(self, f: F) -> Map<Self, F>
fn map<F, O>(self, f: F) -> Map<Self, F>
§fn map_err<F, E>(self, f: F) -> MapErr<Self, F>
fn map_err<F, E>(self, f: F) -> MapErr<Self, F>
§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§
§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
§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> ⓘ
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 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>)
libp2p::SwarmBuilder::with_bandwidth_metrics
or libp2p_metrics::BandwidthTransport
instead.Transport
that logs all traffic that passes through the streams
created by it. Read more