summaryrefslogtreecommitdiff
path: root/alarm/node_modules/graphql/validation/rules/UniqueDirectivesPerLocationRule.js.flow
diff options
context:
space:
mode:
authorMinteck <contact@minteck.org>2023-01-10 14:54:04 +0100
committerMinteck <contact@minteck.org>2023-01-10 14:54:04 +0100
commit99c1d9af689e5325f3cf535c4007b3aeb8325229 (patch)
treee663b3c2ebdbd67c818ac0c5147f0ce1d2463cda /alarm/node_modules/graphql/validation/rules/UniqueDirectivesPerLocationRule.js.flow
parent9871b03912fc28ad38b4037ebf26a78aa937baba (diff)
downloadpluralconnect-99c1d9af689e5325f3cf535c4007b3aeb8325229.tar.gz
pluralconnect-99c1d9af689e5325f3cf535c4007b3aeb8325229.tar.bz2
pluralconnect-99c1d9af689e5325f3cf535c4007b3aeb8325229.zip
Update - This is an automated commit
Diffstat (limited to 'alarm/node_modules/graphql/validation/rules/UniqueDirectivesPerLocationRule.js.flow')
-rw-r--r--alarm/node_modules/graphql/validation/rules/UniqueDirectivesPerLocationRule.js.flow90
1 files changed, 0 insertions, 90 deletions
diff --git a/alarm/node_modules/graphql/validation/rules/UniqueDirectivesPerLocationRule.js.flow b/alarm/node_modules/graphql/validation/rules/UniqueDirectivesPerLocationRule.js.flow
deleted file mode 100644
index a753a84..0000000
--- a/alarm/node_modules/graphql/validation/rules/UniqueDirectivesPerLocationRule.js.flow
+++ /dev/null
@@ -1,90 +0,0 @@
-// @flow strict
-import { GraphQLError } from '../../error/GraphQLError';
-
-import { Kind } from '../../language/kinds';
-import type { ASTVisitor } from '../../language/visitor';
-import {
- isTypeDefinitionNode,
- isTypeExtensionNode,
-} from '../../language/predicates';
-
-import { specifiedDirectives } from '../../type/directives';
-
-import type {
- SDLValidationContext,
- ValidationContext,
-} from '../ValidationContext';
-
-/**
- * Unique directive names per location
- *
- * A GraphQL document is only valid if all non-repeatable directives at
- * a given location are uniquely named.
- */
-export function UniqueDirectivesPerLocationRule(
- context: ValidationContext | SDLValidationContext,
-): ASTVisitor {
- const uniqueDirectiveMap = Object.create(null);
-
- const schema = context.getSchema();
- const definedDirectives = schema
- ? schema.getDirectives()
- : specifiedDirectives;
- for (const directive of definedDirectives) {
- uniqueDirectiveMap[directive.name] = !directive.isRepeatable;
- }
-
- const astDefinitions = context.getDocument().definitions;
- for (const def of astDefinitions) {
- if (def.kind === Kind.DIRECTIVE_DEFINITION) {
- uniqueDirectiveMap[def.name.value] = !def.repeatable;
- }
- }
-
- const schemaDirectives = Object.create(null);
- const typeDirectivesMap = Object.create(null);
-
- return {
- // Many different AST nodes may contain directives. Rather than listing
- // them all, just listen for entering any node, and check to see if it
- // defines any directives.
- enter(node) {
- if (node.directives == null) {
- return;
- }
-
- let seenDirectives;
- if (
- node.kind === Kind.SCHEMA_DEFINITION ||
- node.kind === Kind.SCHEMA_EXTENSION
- ) {
- seenDirectives = schemaDirectives;
- } else if (isTypeDefinitionNode(node) || isTypeExtensionNode(node)) {
- const typeName = node.name.value;
- seenDirectives = typeDirectivesMap[typeName];
- if (seenDirectives === undefined) {
- typeDirectivesMap[typeName] = seenDirectives = Object.create(null);
- }
- } else {
- seenDirectives = Object.create(null);
- }
-
- for (const directive of node.directives) {
- const directiveName = directive.name.value;
-
- if (uniqueDirectiveMap[directiveName]) {
- if (seenDirectives[directiveName]) {
- context.reportError(
- new GraphQLError(
- `The directive "@${directiveName}" can only be used once at this location.`,
- [seenDirectives[directiveName], directive],
- ),
- );
- } else {
- seenDirectives[directiveName] = directive;
- }
- }
- }
- },
- };
-}