🎬 That's a Wrap for GraphQLConf 2024! • Watch the Videos • Check out the recorded talks and workshops
v16graphql/execution

graphql/execution

The graphql/execution module is responsible for the execution phase of fulfilling a GraphQL request. You can import either from the graphql/execution module, or from the root graphql module. For example:

import { execute } from 'graphql'; // ES6
const { execute } = require('graphql'); // CommonJS

Overview

Execution

execute

export function execute(
  schema: GraphQLSchema,
  documentAST: Document,
  rootValue?: mixed,
  contextValue?: mixed,
  variableValues?: { [key: string]: mixed },
  operationName?: string,
): MaybePromise<ExecutionResult>;
 
type MaybePromise<T> = Promise<T> | T;
 
interface ExecutionResult<
  TData = ObjMap<unknown>,
  TExtensions = ObjMap<unknown>,
> {
  errors?: ReadonlyArray<GraphQLError>;
  data?: TData | null;
  extensions?: TExtensions;
}

Implements the “Evaluating requests” section of the GraphQL specification.

Returns a Promise that will eventually be resolved and never rejected.

If the arguments to this function do not result in a legal execution context, a GraphQLError will be thrown immediately explaining the invalid input.

ExecutionResult represents the result of execution. data is the result of executing the query, errors is null if no errors occurred, and is a non-empty array if an error occurred.

executeSync

export function executeSync(
  schema: GraphQLSchema,
  documentAST: Document,
  rootValue?: mixed,
  contextValue?: mixed,
  variableValues?: { [key: string]: mixed },
  operationName?: string,
): ExecutionResult;
 
type ExecutionResult = {
  data: Object;
  errors?: GraphQLError[];
};

This is a short-hand method that will call execute and when the response can be returned synchronously it will be returned, when a Promise is returned this method will throw an error.