Struct async_graphql_warp::GraphQLWebSocket

source ·
pub struct GraphQLWebSocket<Sink, Stream, E, OnInit> { /* private fields */ }
Expand description

A Websocket connection for GraphQL subscription.

§Examples

use std::time::Duration;

use async_graphql::*;
use async_graphql_warp::*;
use futures_util::stream::{Stream, StreamExt};
use warp::{ws, Filter};

struct QueryRoot;

#[Object]
impl QueryRoot {
    async fn value(&self) -> i32 {
        // A GraphQL Object type must define one or more fields.
        100
    }
}

struct SubscriptionRoot;

#[Subscription]
impl SubscriptionRoot {
    async fn tick(&self) -> impl Stream<Item = String> {
        async_stream::stream! {
            let mut interval = tokio::time::interval(Duration::from_secs(1));
            loop {
                let n = interval.tick().await;
                yield format!("{}", n.elapsed().as_secs_f32());
            }
        }
    }
}

let schema = Schema::new(QueryRoot, EmptyMutation, SubscriptionRoot);

let filter = warp::ws()
    .and(graphql_protocol())
    .map(move |ws: ws::Ws, protocol| {
        let schema = schema.clone();

        let reply = ws
            .on_upgrade(move |socket| GraphQLWebSocket::new(socket, schema, protocol).serve());

        warp::reply::with_header(
            reply,
            "Sec-WebSocket-Protocol",
            protocol.sec_websocket_protocol(),
        )
    });

warp::serve(filter).run(([0, 0, 0, 0], 8000)).await;

Implementations§

source§

impl<S, E> GraphQLWebSocket<SplitSink<S, Message>, SplitStream<S>, E, fn(_: Value) -> Ready<Result<Data>>>
where S: Stream<Item = Result<Message, Error>> + Sink<Message>, E: Executor,

source

pub fn new(socket: S, executor: E, protocol: WebSocketProtocols) -> Self

Create a GraphQLWebSocket object.

source§

impl<Sink, Stream, E> GraphQLWebSocket<Sink, Stream, E, fn(_: Value) -> Ready<Result<Data>>>
where Sink: Sink<Message>, Stream: Stream<Item = Result<Message, Error>>, E: Executor,

source

pub fn new_with_pair( sink: Sink, stream: Stream, executor: E, protocol: WebSocketProtocols ) -> Self

Create a GraphQLWebSocket object with sink and stream objects.

source§

impl<Sink, Stream, E, OnConnInit, OnConnInitFut> GraphQLWebSocket<Sink, Stream, E, OnConnInit>
where Sink: Sink<Message>, Stream: Stream<Item = Result<Message, Error>>, E: Executor, OnConnInit: FnOnce(Value) -> OnConnInitFut + Send + 'static, OnConnInitFut: Future<Output = Result<Data>> + Send + 'static,

source

pub fn with_data(self, data: Data) -> Self

Specify the initial subscription context data, usually you can get something from the incoming request to create it.

source

pub fn on_connection_init<OnConnInit2, Fut>( self, callback: OnConnInit2 ) -> GraphQLWebSocket<Sink, Stream, E, OnConnInit2>
where OnConnInit2: FnOnce(Value) -> Fut + Send + 'static, Fut: Future<Output = Result<Data>> + Send + 'static,

Specify a callback function to be called when the connection is initialized.

You can get something from the payload of GQL_CONNECTION_INIT message to create Data. The data returned by this callback function will be merged with the data specified by [with_data].

source

pub async fn serve(self)

Processing subscription requests.

Auto Trait Implementations§

§

impl<Sink, Stream, E, OnInit> Freeze for GraphQLWebSocket<Sink, Stream, E, OnInit>
where Sink: Freeze, Stream: Freeze, E: Freeze, OnInit: Freeze,

§

impl<Sink, Stream, E, OnInit> !RefUnwindSafe for GraphQLWebSocket<Sink, Stream, E, OnInit>

§

impl<Sink, Stream, E, OnInit> Send for GraphQLWebSocket<Sink, Stream, E, OnInit>
where Sink: Send, Stream: Send, E: Send, OnInit: Send,

§

impl<Sink, Stream, E, OnInit> Sync for GraphQLWebSocket<Sink, Stream, E, OnInit>
where Sink: Sync, Stream: Sync, E: Sync, OnInit: Sync,

§

impl<Sink, Stream, E, OnInit> Unpin for GraphQLWebSocket<Sink, Stream, E, OnInit>
where Sink: Unpin, Stream: Unpin, E: Unpin, OnInit: Unpin,

§

impl<Sink, Stream, E, OnInit> !UnwindSafe for GraphQLWebSocket<Sink, Stream, E, OnInit>

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

source§

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

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> Instrument for T

source§

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

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

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 T
where U: From<T>,

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.

source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

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

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

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

Performs the conversion.
source§

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

§

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

The type returned in the event of a conversion error.
source§

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

Performs the conversion.
source§

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

source§

fn vzip(self) -> V

source§

impl<T> WithSubscriber for T

source§

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
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

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