From 2c4ae43e688a9873e86211ea0e7aeb9ba770dd77 Mon Sep 17 00:00:00 2001 From: Minteck Date: Tue, 18 Oct 2022 08:59:09 +0200 Subject: Update --- .../validation/rules/ScalarLeafsRule.js.flow | 49 ++++++++++++++++++++++ 1 file changed, 49 insertions(+) create mode 100644 alarm/node_modules/graphql/validation/rules/ScalarLeafsRule.js.flow (limited to 'alarm/node_modules/graphql/validation/rules/ScalarLeafsRule.js.flow') diff --git a/alarm/node_modules/graphql/validation/rules/ScalarLeafsRule.js.flow b/alarm/node_modules/graphql/validation/rules/ScalarLeafsRule.js.flow new file mode 100644 index 0000000..cac22c5 --- /dev/null +++ b/alarm/node_modules/graphql/validation/rules/ScalarLeafsRule.js.flow @@ -0,0 +1,49 @@ +// @flow strict +import inspect from '../../jsutils/inspect'; + +import { GraphQLError } from '../../error/GraphQLError'; + +import type { FieldNode } from '../../language/ast'; +import type { ASTVisitor } from '../../language/visitor'; + +import { getNamedType, isLeafType } from '../../type/definition'; + +import type { ValidationContext } from '../ValidationContext'; + +/** + * Scalar leafs + * + * A GraphQL document is valid only if all leaf fields (fields without + * sub selections) are of scalar or enum types. + */ +export function ScalarLeafsRule(context: ValidationContext): ASTVisitor { + return { + Field(node: FieldNode) { + const type = context.getType(); + const selectionSet = node.selectionSet; + if (type) { + if (isLeafType(getNamedType(type))) { + if (selectionSet) { + const fieldName = node.name.value; + const typeStr = inspect(type); + context.reportError( + new GraphQLError( + `Field "${fieldName}" must not have a selection since type "${typeStr}" has no subfields.`, + selectionSet, + ), + ); + } + } else if (!selectionSet) { + const fieldName = node.name.value; + const typeStr = inspect(type); + context.reportError( + new GraphQLError( + `Field "${fieldName}" of type "${typeStr}" must have a selection of subfields. Did you mean "${fieldName} { ... }"?`, + node, + ), + ); + } + } + }, + }; +} -- cgit