[−][src]Struct async_graphql::context::ContextBase
Query context.
This type is not stable and should not be used directly.
Fields
path_node: Option<QueryPathNode<'a>>
The current path node being resolved.
Implementations
impl<'a, T> ContextBase<'a, T>
[src]
pub fn data<D: Any + Send + Sync>(&self) -> Result<&D>
[src]
Gets the global data defined in the Context
or Schema
.
If both Schema
and Query
have the same data type, the data in the Query
is obtained.
Errors
Returns a Error
if the specified type data does not exist.
pub fn data_unchecked<D: Any + Send + Sync>(&self) -> &D
[src]
Gets the global data defined in the Context
or Schema
.
Panics
It will panic if the specified data type does not exist.
pub fn data_opt<D: Any + Send + Sync>(&self) -> Option<&D>
[src]
Gets the global data defined in the Context
or Schema
or None
if the specified type data does not exist.
impl<'a> ContextBase<'a, &'a Positioned<Field>>
[src]
pub fn look_ahead(&self) -> Lookahead<'_>
[src]
Creates a uniform interface to inspect the forthcoming selections.
Examples
use async_graphql::*; #[derive(SimpleObject)] struct Detail { c: i32, d: i32, } #[derive(SimpleObject)] struct MyObj { a: i32, b: i32, detail: Detail, } struct Query; #[Object] impl Query { async fn obj(&self, ctx: &Context<'_>) -> MyObj { if ctx.look_ahead().field("a").exists() { // This is a query like `obj { a }` } else if ctx.look_ahead().field("detail").field("c").exists() { // This is a query like `obj { detail { c } }` } else { // This query doesn't have `a` } unimplemented!() } }
pub fn field(&self) -> SelectionField<'a>
[src]
Get the current field.
Examples
use async_graphql::*; #[derive(SimpleObject)] struct MyObj { a: i32, b: i32, c: i32, } pub struct Query; #[Object] impl Query { async fn obj(&self, ctx: &Context<'_>) -> MyObj { let fields = ctx.field().selection_set().map(|field| field.name()).collect::<Vec<_>>(); assert_eq!(fields, vec!["a", "b", "c"]); MyObj { a: 1, b: 2, c: 3 } } } async_std::task::block_on(async move { let schema = Schema::new(Query, EmptyMutation, EmptySubscription); assert!(schema.execute("{ obj { a b c }}").await.is_ok()); assert!(schema.execute("{ obj { a ... { b c } }}").await.is_ok()); assert!(schema.execute("{ obj { a ... BC }} fragment BC on MyObj { b c }").await.is_ok()); });
Trait Implementations
impl<'a, T: Clone> Clone for ContextBase<'a, T>
[src]
pub fn clone(&self) -> ContextBase<'a, T>
[src]
pub fn clone_from(&mut self, source: &Self)
1.0.0[src]
Auto Trait Implementations
impl<'a, T> !RefUnwindSafe for ContextBase<'a, T>
[src]
impl<'a, T> Send for ContextBase<'a, T> where
T: Send,
[src]
T: Send,
impl<'a, T> Sync for ContextBase<'a, T> where
T: Sync,
[src]
T: Sync,
impl<'a, T> Unpin for ContextBase<'a, T> where
T: Unpin,
[src]
T: Unpin,
impl<'a, T> !UnwindSafe for ContextBase<'a, T>
[src]
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
pub fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> From<T> for T
[src]
impl<T> Instrument for T
[src]
pub fn instrument(self, span: Span) -> Instrumented<Self>
[src]
pub fn in_current_span(self) -> Instrumented<Self>
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T> Same<T> for T
type Output = T
Should always be Self
impl<T> ToOwned for T where
T: Clone,
[src]
T: Clone,
type Owned = T
The resulting type after obtaining ownership.
pub fn to_owned(&self) -> T
[src]
pub fn clone_into(&self, target: &mut T)
[src]
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
pub fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
V: MultiLane<T>,