pub struct WebSocket<S, H> { /* private fields */ }
Expand description
endpoint/middleware handler for websockets in tide
This can either be used as a middleware or as an
endpoint. Regardless of which approach is taken, the handler
function provided to WebSocket::new
is only called if the
request correctly negotiates an upgrade to the websocket protocol.
As a middleware
If used as a middleware, the endpoint will be executed if the request is not a websocket upgrade.
Example
use async_std::prelude::*;
use tide_websockets::{Message, WebSocket};
#[async_std::main]
async fn main() -> Result<(), std::io::Error> {
let mut app = tide::new();
app.at("/ws")
.with(WebSocket::new(|_request, mut stream| async move {
while let Some(Ok(Message::Text(input))) = stream.next().await {
let output: String = input.chars().rev().collect();
stream
.send_string(format!("{} | {}", &input, &output))
.await?;
}
Ok(())
}))
.get(|_| async move { Ok("this was not a websocket request") });
app.listen("127.0.0.1:8080").await?;
Ok(())
}
As an endpoint
If used as an endpoint but the request is
not a websocket request, tide will reply with a 426 Upgrade Required
status code.
example
use async_std::prelude::*;
use tide_websockets::{Message, WebSocket};
#[async_std::main]
async fn main() -> Result<(), std::io::Error> {
let mut app = tide::new();
app.at("/ws")
.get(WebSocket::new(|_request, mut stream| async move {
while let Some(Ok(Message::Text(input))) = stream.next().await {
let output: String = input.chars().rev().collect();
stream
.send_string(format!("{} | {}", &input, &output))
.await?;
}
Ok(())
}));
app.listen("127.0.0.1:8080").await?;
Ok(())
}
Implementations§
§impl<S, H, Fut> WebSocket<S, H>where
S: Send + Sync + Clone + 'static,
H: Fn(Request<S>, WebSocketConnection) -> Fut + Sync + Send + 'static,
Fut: Future<Output = Result<(), Error>> + Send + 'static,
impl<S, H, Fut> WebSocket<S, H>where S: Send + Sync + Clone + 'static, H: Fn(Request<S>, WebSocketConnection) -> Fut + Sync + Send + 'static, Fut: Future<Output = Result<(), Error>> + Send + 'static,
pub fn with_protocols(self, protocols: &[&str]) -> WebSocket<S, H>
pub fn with_protocols(self, protocols: &[&str]) -> WebSocket<S, H>
protocols
is a sequence of known protocols. On successful handshake,
the returned response headers contain the first protocol in this list
which the server also knows.
Trait Implementations§
§impl<H, S, Fut> Endpoint<S> for WebSocket<S, H>where
H: Fn(Request<S>, WebSocketConnection) -> Fut + Sync + Send + 'static,
Fut: Future<Output = Result<(), Error>> + Send + 'static,
S: Send + Sync + Clone + 'static,
impl<H, S, Fut> Endpoint<S> for WebSocket<S, H>where H: Fn(Request<S>, WebSocketConnection) -> Fut + Sync + Send + 'static, Fut: Future<Output = Result<(), Error>> + Send + 'static, S: Send + Sync + Clone + 'static,
§impl<H, S, Fut> Middleware<S> for WebSocket<S, H>where
H: Fn(Request<S>, WebSocketConnection) -> Fut + Sync + Send + 'static,
Fut: Future<Output = Result<(), Error>> + Send + 'static,
S: Send + Sync + Clone + 'static,
impl<H, S, Fut> Middleware<S> for WebSocket<S, H>where H: Fn(Request<S>, WebSocketConnection) -> Fut + Sync + Send + 'static, Fut: Future<Output = Result<(), Error>> + Send + 'static, S: Send + Sync + Clone + 'static,
§fn handle<'life0, 'life1, 'async_trait>(
&'life0 self,
req: Request<S>,
next: Next<'life1, S>
) -> Pin<Box<dyn Future<Output = Result<Response, Error>> + Send + 'async_trait, Global>>where
'life0: 'async_trait,
'life1: 'async_trait,
WebSocket<S, H>: 'async_trait,
fn handle<'life0, 'life1, 'async_trait>( &'life0 self, req: Request<S>, next: Next<'life1, S> ) -> Pin<Box<dyn Future<Output = Result<Response, Error>> + Send + 'async_trait, Global>>where 'life0: 'async_trait, 'life1: 'async_trait, WebSocket<S, H>: 'async_trait,
Asynchronously handle the request, and return a response.
Auto Trait Implementations§
impl<S, H> RefUnwindSafe for WebSocket<S, H>where H: RefUnwindSafe, S: RefUnwindSafe,
impl<S, H> Send for WebSocket<S, H>where H: Send + Sync, S: Send,
impl<S, H> Sync for WebSocket<S, H>where H: Send + Sync, S: Sync,
impl<S, H> Unpin for WebSocket<S, H>where S: Unpin,
impl<S, H> UnwindSafe for WebSocket<S, H>where H: RefUnwindSafe, S: UnwindSafe,
Blanket Implementations§
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> RoundFrom<T> for T
impl<T> RoundFrom<T> for T
§fn round_from(x: T) -> T
fn round_from(x: T) -> T
Performs the conversion.
§impl<T, U> RoundInto<U> for Twhere
U: RoundFrom<T>,
impl<T, U> RoundInto<U> for Twhere U: RoundFrom<T>,
§fn round_into(self) -> U
fn round_into(self) -> U
Performs the conversion.