mirror of
https://github.com/JamesIves/github-pages-deploy-action.git
synced 2023-12-15 20:03:39 +08:00
40 lines
1.2 KiB
Plaintext
40 lines
1.2 KiB
Plaintext
|
// @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 './getIntrospectionQuery';
|
||
|
|
||
|
/**
|
||
|
* 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 optionsWithDefaults = {
|
||
|
directiveIsRepeatable: true,
|
||
|
schemaDescription: true,
|
||
|
...options,
|
||
|
};
|
||
|
|
||
|
const document = parse(getIntrospectionQuery(optionsWithDefaults));
|
||
|
const result = execute({ schema, document });
|
||
|
invariant(!isPromise(result) && !result.errors && result.data);
|
||
|
return (result.data: any);
|
||
|
}
|