diff options
Diffstat (limited to 'alarm/node_modules/graphql/validation/rules/UniqueInputFieldNamesRule.js.flow')
-rw-r--r-- | alarm/node_modules/graphql/validation/rules/UniqueInputFieldNamesRule.js.flow | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/alarm/node_modules/graphql/validation/rules/UniqueInputFieldNamesRule.js.flow b/alarm/node_modules/graphql/validation/rules/UniqueInputFieldNamesRule.js.flow new file mode 100644 index 0000000..e79cd7a --- /dev/null +++ b/alarm/node_modules/graphql/validation/rules/UniqueInputFieldNamesRule.js.flow @@ -0,0 +1,44 @@ +// @flow strict +import { GraphQLError } from '../../error/GraphQLError'; + +import type { ASTVisitor } from '../../language/visitor'; + +import type { ASTValidationContext } from '../ValidationContext'; + +/** + * Unique input field names + * + * A GraphQL input object value is only valid if all supplied fields are + * uniquely named. + */ +export function UniqueInputFieldNamesRule( + context: ASTValidationContext, +): ASTVisitor { + const knownNameStack = []; + let knownNames = Object.create(null); + + return { + ObjectValue: { + enter() { + knownNameStack.push(knownNames); + knownNames = Object.create(null); + }, + leave() { + knownNames = knownNameStack.pop(); + }, + }, + ObjectField(node) { + const fieldName = node.name.value; + if (knownNames[fieldName]) { + context.reportError( + new GraphQLError( + `There can be only one input field named "${fieldName}".`, + [knownNames[fieldName], node.name], + ), + ); + } else { + knownNames[fieldName] = node.name; + } + }, + }; +} |