From 2c4ae43e688a9873e86211ea0e7aeb9ba770dd77 Mon Sep 17 00:00:00 2001 From: Minteck Date: Tue, 18 Oct 2022 08:59:09 +0200 Subject: Update --- .../rules/ExecutableDefinitionsRule.js.flow | 39 ++++++++++++++++++++++ 1 file changed, 39 insertions(+) create mode 100644 alarm/node_modules/graphql/validation/rules/ExecutableDefinitionsRule.js.flow (limited to 'alarm/node_modules/graphql/validation/rules/ExecutableDefinitionsRule.js.flow') diff --git a/alarm/node_modules/graphql/validation/rules/ExecutableDefinitionsRule.js.flow b/alarm/node_modules/graphql/validation/rules/ExecutableDefinitionsRule.js.flow new file mode 100644 index 0000000..06c0d52 --- /dev/null +++ b/alarm/node_modules/graphql/validation/rules/ExecutableDefinitionsRule.js.flow @@ -0,0 +1,39 @@ +// @flow strict +import { GraphQLError } from '../../error/GraphQLError'; + +import type { ASTVisitor } from '../../language/visitor'; +import { Kind } from '../../language/kinds'; +import { isExecutableDefinitionNode } from '../../language/predicates'; + +import type { ASTValidationContext } from '../ValidationContext'; + +/** + * Executable definitions + * + * A GraphQL document is only valid for execution if all definitions are either + * operation or fragment definitions. + */ +export function ExecutableDefinitionsRule( + context: ASTValidationContext, +): ASTVisitor { + return { + Document(node) { + for (const definition of node.definitions) { + if (!isExecutableDefinitionNode(definition)) { + const defName = + definition.kind === Kind.SCHEMA_DEFINITION || + definition.kind === Kind.SCHEMA_EXTENSION + ? 'schema' + : '"' + definition.name.value + '"'; + context.reportError( + new GraphQLError( + `The ${defName} definition is not executable.`, + definition, + ), + ); + } + } + return false; + }, + }; +} -- cgit