UNPKG

@graphql-eslint/eslint-plugin

Version:
113 lines (112 loc) 3.52 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.rule = void 0; const graphql_1 = require("graphql"); const RULE_ID = 'no-duplicate-fields'; exports.rule = { meta: { type: 'suggestion', hasSuggestions: true, docs: { description: 'Checks for duplicate fields in selection set, variables in operation definition, or in arguments set of a field.', category: 'Operations', url: `https://github.com/B2o5T/graphql-eslint/blob/master/docs/rules/${RULE_ID}.md`, recommended: true, examples: [ { title: 'Incorrect', code: /* GraphQL */ ` query { user { name email name # duplicate field } } `, }, { title: 'Incorrect', code: /* GraphQL */ ` query { users( first: 100 skip: 50 after: "cji629tngfgou0b73kt7vi5jo" first: 100 # duplicate argument ) { id } } `, }, { title: 'Incorrect', code: /* GraphQL */ ` query ( $first: Int! $first: Int! # duplicate variable ) { users(first: $first, skip: 50) { id } } `, }, ], }, messages: { [RULE_ID]: '{{ type }} `{{ fieldName }}` defined multiple times.', }, schema: [], }, create(context) { function checkNode(usedFields, node) { const fieldName = node.value; if (usedFields.has(fieldName)) { const { parent } = node; context.report({ node, messageId: RULE_ID, data: { type: parent.type, fieldName, }, suggest: [ { desc: `Remove \`${fieldName}\` ${parent.type.toLowerCase()}`, fix(fixer) { return fixer.remove((parent.type === graphql_1.Kind.VARIABLE ? parent.parent : parent)); }, }, ], }); } else { usedFields.add(fieldName); } } return { OperationDefinition(node) { const set = new Set(); for (const varDef of node.variableDefinitions) { checkNode(set, varDef.variable.name); } }, Field(node) { const set = new Set(); for (const arg of node.arguments) { checkNode(set, arg.name); } }, SelectionSet(node) { const set = new Set(); for (const selection of node.selections) { if (selection.kind === graphql_1.Kind.FIELD) { checkNode(set, selection.alias || selection.name); } } }, }; }, };