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/UniqueFragmentNamesRule.js.flow | 34 ++++++++++++++++++++++ 1 file changed, 34 insertions(+) create mode 100644 school/node_modules/graphql/validation/rules/UniqueFragmentNamesRule.js.flow (limited to 'school/node_modules/graphql/validation/rules/UniqueFragmentNamesRule.js.flow') diff --git a/school/node_modules/graphql/validation/rules/UniqueFragmentNamesRule.js.flow b/school/node_modules/graphql/validation/rules/UniqueFragmentNamesRule.js.flow new file mode 100644 index 0000000..cb1b777 --- /dev/null +++ b/school/node_modules/graphql/validation/rules/UniqueFragmentNamesRule.js.flow @@ -0,0 +1,34 @@ +// @flow strict +import { GraphQLError } from '../../error/GraphQLError'; + +import type { ASTVisitor } from '../../language/visitor'; + +import type { ASTValidationContext } from '../ValidationContext'; + +/** + * Unique fragment names + * + * A GraphQL document is only valid if all defined fragments have unique names. + */ +export function UniqueFragmentNamesRule( + context: ASTValidationContext, +): ASTVisitor { + const knownFragmentNames = Object.create(null); + return { + OperationDefinition: () => false, + FragmentDefinition(node) { + const fragmentName = node.name.value; + if (knownFragmentNames[fragmentName]) { + context.reportError( + new GraphQLError( + `There can be only one fragment named "${fragmentName}".`, + [knownFragmentNames[fragmentName], node.name], + ), + ); + } else { + knownFragmentNames[fragmentName] = node.name; + } + return false; + }, + }; +} -- cgit