pub type GraphQLSchema = Schema<Query, Mutation, EmptySubscription>;
Aliased Type§
struct GraphQLSchema(/* private fields */);
Implementations
Source§impl<Query, Mutation, Subscription> Schema<Query, Mutation, Subscription>where
Query: ObjectType + 'static,
Mutation: ObjectType + 'static,
Subscription: SubscriptionType + 'static,
impl<Query, Mutation, Subscription> Schema<Query, Mutation, Subscription>where
Query: ObjectType + 'static,
Mutation: ObjectType + 'static,
Subscription: SubscriptionType + 'static,
Sourcepub fn build(
query: Query,
mutation: Mutation,
subscription: Subscription,
) -> SchemaBuilder<Query, Mutation, Subscription>
pub fn build( query: Query, mutation: Mutation, subscription: Subscription, ) -> SchemaBuilder<Query, Mutation, Subscription>
Create a schema builder
The root object for the query and Mutation needs to be specified.
If there is no mutation, you can use EmptyMutation
.
If there is no subscription, you can use EmptySubscription
.
Sourcepub fn build_with_ignore_name_conflicts<I, T>(
query: Query,
mutation: Mutation,
subscription: Subscription,
ignore_name_conflicts: I,
) -> SchemaBuilder<Query, Mutation, Subscription>
pub fn build_with_ignore_name_conflicts<I, T>( query: Query, mutation: Mutation, subscription: Subscription, ignore_name_conflicts: I, ) -> SchemaBuilder<Query, Mutation, Subscription>
Create a schema builder and specifies a list to ignore type conflict detection.
NOTE: It is not recommended to use it unless you know what it does.
Sourcepub fn new(
query: Query,
mutation: Mutation,
subscription: Subscription,
) -> Schema<Query, Mutation, Subscription>
pub fn new( query: Query, mutation: Mutation, subscription: Subscription, ) -> Schema<Query, Mutation, Subscription>
Create a schema
Sourcepub fn sdl_with_options(&self, options: SDLExportOptions) -> String
pub fn sdl_with_options(&self, options: SDLExportOptions) -> String
Returns SDL(Schema Definition Language) of this schema with options.
Sourcepub fn names(&self) -> Vec<String>
pub fn names(&self) -> Vec<String>
Get all names in this schema
Maybe you want to serialize a custom binary protocol. In order to minimize message size, a dictionary is usually used to compress type names, field names, directive names, and parameter names. This function gets all the names, so you can create this dictionary.
Sourcepub async fn execute_batch(&self, batch_request: BatchRequest) -> BatchResponse
pub async fn execute_batch(&self, batch_request: BatchRequest) -> BatchResponse
Execute a GraphQL batch query.
Trait Implementations
Source§impl<Query, Mutation, Subscription> Default for Schema<Query, Mutation, Subscription>where
Query: Default + ObjectType + 'static,
Mutation: Default + ObjectType + 'static,
Subscription: Default + SubscriptionType + 'static,
impl<Query, Mutation, Subscription> Default for Schema<Query, Mutation, Subscription>where
Query: Default + ObjectType + 'static,
Mutation: Default + ObjectType + 'static,
Subscription: Default + SubscriptionType + 'static,
Source§impl<Query, Mutation, Subscription> Executor for Schema<Query, Mutation, Subscription>where
Query: ObjectType + 'static,
Mutation: ObjectType + 'static,
Subscription: SubscriptionType + 'static,
impl<Query, Mutation, Subscription> Executor for Schema<Query, Mutation, Subscription>where
Query: ObjectType + 'static,
Mutation: ObjectType + 'static,
Subscription: SubscriptionType + 'static,
Source§fn execute_stream(
&self,
request: Request,
session_data: Option<Arc<Data>>,
) -> Pin<Box<dyn Stream<Item = Response> + Send>>
fn execute_stream( &self, request: Request, session_data: Option<Arc<Data>>, ) -> Pin<Box<dyn Stream<Item = Response> + Send>>
Execute a GraphQL subscription with session data.
Source§fn execute_batch(
&self,
batch_request: BatchRequest,
) -> impl Future<Output = BatchResponse> + Send
fn execute_batch( &self, batch_request: BatchRequest, ) -> impl Future<Output = BatchResponse> + Send
Execute a GraphQL batch query.