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/SingleFieldSubscriptionsRule.js.flow | 33 ++++++++++++++++++++++ 1 file changed, 33 insertions(+) create mode 100644 school/node_modules/graphql/validation/rules/SingleFieldSubscriptionsRule.js.flow (limited to 'school/node_modules/graphql/validation/rules/SingleFieldSubscriptionsRule.js.flow') diff --git a/school/node_modules/graphql/validation/rules/SingleFieldSubscriptionsRule.js.flow b/school/node_modules/graphql/validation/rules/SingleFieldSubscriptionsRule.js.flow new file mode 100644 index 0000000..290432f --- /dev/null +++ b/school/node_modules/graphql/validation/rules/SingleFieldSubscriptionsRule.js.flow @@ -0,0 +1,33 @@ +// @flow strict +import { GraphQLError } from '../../error/GraphQLError'; + +import type { ASTVisitor } from '../../language/visitor'; +import type { OperationDefinitionNode } from '../../language/ast'; + +import type { ASTValidationContext } from '../ValidationContext'; + +/** + * Subscriptions must only include one field. + * + * A GraphQL subscription is valid only if it contains a single root field. + */ +export function SingleFieldSubscriptionsRule( + context: ASTValidationContext, +): ASTVisitor { + return { + OperationDefinition(node: OperationDefinitionNode) { + if (node.operation === 'subscription') { + if (node.selectionSet.selections.length !== 1) { + context.reportError( + new GraphQLError( + node.name + ? `Subscription "${node.name.value}" must select only one top level field.` + : 'Anonymous Subscription must select only one top level field.', + node.selectionSet.selections.slice(1), + ), + ); + } + } + }, + }; +} -- cgit