Struct juniper::RootNode

source ·
pub struct RootNode<'a, QueryT: GraphQLType<S>, MutationT: GraphQLType<S>, SubscriptionT: GraphQLType<S>, S = DefaultScalarValue>
where S: ScalarValue,
{ /* private fields */ }
Expand description

Root query node of a schema

This brings the mutation, subscription and query types together, and provides the predefined metadata fields.

Implementations§

source§

impl<'a, QueryT, MutationT, SubscriptionT> RootNode<'a, QueryT, MutationT, SubscriptionT, DefaultScalarValue>
where QueryT: GraphQLType<DefaultScalarValue, TypeInfo = ()>, MutationT: GraphQLType<DefaultScalarValue, TypeInfo = ()>, SubscriptionT: GraphQLType<DefaultScalarValue, TypeInfo = ()>,

source

pub fn new( query: QueryT, mutation: MutationT, subscription: SubscriptionT ) -> Self

Constructs a new RootNode from query, mutation and subscription nodes, parametrizing it with a DefaultScalarValue.

source§

impl<'a, QueryT, MutationT, SubscriptionT, S> RootNode<'a, QueryT, MutationT, SubscriptionT, S>
where S: ScalarValue + 'a, QueryT: GraphQLType<S, TypeInfo = ()>, MutationT: GraphQLType<S, TypeInfo = ()>, SubscriptionT: GraphQLType<S, TypeInfo = ()>,

source

pub fn new_with_scalar_value( query: QueryT, mutation: MutationT, subscription: SubscriptionT ) -> Self

Constructs a new RootNode from query, mutation and subscription nodes, parametrizing it with the provided ScalarValue.

source§

impl<'a, S, QueryT, MutationT, SubscriptionT> RootNode<'a, QueryT, MutationT, SubscriptionT, S>
where QueryT: GraphQLType<S>, MutationT: GraphQLType<S>, SubscriptionT: GraphQLType<S>, S: ScalarValue + 'a,

source

pub fn new_with_info( query_obj: QueryT, mutation_obj: MutationT, subscription_obj: SubscriptionT, query_info: QueryT::TypeInfo, mutation_info: MutationT::TypeInfo, subscription_info: SubscriptionT::TypeInfo ) -> Self

Construct a new root node from query and mutation nodes, while also providing type info objects for the query and mutation types.

source

pub fn disable_introspection(self) -> Self

Disables introspection for this RootNode, making it to return a [FieldError] whenever its __schema or __type field is resolved.

By default, all introspection queries are allowed.

§Example
pub struct Query;

#[graphql_object]
impl Query {
    fn some() -> bool {
        true
    }
}

type Schema = RootNode<'static, Query, EmptyMutation, EmptySubscription>;

let schema = Schema::new(Query, EmptyMutation::new(), EmptySubscription::new())
    .disable_introspection();

let query = "query { __schema { queryType { name } } }";

match juniper::execute_sync(query, None, &schema, &graphql_vars! {}, &()) {
    Err(GraphQLError::ValidationError(errs)) => {
        assert_eq!(
            errs.first().unwrap().message(),
            "GraphQL introspection is not allowed, but the operation contained `__schema`",
        );
    }
    res => panic!("expected `ValidationError`, returned: {res:#?}"),
}
source

pub fn enable_introspection(self) -> Self

Enables introspection for this RootNode, if it was previously disabled.

By default, all introspection queries are allowed.

source

pub fn as_sdl(&self) -> String

Returns this RootNode as a String containing the schema in [SDL (schema definition language)].

§Sorted

The order of the generated definitions is stable and is sorted in the “type-then-name” manner.

If another sorting order is required, then the as_document() method should be used, which allows to sort the returned Document in the desired manner and then to convert it to_string().

source

pub fn as_document(&'a self) -> Document<'a, &'a str>

Returns this RootNode as a graphql_parser’s Document.

§Unsorted

The order of the generated definitions in the returned Document is NOT stable and may change without any real schema changes.

Trait Implementations§

source§

impl<'a, QueryT: Debug + GraphQLType<S>, MutationT: Debug + GraphQLType<S>, SubscriptionT: Debug + GraphQLType<S>, S> Debug for RootNode<'a, QueryT, MutationT, SubscriptionT, S>
where S: ScalarValue + Debug, QueryT::TypeInfo: Debug, MutationT::TypeInfo: Debug, SubscriptionT::TypeInfo: Debug,

source§

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

Formats the value using the given formatter. Read more
source§

impl<'a, S, QueryT, MutationT, SubscriptionT> GraphQLType<S> for RootNode<'a, QueryT, MutationT, SubscriptionT, S>
where S: ScalarValue, QueryT: GraphQLType<S>, MutationT: GraphQLType<S, Context = QueryT::Context>, SubscriptionT: GraphQLType<S, Context = QueryT::Context>,

source§

fn name(info: &Self::TypeInfo) -> Option<&str>

Returns name of this GraphQLType to expose. Read more
source§

fn meta<'r>( info: &Self::TypeInfo, registry: &mut Registry<'r, S> ) -> MetaType<'r, S>
where S: 'r,

Returns MetaType representing this GraphQLType.
source§

impl<'a, S, QueryT, MutationT, SubscriptionT> GraphQLValue<S> for RootNode<'a, QueryT, MutationT, SubscriptionT, S>
where S: ScalarValue, QueryT: GraphQLType<S>, MutationT: GraphQLType<S, Context = QueryT::Context>, SubscriptionT: GraphQLType<S, Context = QueryT::Context>,

§

type Context = <QueryT as GraphQLValue<S>>::Context

Context type for this GraphQLValue. Read more
§

type TypeInfo = <QueryT as GraphQLValue<S>>::TypeInfo

Type that may carry additional schema information for this GraphQLValue. Read more
source§

fn type_name<'i>(&self, info: &'i Self::TypeInfo) -> Option<&'i str>

Returns name of the GraphQLType exposed by this GraphQLValue. Read more
source§

fn concrete_type_name( &self, context: &Self::Context, info: &Self::TypeInfo ) -> String

Returns the concrete GraphQLType name for this GraphQLValue being an interface, an union or an object. Read more
source§

fn resolve_field( &self, info: &Self::TypeInfo, field: &str, args: &Arguments<'_, S>, executor: &Executor<'_, '_, Self::Context, S> ) -> ExecutionResult<S>

Resolves the value of a single field on this GraphQLValue. Read more
source§

fn resolve( &self, info: &Self::TypeInfo, selection_set: Option<&[Selection<'_, S>]>, executor: &Executor<'_, '_, Self::Context, S> ) -> ExecutionResult<S>

Resolves the provided selection_set against this GraphQLValue. Read more
source§

fn resolve_into_type( &self, info: &Self::TypeInfo, type_name: &str, selection_set: Option<&[Selection<'_, S>]>, executor: &Executor<'_, '_, Self::Context, S> ) -> ExecutionResult<S>

Resolves this GraphQLValue (being an interface or an union) into a concrete downstream object type. Read more
source§

impl<'a, S, QueryT, MutationT, SubscriptionT> GraphQLValueAsync<S> for RootNode<'a, QueryT, MutationT, SubscriptionT, S>
where QueryT: GraphQLTypeAsync<S>, QueryT::TypeInfo: Sync, QueryT::Context: Sync + 'a, MutationT: GraphQLTypeAsync<S, Context = QueryT::Context>, MutationT::TypeInfo: Sync, SubscriptionT: GraphQLType<S, Context = QueryT::Context> + Sync, SubscriptionT::TypeInfo: Sync, S: ScalarValue + Send + Sync,

source§

fn resolve_field_async<'b>( &'b self, info: &'b Self::TypeInfo, field_name: &'b str, arguments: &'b Arguments<'_, S>, executor: &'b Executor<'_, '_, Self::Context, S> ) -> BoxFuture<'b, ExecutionResult<S>>

Resolves the value of a single field on this GraphQLValueAsync. Read more
source§

fn resolve_into_type_async<'a>( &'a self, info: &'a Self::TypeInfo, type_name: &str, selection_set: Option<&'a [Selection<'a, S>]>, executor: &'a Executor<'a, 'a, Self::Context, S> ) -> BoxFuture<'a, ExecutionResult<S>>

Resolves this GraphQLValueAsync (being an interface or an union) into a concrete downstream object type. Read more
source§

fn resolve_async<'a>( &'a self, info: &'a Self::TypeInfo, selection_set: Option<&'a [Selection<'_, S>]>, executor: &'a Executor<'_, '_, Self::Context, S> ) -> BoxFuture<'a, ExecutionResult<S>>

Resolves the provided selection_set against this GraphQLValueAsync. Read more

Auto Trait Implementations§

§

impl<'a, QueryT, MutationT, SubscriptionT, S> Freeze for RootNode<'a, QueryT, MutationT, SubscriptionT, S>
where S: From<f64> + From<i32> + From<bool> + From<String> + Serialize + DeserializeOwned + for<'de> Deserialize<'de> + Clone + PartialEq + Display + Debug + 'static, SubscriptionT: GraphQLValue<S> + Freeze, MutationT: GraphQLValue<S> + Freeze, QueryT: GraphQLValue<S> + Freeze, <QueryT as GraphQLValue<S>>::TypeInfo: Freeze, <MutationT as GraphQLValue<S>>::TypeInfo: Freeze, <SubscriptionT as GraphQLValue<S>>::TypeInfo: Freeze,

§

impl<'a, QueryT, MutationT, SubscriptionT, S> RefUnwindSafe for RootNode<'a, QueryT, MutationT, SubscriptionT, S>
where S: From<f64> + From<i32> + From<bool> + From<String> + Serialize + DeserializeOwned + for<'de> Deserialize<'de> + Clone + PartialEq + Display + Debug + 'static + RefUnwindSafe, SubscriptionT: GraphQLValue<S> + RefUnwindSafe, MutationT: GraphQLValue<S> + RefUnwindSafe, QueryT: GraphQLValue<S> + RefUnwindSafe, <QueryT as GraphQLValue<S>>::TypeInfo: RefUnwindSafe, <MutationT as GraphQLValue<S>>::TypeInfo: RefUnwindSafe, <SubscriptionT as GraphQLValue<S>>::TypeInfo: RefUnwindSafe,

§

impl<'a, QueryT, MutationT, SubscriptionT, S> Send for RootNode<'a, QueryT, MutationT, SubscriptionT, S>
where S: From<f64> + From<i32> + From<bool> + From<String> + Serialize + DeserializeOwned + for<'de> Deserialize<'de> + Clone + PartialEq + Display + Debug + 'static + Send, SubscriptionT: GraphQLValue<S> + Send, MutationT: GraphQLValue<S> + Send, QueryT: GraphQLValue<S> + Send, <QueryT as GraphQLValue<S>>::TypeInfo: Send, <MutationT as GraphQLValue<S>>::TypeInfo: Send, <SubscriptionT as GraphQLValue<S>>::TypeInfo: Send,

§

impl<'a, QueryT, MutationT, SubscriptionT, S> Sync for RootNode<'a, QueryT, MutationT, SubscriptionT, S>
where S: From<f64> + From<i32> + From<bool> + From<String> + Serialize + DeserializeOwned + for<'de> Deserialize<'de> + Clone + PartialEq + Display + Debug + 'static + Sync, SubscriptionT: GraphQLValue<S> + Sync, MutationT: GraphQLValue<S> + Sync, QueryT: GraphQLValue<S> + Sync, <QueryT as GraphQLValue<S>>::TypeInfo: Sync, <MutationT as GraphQLValue<S>>::TypeInfo: Sync, <SubscriptionT as GraphQLValue<S>>::TypeInfo: Sync,

§

impl<'a, QueryT, MutationT, SubscriptionT, S> Unpin for RootNode<'a, QueryT, MutationT, SubscriptionT, S>
where S: From<f64> + From<i32> + From<bool> + From<String> + Serialize + DeserializeOwned + for<'de> Deserialize<'de> + Clone + PartialEq + Display + Debug + 'static + Unpin, SubscriptionT: GraphQLValue<S> + Unpin, MutationT: GraphQLValue<S> + Unpin, QueryT: GraphQLValue<S> + Unpin, <QueryT as GraphQLValue<S>>::TypeInfo: Unpin, <MutationT as GraphQLValue<S>>::TypeInfo: Unpin, <SubscriptionT as GraphQLValue<S>>::TypeInfo: Unpin,

§

impl<'a, QueryT, MutationT, SubscriptionT, S> UnwindSafe for RootNode<'a, QueryT, MutationT, SubscriptionT, S>
where S: From<f64> + From<i32> + From<bool> + From<String> + Serialize + DeserializeOwned + for<'de> Deserialize<'de> + Clone + PartialEq + Display + Debug + 'static + UnwindSafe, SubscriptionT: GraphQLValue<S> + UnwindSafe, MutationT: GraphQLValue<S> + UnwindSafe, QueryT: GraphQLValue<S> + UnwindSafe, <QueryT as GraphQLValue<S>>::TypeInfo: UnwindSafe, <MutationT as GraphQLValue<S>>::TypeInfo: UnwindSafe, <SubscriptionT as GraphQLValue<S>>::TypeInfo: UnwindSafe,

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> Conv for T

source§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
source§

impl<T> FmtForward for T

source§

fn fmt_binary(self) -> FmtBinary<Self>
where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
source§

fn fmt_display(self) -> FmtDisplay<Self>
where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
source§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>
where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
source§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>
where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
source§

fn fmt_octal(self) -> FmtOctal<Self>
where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
source§

fn fmt_pointer(self) -> FmtPointer<Self>
where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
source§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>
where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
source§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>
where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
source§

fn fmt_list(self) -> FmtList<Self>
where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

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> Pipe for T
where T: ?Sized,

source§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
source§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
source§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
source§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
source§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
source§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
source§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
source§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
source§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
source§

impl<T> Tap for T

source§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
source§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
source§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
source§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
source§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
source§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
source§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
source§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
source§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
source§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
source§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
source§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
source§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
source§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
source§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
source§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
source§

impl<T> TryConv for T

source§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. Read more
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