diff --git a/src/type/definition.js b/src/type/definition.js index f322f4d9d1..ce151b6d89 100644 --- a/src/type/definition.js +++ b/src/type/definition.js @@ -558,9 +558,9 @@ export class GraphQLScalarType { this.parseValue = parseValue; this.parseLiteral = config.parseLiteral || (node => parseValue(valueFromASTUntyped(node))); - this.astNode = config.astNode; this.extensionASTNodes = undefineIfEmpty(config.extensionASTNodes); + devAssert(typeof config.name === 'string', 'Must provide name.'); devAssert( config.serialize == null || typeof config.serialize === 'function', @@ -663,9 +663,9 @@ export type GraphQLScalarTypeConfig = {| export class GraphQLObjectType { name: string; description: ?string; + isTypeOf: ?GraphQLIsTypeOfFn<*, *>; astNode: ?ObjectTypeDefinitionNode; extensionASTNodes: ?$ReadOnlyArray; - isTypeOf: ?GraphQLIsTypeOfFn<*, *>; _fields: Thunk>; _interfaces: Thunk>; @@ -673,9 +673,10 @@ export class GraphQLObjectType { constructor(config: GraphQLObjectTypeConfig<*, *>): void { this.name = config.name; this.description = config.description; + this.isTypeOf = config.isTypeOf; this.astNode = config.astNode; this.extensionASTNodes = undefineIfEmpty(config.extensionASTNodes); - this.isTypeOf = config.isTypeOf; + this._fields = defineFieldMap.bind(undefined, config); this._interfaces = defineInterfaces.bind(undefined, config); devAssert(typeof config.name === 'string', 'Must provide name.'); @@ -709,9 +710,9 @@ export class GraphQLObjectType { return { name: this.name, description: this.description, - isTypeOf: this.isTypeOf, interfaces: this.getInterfaces(), fields: fieldsToFieldsConfig(this.getFields()), + isTypeOf: this.isTypeOf, astNode: this.astNode, extensionASTNodes: this.extensionASTNodes || [], }; @@ -797,12 +798,12 @@ function isPlainObj(obj) { function fieldsToFieldsConfig(fields) { return mapValue(fields, field => ({ + description: field.description, type: field.type, args: argsToArgsConfig(field.args), resolve: field.resolve, subscribe: field.subscribe, deprecationReason: field.deprecationReason, - description: field.description, astNode: field.astNode, })); } @@ -814,9 +815,9 @@ export function argsToArgsConfig( args, arg => arg.name, arg => ({ + description: arg.description, type: arg.type, defaultValue: arg.defaultValue, - description: arg.description, astNode: arg.astNode, }), ); @@ -824,10 +825,10 @@ export function argsToArgsConfig( export type GraphQLObjectTypeConfig = {| name: string, + description?: ?string, interfaces?: Thunk>, fields: Thunk>, isTypeOf?: ?GraphQLIsTypeOfFn, - description?: ?string, astNode?: ?ObjectTypeDefinitionNode, extensionASTNodes?: ?$ReadOnlyArray, |}; @@ -874,21 +875,21 @@ export type GraphQLFieldConfig< TContext, TArgs = { [argument: string]: any, ... }, > = {| + description?: ?string, type: GraphQLOutputType, args?: GraphQLFieldConfigArgumentMap, resolve?: GraphQLFieldResolver, subscribe?: GraphQLFieldResolver, deprecationReason?: ?string, - description?: ?string, astNode?: ?FieldDefinitionNode, |}; export type GraphQLFieldConfigArgumentMap = ObjMap; export type GraphQLArgumentConfig = {| + description?: ?string, type: GraphQLInputType, defaultValue?: mixed, - description?: ?string, astNode?: ?InputValueDefinitionNode, |}; @@ -914,9 +915,9 @@ export type GraphQLField< export type GraphQLArgument = {| name: string, + description?: ?string, type: GraphQLInputType, defaultValue?: mixed, - description?: ?string, astNode?: ?InputValueDefinitionNode, |}; @@ -949,18 +950,19 @@ export type GraphQLFieldMap = ObjMap< export class GraphQLInterfaceType { name: string; description: ?string; + resolveType: ?GraphQLTypeResolver<*, *>; astNode: ?InterfaceTypeDefinitionNode; extensionASTNodes: ?$ReadOnlyArray; - resolveType: ?GraphQLTypeResolver<*, *>; _fields: Thunk>; constructor(config: GraphQLInterfaceTypeConfig<*, *>): void { this.name = config.name; this.description = config.description; + this.resolveType = config.resolveType; this.astNode = config.astNode; this.extensionASTNodes = undefineIfEmpty(config.extensionASTNodes); - this.resolveType = config.resolveType; + this._fields = defineFieldMap.bind(undefined, config); devAssert(typeof config.name === 'string', 'Must provide name.'); devAssert( @@ -985,8 +987,8 @@ export class GraphQLInterfaceType { return { name: this.name, description: this.description, - resolveType: this.resolveType, fields: fieldsToFieldsConfig(this.getFields()), + resolveType: this.resolveType, astNode: this.astNode, extensionASTNodes: this.extensionASTNodes || [], }; @@ -1003,6 +1005,7 @@ defineToJSON(GraphQLInterfaceType); export type GraphQLInterfaceTypeConfig = {| name: string, + description?: ?string, fields: Thunk>, /** * Optionally provide a custom type resolver function. If one is not provided, @@ -1010,7 +1013,6 @@ export type GraphQLInterfaceTypeConfig = {| * Object type. */ resolveType?: ?GraphQLTypeResolver, - description?: ?string, astNode?: ?InterfaceTypeDefinitionNode, extensionASTNodes?: ?$ReadOnlyArray, |}; @@ -1041,18 +1043,19 @@ export type GraphQLInterfaceTypeConfig = {| export class GraphQLUnionType { name: string; description: ?string; + resolveType: ?GraphQLTypeResolver<*, *>; astNode: ?UnionTypeDefinitionNode; extensionASTNodes: ?$ReadOnlyArray; - resolveType: ?GraphQLTypeResolver<*, *>; _types: Thunk>; constructor(config: GraphQLUnionTypeConfig<*, *>): void { this.name = config.name; this.description = config.description; + this.resolveType = config.resolveType; this.astNode = config.astNode; this.extensionASTNodes = undefineIfEmpty(config.extensionASTNodes); - this.resolveType = config.resolveType; + this._types = defineTypes.bind(undefined, config); devAssert(typeof config.name === 'string', 'Must provide name.'); devAssert( @@ -1077,8 +1080,8 @@ export class GraphQLUnionType { return { name: this.name, description: this.description, - resolveType: this.resolveType, types: this.getTypes(), + resolveType: this.resolveType, astNode: this.astNode, extensionASTNodes: this.extensionASTNodes || [], }; @@ -1106,6 +1109,7 @@ function defineTypes( export type GraphQLUnionTypeConfig = {| name: string, + description?: ?string, types: Thunk>, /** * Optionally provide a custom type resolver function. If one is not provided, @@ -1113,7 +1117,6 @@ export type GraphQLUnionTypeConfig = {| * Object type. */ resolveType?: ?GraphQLTypeResolver, - description?: ?string, astNode?: ?UnionTypeDefinitionNode, extensionASTNodes?: ?$ReadOnlyArray, |}; @@ -1154,6 +1157,7 @@ export class GraphQLEnumType /* */ { this.description = config.description; this.astNode = config.astNode; this.extensionASTNodes = undefineIfEmpty(config.extensionASTNodes); + this._values = defineEnumValues(this.name, config.values); this._valueLookup = new Map( this._values.map(enumValue => [enumValue.value, enumValue]), @@ -1251,18 +1255,18 @@ function defineEnumValues( return { name: valueName, description: value.description, + value: 'value' in value ? value.value : valueName, isDeprecated: Boolean(value.deprecationReason), deprecationReason: value.deprecationReason, astNode: value.astNode, - value: 'value' in value ? value.value : valueName, }; }); } export type GraphQLEnumTypeConfig /* */ = {| name: string, - values: GraphQLEnumValueConfigMap /* */, description?: ?string, + values: GraphQLEnumValueConfigMap /* */, astNode?: ?EnumTypeDefinitionNode, extensionASTNodes?: ?$ReadOnlyArray, |}; @@ -1270,19 +1274,19 @@ export type GraphQLEnumTypeConfig /* */ = {| export type GraphQLEnumValueConfigMap /* */ = ObjMap */>; export type GraphQLEnumValueConfig /* */ = {| + description?: ?string, value?: any /* T */, deprecationReason?: ?string, - description?: ?string, astNode?: ?EnumValueDefinitionNode, |}; export type GraphQLEnumValue /* */ = {| name: string, description: ?string, + value: any /* T */, isDeprecated?: boolean, deprecationReason: ?string, astNode?: ?EnumValueDefinitionNode, - value: any /* T */, |}; /** @@ -1318,6 +1322,7 @@ export class GraphQLInputObjectType { this.description = config.description; this.astNode = config.astNode; this.extensionASTNodes = undefineIfEmpty(config.extensionASTNodes); + this._fields = defineInputFieldMap.bind(undefined, config); devAssert(typeof config.name === 'string', 'Must provide name.'); } @@ -1375,9 +1380,9 @@ function defineInputFieldMap( return { name: fieldName, + description: fieldConfig.description, type: fieldConfig.type, defaultValue: fieldConfig.defaultValue, - description: fieldConfig.description, astNode: fieldConfig.astNode, }; }); @@ -1385,16 +1390,16 @@ function defineInputFieldMap( export type GraphQLInputObjectTypeConfig = {| name: string, - fields: Thunk, description?: ?string, + fields: Thunk, astNode?: ?InputObjectTypeDefinitionNode, extensionASTNodes?: ?$ReadOnlyArray, |}; export type GraphQLInputFieldConfig = {| + description?: ?string, type: GraphQLInputType, defaultValue?: mixed, - description?: ?string, astNode?: ?InputValueDefinitionNode, |}; @@ -1402,9 +1407,9 @@ export type GraphQLInputFieldConfigMap = ObjMap; export type GraphQLInputField = {| name: string, + description?: ?string, type: GraphQLInputType, defaultValue?: mixed, - description?: ?string, astNode?: ?InputValueDefinitionNode, |}; diff --git a/src/type/directives.js b/src/type/directives.js index 64640a5c48..9691994eba 100644 --- a/src/type/directives.js +++ b/src/type/directives.js @@ -58,10 +58,10 @@ export class GraphQLDirective { constructor(config: GraphQLDirectiveConfig): void { this.name = config.name; this.description = config.description; - this.locations = config.locations; this.isRepeatable = config.isRepeatable != null && config.isRepeatable; this.astNode = config.astNode; + devAssert(config.name, 'Directive must be named.'); devAssert( Array.isArray(config.locations), diff --git a/src/type/schema.js b/src/type/schema.js index 070c915555..3c0fac47c3 100644 --- a/src/type/schema.js +++ b/src/type/schema.js @@ -117,6 +117,7 @@ export function assertSchema(schema: mixed): GraphQLSchema { export class GraphQLSchema { astNode: ?SchemaDefinitionNode; extensionASTNodes: ?$ReadOnlyArray; + _queryType: ?GraphQLObjectType; _mutationType: ?GraphQLObjectType; _subscriptionType: ?GraphQLObjectType; @@ -156,14 +157,15 @@ export class GraphQLSchema { ); } + this.astNode = config.astNode; + this.extensionASTNodes = config.extensionASTNodes; + this.__allowedLegacyNames = config.allowedLegacyNames || []; this._queryType = config.query; this._mutationType = config.mutation; this._subscriptionType = config.subscription; // Provide specified directives (e.g. @include and @skip) by default. this._directives = config.directives || specifiedDirectives; - this.astNode = config.astNode; - this.extensionASTNodes = config.extensionASTNodes; // Build type map now to detect any errors within this schema. const initialTypes: Array = [ @@ -266,11 +268,11 @@ export class GraphQLSchema { allowedLegacyNames: $ReadOnlyArray, |} { return { - types: objectValues(this.getTypeMap()), - directives: this.getDirectives().slice(), query: this.getQueryType(), mutation: this.getMutationType(), subscription: this.getSubscriptionType(), + types: objectValues(this.getTypeMap()), + directives: this.getDirectives().slice(), astNode: this.astNode, extensionASTNodes: this.extensionASTNodes || [], assumeValid: this.__validationErrors !== undefined,