From 99c1d9af689e5325f3cf535c4007b3aeb8325229 Mon Sep 17 00:00:00 2001 From: Minteck Date: Tue, 10 Jan 2023 14:54:04 +0100 Subject: Update - This is an automated commit --- .../utilities/introspectionFromSchema.js.flow | 41 ++++++++++++++++++++++ 1 file changed, 41 insertions(+) create mode 100644 school/node_modules/graphql/utilities/introspectionFromSchema.js.flow (limited to 'school/node_modules/graphql/utilities/introspectionFromSchema.js.flow') diff --git a/school/node_modules/graphql/utilities/introspectionFromSchema.js.flow b/school/node_modules/graphql/utilities/introspectionFromSchema.js.flow new file mode 100644 index 0000000..0a73fe0 --- /dev/null +++ b/school/node_modules/graphql/utilities/introspectionFromSchema.js.flow @@ -0,0 +1,41 @@ +// @flow strict +import invariant from '../jsutils/invariant'; + +import { parse } from '../language/parser'; + +import type { GraphQLSchema } from '../type/schema'; + +import { executeSync } from '../execution/execute'; + +import type { + IntrospectionQuery, + IntrospectionOptions, +} from './getIntrospectionQuery'; +import { 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 = { + specifiedByUrl: true, + directiveIsRepeatable: true, + schemaDescription: true, + inputValueDeprecation: true, + ...options, + }; + + const document = parse(getIntrospectionQuery(optionsWithDefaults)); + const result = executeSync({ schema, document }); + invariant(!result.errors && result.data); + return (result.data: any); +} -- cgit