diff --git a/src/index.d.ts b/src/index.d.ts index ddf092347fb..317602293e5 100644 --- a/src/index.d.ts +++ b/src/index.d.ts @@ -160,14 +160,12 @@ export { GraphQLField, GraphQLFieldConfig, GraphQLFieldExtensions, - GraphQLFieldConfigArgumentMap, GraphQLFieldConfigMap, GraphQLFieldMap, GraphQLFieldResolver, GraphQLInputField, GraphQLInputFieldConfig, GraphQLInputFieldExtensions, - GraphQLInputFieldConfigMap, GraphQLInputFieldMap, GraphQLInputObjectTypeConfig, GraphQLInputObjectTypeExtensions, diff --git a/src/index.js b/src/index.js index a9864a384f4..b46f10cd3a0 100644 --- a/src/index.js +++ b/src/index.js @@ -153,13 +153,11 @@ export type { GraphQLEnumValueConfigMap, GraphQLField, GraphQLFieldConfig, - GraphQLFieldConfigArgumentMap, GraphQLFieldConfigMap, GraphQLFieldMap, GraphQLFieldResolver, GraphQLInputField, GraphQLInputFieldConfig, - GraphQLInputFieldConfigMap, GraphQLInputFieldMap, GraphQLInputObjectTypeConfig, GraphQLInterfaceTypeConfig, diff --git a/src/type/definition.d.ts b/src/type/definition.d.ts index 3614db5b1bb..f07202d91af 100644 --- a/src/type/definition.d.ts +++ b/src/type/definition.d.ts @@ -516,7 +516,7 @@ export interface GraphQLFieldConfig< > { description?: Maybe; type: GraphQLOutputType; - args?: GraphQLFieldConfigArgumentMap; + args?: ObjMap; resolve?: GraphQLFieldResolver; subscribe?: GraphQLFieldResolver; deprecationReason?: Maybe; @@ -526,8 +526,6 @@ export interface GraphQLFieldConfig< astNode?: Maybe; } -export type GraphQLFieldConfigArgumentMap = ObjMap; - /** * Custom extensions * @@ -885,7 +883,7 @@ export class GraphQLInputObjectType { getFields(): GraphQLInputFieldMap; toConfig(): GraphQLInputObjectTypeConfig & { - fields: GraphQLInputFieldConfigMap; + fields: ObjMap; extensions: Maybe>; extensionASTNodes: ReadonlyArray; }; @@ -920,8 +918,6 @@ export interface GraphQLInputFieldExtensions { export type GraphQLInputFieldConfig = GraphQLInputValueConfig; -export type GraphQLInputFieldConfigMap = ObjMap; - export type GraphQLInputField = GraphQLInputValue; export function isRequiredInputField(field: GraphQLInputField): boolean; diff --git a/src/type/definition.js b/src/type/definition.js index 8a7f0a72b14..c16433d5b31 100644 --- a/src/type/definition.js +++ b/src/type/definition.js @@ -918,7 +918,7 @@ export type GraphQLFieldConfig< > = {| description?: ?string, type: GraphQLOutputType, - args?: GraphQLFieldConfigArgumentMap, + args?: ObjMap, resolve?: GraphQLFieldResolver, subscribe?: GraphQLFieldResolver, deprecationReason?: ?string, @@ -926,8 +926,6 @@ export type GraphQLFieldConfig< astNode?: ?FieldDefinitionNode, |}; -export type GraphQLFieldConfigArgumentMap = ObjMap; - export type GraphQLArgumentConfig = GraphQLInputValueConfig; export type GraphQLFieldConfigMap = ObjMap< @@ -1561,15 +1559,13 @@ export type GraphQLInputObjectTypeConfig = {| type GraphQLInputObjectTypeNormalizedConfig = {| ...GraphQLInputObjectTypeConfig, - fields: GraphQLInputFieldConfigMap, + fields: ObjMap, extensions: ?ReadOnlyObjMap, extensionASTNodes: $ReadOnlyArray, |}; export type GraphQLInputFieldConfig = GraphQLInputValueConfig; -export type GraphQLInputFieldConfigMap = ObjMap; - export type GraphQLInputField = GraphQLInputValue; export const isRequiredInputField = isRequiredInput; diff --git a/src/type/index.d.ts b/src/type/index.d.ts index fc7c22ead89..365256dfd1d 100644 --- a/src/type/index.d.ts +++ b/src/type/index.d.ts @@ -91,14 +91,12 @@ export { GraphQLEnumValueExtensions, GraphQLField, GraphQLFieldConfig, - GraphQLFieldConfigArgumentMap, GraphQLFieldConfigMap, GraphQLFieldExtensions, GraphQLFieldMap, GraphQLFieldResolver, GraphQLInputField, GraphQLInputFieldConfig, - GraphQLInputFieldConfigMap, GraphQLInputFieldExtensions, GraphQLInputFieldMap, GraphQLInputObjectTypeConfig, diff --git a/src/type/index.js b/src/type/index.js index 851d9a192d8..6bf0943f228 100644 --- a/src/type/index.js +++ b/src/type/index.js @@ -143,13 +143,11 @@ export type { GraphQLEnumValueConfigMap, GraphQLField, GraphQLFieldConfig, - GraphQLFieldConfigArgumentMap, GraphQLFieldConfigMap, GraphQLFieldMap, GraphQLFieldResolver, GraphQLInputField, GraphQLInputFieldConfig, - GraphQLInputFieldConfigMap, GraphQLInputFieldMap, GraphQLInputObjectTypeConfig, GraphQLInterfaceTypeConfig, diff --git a/src/utilities/extendSchema.js b/src/utilities/extendSchema.js index 71be143ca8e..a824f0fb97f 100644 --- a/src/utilities/extendSchema.js +++ b/src/utilities/extendSchema.js @@ -1,3 +1,4 @@ +import type { ObjMap } from '../jsutils/ObjMap'; import { keyMap } from '../jsutils/keyMap'; import { inspect } from '../jsutils/inspect'; import { mapValue } from '../jsutils/mapValue'; @@ -48,10 +49,9 @@ import type { GraphQLNamedType, GraphQLFieldConfig, GraphQLFieldConfigMap, + GraphQLInputValueConfig, GraphQLArgumentConfig, - GraphQLFieldConfigArgumentMap, GraphQLEnumValueConfigMap, - GraphQLInputFieldConfigMap, } from '../type/definition'; import { assertSchema, GraphQLSchema } from '../type/schema'; import { specifiedScalarTypes, isSpecifiedScalarType } from '../type/scalars'; @@ -446,7 +446,7 @@ export function extendSchemaImpl( description: node.description?.value, locations, isRepeatable: node.repeatable, - args: buildArgumentMap(node.arguments), + args: buildInputValueMap(node.arguments), astNode: node, }); } @@ -471,7 +471,7 @@ export function extendSchemaImpl( // with validateSchema() will produce more actionable results. type: (getWrappedType(field.type): any), description: field.description?.value, - args: buildArgumentMap(field.arguments), + args: buildInputValueMap(field.arguments), deprecationReason: getDeprecationReason(field), astNode: field, }; @@ -480,54 +480,38 @@ export function extendSchemaImpl( return fieldConfigMap; } - function buildArgumentMap( - args: ?$ReadOnlyArray, - ): GraphQLFieldConfigArgumentMap { + function buildInputValueMap( + nodes: ?$ReadOnlyArray, + configMap: ObjMap = Object.create(null), + ): ObjMap { // istanbul ignore next (See: 'https://github.com/graphql/graphql-js/issues/2203') - const argsNodes = args ?? []; + const inputNodes = nodes ?? []; - const argConfigMap = Object.create(null); - for (const arg of argsNodes) { + for (const node of inputNodes) { // Note: While this could make assertions to get the correctly typed // value, that would throw immediately while type system validation // with validateSchema() will produce more actionable results. - const type: any = getWrappedType(arg.type); + const type: any = getWrappedType(node.type); - argConfigMap[arg.name.value] = { + configMap[node.name.value] = { type, - description: arg.description?.value, - defaultValue: valueFromAST(arg.defaultValue, type), - deprecationReason: getDeprecationReason(arg), - astNode: arg, + description: node.description?.value, + defaultValue: valueFromAST(node.defaultValue, type), + deprecationReason: getDeprecationReason(node), + astNode: node, }; } - return argConfigMap; + return configMap; } function buildInputFieldMap( nodes: $ReadOnlyArray< InputObjectTypeDefinitionNode | InputObjectTypeExtensionNode, >, - ): GraphQLInputFieldConfigMap { - const inputFieldMap = Object.create(null); + ): ObjMap { + let inputFieldMap = Object.create(null); for (const node of nodes) { - // istanbul ignore next (See: 'https://github.com/graphql/graphql-js/issues/2203') - const fieldsNodes = node.fields ?? []; - - for (const field of fieldsNodes) { - // Note: While this could make assertions to get the correctly typed - // value, that would throw immediately while type system validation - // with validateSchema() will produce more actionable results. - const type: any = getWrappedType(field.type); - - inputFieldMap[field.name.value] = { - type, - description: field.description?.value, - defaultValue: valueFromAST(field.defaultValue, type), - deprecationReason: getDeprecationReason(field), - astNode: field, - }; - } + inputFieldMap = buildInputValueMap(node.fields, inputFieldMap); } return inputFieldMap; } diff --git a/src/utilities/lexicographicSortSchema.js b/src/utilities/lexicographicSortSchema.js index 30c0e44807d..67e1b0edc06 100644 --- a/src/utilities/lexicographicSortSchema.js +++ b/src/utilities/lexicographicSortSchema.js @@ -8,8 +8,7 @@ import type { GraphQLType, GraphQLNamedType, GraphQLFieldConfigMap, - GraphQLFieldConfigArgumentMap, - GraphQLInputFieldConfigMap, + GraphQLInputValueConfig, } from '../type/definition'; import { GraphQLSchema } from '../type/schema'; import { GraphQLDirective } from '../type/directives'; @@ -78,14 +77,14 @@ export function lexicographicSortSchema(schema: GraphQLSchema): GraphQLSchema { return new GraphQLDirective({ ...config, locations: sortBy(config.locations, (x) => x), - args: sortArgs(config.args), + args: sortInputs(config.args), }); } - function sortArgs(args: GraphQLFieldConfigArgumentMap) { - return sortObjMap(args, (arg) => ({ - ...arg, - type: replaceType(arg.type), + function sortInputs(inputs: ObjMap) { + return sortObjMap(inputs, (input) => ({ + ...input, + type: replaceType(input.type), })); } @@ -93,14 +92,7 @@ export function lexicographicSortSchema(schema: GraphQLSchema): GraphQLSchema { return sortObjMap(fieldsMap, (field) => ({ ...field, type: replaceType(field.type), - args: sortArgs(field.args), - })); - } - - function sortInputFields(fieldsMap: GraphQLInputFieldConfigMap) { - return sortObjMap(fieldsMap, (field) => ({ - ...field, - type: replaceType(field.type), + args: sortInputs(field.args), })); } @@ -147,7 +139,7 @@ export function lexicographicSortSchema(schema: GraphQLSchema): GraphQLSchema { const config = type.toConfig(); return new GraphQLInputObjectType({ ...config, - fields: () => sortInputFields(config.fields), + fields: () => sortInputs(config.fields), }); }