1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
use async_graphql::Executor;
use poem::{async_trait, Endpoint, FromRequest, Request, Result};
use crate::{GraphQLBatchRequest, GraphQLBatchResponse};
/// A GraphQL query endpoint.
///
/// # Example
///
/// ```
/// use async_graphql::{EmptyMutation, EmptySubscription, Object, Schema};
/// use async_graphql_poem::GraphQL;
/// use poem::{post, Route};
///
/// struct Query;
///
/// #[Object]
/// impl Query {
/// async fn value(&self) -> i32 {
/// 100
/// }
/// }
///
/// type MySchema = Schema<Query, EmptyMutation, EmptySubscription>;
///
/// let schema = Schema::new(Query, EmptyMutation, EmptySubscription);
/// let app = Route::new().at("/", post(GraphQL::new(schema)));
/// ```
pub struct GraphQL<E> {
executor: E,
}
impl<E> GraphQL<E> {
/// Create a GraphQL query endpoint.
pub fn new(executor: E) -> Self {
Self { executor }
}
}
#[async_trait]
impl<E> Endpoint for GraphQL<E>
where
E: Executor,
{
type Output = GraphQLBatchResponse;
async fn call(&self, req: Request) -> Result<Self::Output> {
let (req, mut body) = req.split();
let req = GraphQLBatchRequest::from_request(&req, &mut body).await?;
Ok(GraphQLBatchResponse(
self.executor.execute_batch(req.0).await,
))
}
}