Struct titanium::web::WebSocket

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,

pub fn new(handler: H) -> WebSocket<S, H>

Build a new WebSocket with a handler function that

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<S, H> Debug for WebSocket<S, H>where S: Debug, H: Debug,

§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
§

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,

§

fn call<'life0, 'async_trait>( &'life0 self, req: Request<S> ) -> Pin<Box<dyn Future<Output = Result<Response, Error>> + Send + 'async_trait, Global>>where 'life0: 'async_trait, WebSocket<S, H>: 'async_trait,

Invoke the endpoint within the given context
§

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,

Asynchronously handle the request, and return a response.
§

fn name(&self) -> &str

Set the middleware’s name. By default it uses the type signature.

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§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

const: unstable · source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

const: unstable · source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

const: unstable · source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for Twhere U: From<T>,

const: unstable · source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

§

impl<T> Pointable for T

§

const ALIGN: usize = mem::align_of::<T>()

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
§

impl<T> RoundFrom<T> for T

§

fn round_from(x: T) -> T

Performs the conversion.
§

impl<T, U> RoundInto<U> for Twhere U: RoundFrom<T>,

§

fn round_into(self) -> U

Performs the conversion.
source§

impl<T> Same<T> for T

§

type Output = T

Should always be Self
source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
const: unstable · source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
const: unstable · source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for Twhere V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more