introspectionFromSchema.js.flow 1.04 KB
Newer Older
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
// @flow strict

import invariant from '../jsutils/invariant';
import isPromise from '../jsutils/isPromise';

import { parse } from '../language/parser';
import { execute } from '../execution/execute';
import { type GraphQLSchema } from '../type/schema';

import {
  type IntrospectionQuery,
  type IntrospectionOptions,
  getIntrospectionQuery,
} from './introspectionQuery';

/**
 * Build an IntrospectionQuery from a GraphQLSchema
 *
 * IntrospectionQuery is useful for utilities that care about type and field
 * relationships, but do not need to traverse through those relationships.
 *
 * This is the inverse of buildClientSchema. The primary use case is outside
 * of the server context, for instance when doing schema comparisons.
 */
export function introspectionFromSchema(
  schema: GraphQLSchema,
  options?: IntrospectionOptions,
): IntrospectionQuery {
  const queryAST = parse(getIntrospectionQuery(options));
  const result = execute(schema, queryAST);
  invariant(!isPromise(result) && !result.errors && result.data);
  return (result.data: any);
}