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 --- .../rules/NoUndefinedVariablesRule.js.flow | 46 ++++++++++++++++++++++ 1 file changed, 46 insertions(+) create mode 100644 school/node_modules/graphql/validation/rules/NoUndefinedVariablesRule.js.flow (limited to 'school/node_modules/graphql/validation/rules/NoUndefinedVariablesRule.js.flow') diff --git a/school/node_modules/graphql/validation/rules/NoUndefinedVariablesRule.js.flow b/school/node_modules/graphql/validation/rules/NoUndefinedVariablesRule.js.flow new file mode 100644 index 0000000..1773ada --- /dev/null +++ b/school/node_modules/graphql/validation/rules/NoUndefinedVariablesRule.js.flow @@ -0,0 +1,46 @@ +// @flow strict +import { GraphQLError } from '../../error/GraphQLError'; + +import type { ASTVisitor } from '../../language/visitor'; + +import type { ValidationContext } from '../ValidationContext'; + +/** + * No undefined variables + * + * A GraphQL operation is only valid if all variables encountered, both directly + * and via fragment spreads, are defined by that operation. + */ +export function NoUndefinedVariablesRule( + context: ValidationContext, +): ASTVisitor { + let variableNameDefined = Object.create(null); + + return { + OperationDefinition: { + enter() { + variableNameDefined = Object.create(null); + }, + leave(operation) { + const usages = context.getRecursiveVariableUsages(operation); + + for (const { node } of usages) { + const varName = node.name.value; + if (variableNameDefined[varName] !== true) { + context.reportError( + new GraphQLError( + operation.name + ? `Variable "$${varName}" is not defined by operation "${operation.name.value}".` + : `Variable "$${varName}" is not defined.`, + [node, operation], + ), + ); + } + } + }, + }, + VariableDefinition(node) { + variableNameDefined[node.variable.name.value] = true; + }, + }; +} -- cgit