flow like the river
This commit is contained in:
commit
013fe673f3
42435 changed files with 5764238 additions and 0 deletions
44
BACK_BACK/node_modules/graphql/validation/rules/UniqueInputFieldNamesRule.js.flow
generated
vendored
Executable file
44
BACK_BACK/node_modules/graphql/validation/rules/UniqueInputFieldNamesRule.js.flow
generated
vendored
Executable file
|
|
@ -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;
|
||||
}
|
||||
},
|
||||
};
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue