graphql 1.10.0.pre1 → 1.10.0.pre2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/generators/graphql/core.rb +1 -0
- data/lib/generators/graphql/install_generator.rb +1 -0
- data/lib/generators/graphql/mutation_generator.rb +1 -1
- data/lib/generators/graphql/templates/base_field.erb +0 -4
- data/lib/generators/graphql/templates/base_mutation.erb +8 -0
- data/lib/generators/graphql/templates/graphql_controller.erb +5 -0
- data/lib/generators/graphql/templates/mutation.erb +1 -1
- data/lib/generators/graphql/templates/schema.erb +1 -1
- data/lib/graphql.rb +4 -1
- data/lib/graphql/analysis/ast.rb +14 -13
- data/lib/graphql/analysis/ast/analyzer.rb +23 -4
- data/lib/graphql/analysis/ast/field_usage.rb +1 -1
- data/lib/graphql/analysis/ast/max_query_complexity.rb +3 -3
- data/lib/graphql/analysis/ast/max_query_depth.rb +7 -3
- data/lib/graphql/analysis/ast/query_complexity.rb +2 -2
- data/lib/graphql/analysis/ast/visitor.rb +3 -3
- data/lib/graphql/base_type.rb +1 -1
- data/lib/graphql/directive.rb +0 -1
- data/lib/graphql/directive/deprecated_directive.rb +1 -12
- data/lib/graphql/execution/errors.rb +4 -8
- data/lib/graphql/execution/interpreter.rb +5 -11
- data/lib/graphql/execution/interpreter/runtime.rb +56 -48
- data/lib/graphql/execution/lazy/lazy_method_map.rb +4 -0
- data/lib/graphql/execution/lookahead.rb +5 -5
- data/lib/graphql/execution/multiplex.rb +10 -0
- data/lib/graphql/function.rb +1 -1
- data/lib/graphql/input_object_type.rb +3 -2
- data/lib/graphql/interface_type.rb +1 -1
- data/lib/graphql/introspection/base_object.rb +2 -5
- data/lib/graphql/introspection/directive_type.rb +1 -1
- data/lib/graphql/introspection/entry_points.rb +6 -6
- data/lib/graphql/introspection/schema_type.rb +1 -6
- data/lib/graphql/introspection/type_type.rb +5 -5
- data/lib/graphql/language.rb +1 -1
- data/lib/graphql/language/block_string.rb +2 -2
- data/lib/graphql/language/definition_slice.rb +21 -10
- data/lib/graphql/language/document_from_schema_definition.rb +42 -42
- data/lib/graphql/language/lexer.rb +49 -48
- data/lib/graphql/language/lexer.rl +49 -48
- data/lib/graphql/language/nodes.rb +11 -8
- data/lib/graphql/language/parser.rb +4 -1
- data/lib/graphql/language/parser.y +4 -1
- data/lib/graphql/language/token.rb +1 -1
- data/lib/graphql/pagination/array_connection.rb +0 -1
- data/lib/graphql/pagination/connection.rb +31 -10
- data/lib/graphql/pagination/connections.rb +7 -2
- data/lib/graphql/pagination/relation_connection.rb +1 -7
- data/lib/graphql/query.rb +9 -4
- data/lib/graphql/query/arguments.rb +8 -1
- data/lib/graphql/query/literal_input.rb +2 -1
- data/lib/graphql/query/variables.rb +5 -1
- data/lib/graphql/relay/base_connection.rb +3 -3
- data/lib/graphql/relay/relation_connection.rb +9 -5
- data/lib/graphql/schema.rb +699 -153
- data/lib/graphql/schema/argument.rb +20 -4
- data/lib/graphql/schema/build_from_definition.rb +64 -31
- data/lib/graphql/schema/built_in_types.rb +5 -5
- data/lib/graphql/schema/directive.rb +16 -1
- data/lib/graphql/schema/directive/deprecated.rb +18 -0
- data/lib/graphql/schema/directive/feature.rb +1 -1
- data/lib/graphql/schema/enum.rb +39 -3
- data/lib/graphql/schema/field.rb +39 -9
- data/lib/graphql/schema/field/connection_extension.rb +4 -4
- data/lib/graphql/schema/find_inherited_value.rb +13 -0
- data/lib/graphql/schema/finder.rb +13 -11
- data/lib/graphql/schema/input_object.rb +109 -1
- data/lib/graphql/schema/interface.rb +8 -7
- data/lib/graphql/schema/introspection_system.rb +104 -36
- data/lib/graphql/schema/late_bound_type.rb +1 -0
- data/lib/graphql/schema/list.rb +26 -0
- data/lib/graphql/schema/loader.rb +10 -4
- data/lib/graphql/schema/member.rb +3 -0
- data/lib/graphql/schema/member/base_dsl_methods.rb +23 -13
- data/lib/graphql/schema/member/build_type.rb +1 -1
- data/lib/graphql/schema/member/has_arguments.rb +2 -2
- data/lib/graphql/schema/member/has_fields.rb +15 -6
- data/lib/graphql/schema/member/instrumentation.rb +6 -1
- data/lib/graphql/schema/member/type_system_helpers.rb +1 -1
- data/lib/graphql/schema/member/validates_input.rb +33 -0
- data/lib/graphql/schema/non_null.rb +25 -0
- data/lib/graphql/schema/object.rb +14 -1
- data/lib/graphql/schema/printer.rb +4 -3
- data/lib/graphql/schema/relay_classic_mutation.rb +5 -1
- data/lib/graphql/schema/resolver.rb +20 -2
- data/lib/graphql/schema/scalar.rb +18 -3
- data/lib/graphql/schema/subscription.rb +1 -1
- data/lib/graphql/schema/timeout_middleware.rb +3 -2
- data/lib/graphql/schema/traversal.rb +1 -1
- data/lib/graphql/schema/type_expression.rb +22 -24
- data/lib/graphql/schema/validation.rb +17 -1
- data/lib/graphql/schema/warden.rb +46 -17
- data/lib/graphql/schema/wrapper.rb +1 -1
- data/lib/graphql/static_validation/base_visitor.rb +10 -6
- data/lib/graphql/static_validation/definition_dependencies.rb +21 -12
- data/lib/graphql/static_validation/rules/fields_are_defined_on_type.rb +4 -4
- data/lib/graphql/static_validation/rules/fragment_spreads_are_possible.rb +3 -3
- data/lib/graphql/static_validation/type_stack.rb +2 -2
- data/lib/graphql/static_validation/validator.rb +1 -1
- data/lib/graphql/subscriptions.rb +38 -13
- data/lib/graphql/subscriptions/event.rb +24 -7
- data/lib/graphql/subscriptions/instrumentation.rb +1 -1
- data/lib/graphql/subscriptions/subscription_root.rb +0 -1
- data/lib/graphql/tracing/active_support_notifications_tracing.rb +10 -10
- data/lib/graphql/tracing/platform_tracing.rb +1 -2
- data/lib/graphql/tracing/skylight_tracing.rb +1 -0
- data/lib/graphql/unresolved_type_error.rb +2 -2
- data/lib/graphql/upgrader/member.rb +1 -1
- data/lib/graphql/version.rb +1 -1
- metadata +5 -2
@@ -223,14 +223,14 @@ module GraphQL
|
|
223
223
|
subselections_on_type = selections_on_type
|
224
224
|
if (t = ast_selection.type)
|
225
225
|
# Assuming this is valid, that `t` will be found.
|
226
|
-
on_type = @query.schema.
|
226
|
+
on_type = @query.schema.get_type(t.name).type_class
|
227
227
|
subselections_on_type = subselections_by_type[on_type] ||= {}
|
228
228
|
end
|
229
229
|
find_selections(subselections_by_type, subselections_on_type, on_type, ast_selection.selections, arguments)
|
230
230
|
when GraphQL::Language::Nodes::FragmentSpread
|
231
231
|
frag_defn = @query.fragments[ast_selection.name] || raise("Invariant: Can't look ahead to nonexistent fragment #{ast_selection.name} (found: #{@query.fragments.keys})")
|
232
232
|
# Again, assuming a valid AST
|
233
|
-
on_type = @query.schema.
|
233
|
+
on_type = @query.schema.get_type(frag_defn.type.name).type_class
|
234
234
|
subselections_on_type = subselections_by_type[on_type] ||= {}
|
235
235
|
find_selections(subselections_by_type, subselections_on_type, on_type, frag_defn.selections, arguments)
|
236
236
|
else
|
@@ -366,10 +366,10 @@ module GraphQL
|
|
366
366
|
|
367
367
|
def get_field(schema, owner_type, field_name)
|
368
368
|
field_defn = owner_type.get_field(field_name)
|
369
|
-
field_defn ||= if owner_type == schema.query.
|
370
|
-
entry_point_field.
|
369
|
+
field_defn ||= if owner_type == schema.query.type_class && (entry_point_field = schema.introspection_system.entry_point(name: field_name))
|
370
|
+
entry_point_field.type_class
|
371
371
|
elsif (dynamic_field = schema.introspection_system.dynamic_field(name: field_name))
|
372
|
-
dynamic_field.
|
372
|
+
dynamic_field.type_class
|
373
373
|
else
|
374
374
|
nil
|
375
375
|
end
|
@@ -95,6 +95,7 @@ module GraphQL
|
|
95
95
|
query.result
|
96
96
|
end
|
97
97
|
rescue Exception
|
98
|
+
# TODO rescue at a higher level so it will catch errors in analysis, too
|
98
99
|
# Assign values here so that the query's `@executed` becomes true
|
99
100
|
queries.map { |q| q.result_values ||= {} }
|
100
101
|
raise
|
@@ -173,6 +174,15 @@ module GraphQL
|
|
173
174
|
def instrument_and_analyze(multiplex)
|
174
175
|
GraphQL::Execution::Instrumentation.apply_instrumenters(multiplex) do
|
175
176
|
schema = multiplex.schema
|
177
|
+
if schema.interpreter? && schema.analysis_engine != GraphQL::Analysis::AST
|
178
|
+
raise <<-ERR
|
179
|
+
Can't use `GraphQL::Execution::Interpreter` without `GraphQL::Analysis::AST`, please add this plugin to your schema:
|
180
|
+
|
181
|
+
use GraphQL::Analysis::AST
|
182
|
+
|
183
|
+
For information about the new analysis engine: https://graphql-ruby.org/queries/ast_analysis.html
|
184
|
+
ERR
|
185
|
+
end
|
176
186
|
multiplex_analyzers = schema.multiplex_analyzers
|
177
187
|
if multiplex.max_complexity
|
178
188
|
multiplex_analyzers += if schema.using_ast_analysis?
|
data/lib/graphql/function.rb
CHANGED
@@ -99,7 +99,8 @@ module GraphQL
|
|
99
99
|
end
|
100
100
|
end
|
101
101
|
|
102
|
-
arguments_class.new(input_values, context: ctx, defaults_used: defaults_used)
|
102
|
+
result = arguments_class.new(input_values, context: ctx, defaults_used: defaults_used)
|
103
|
+
result.prepare
|
103
104
|
end
|
104
105
|
|
105
106
|
# @api private
|
@@ -135,7 +136,7 @@ module GraphQL
|
|
135
136
|
# Items in the input that are unexpected
|
136
137
|
input.each do |name, value|
|
137
138
|
if visible_arguments_map[name].nil?
|
138
|
-
result.add_problem("Field is not defined on #{self.
|
139
|
+
result.add_problem("Field is not defined on #{self.graphql_name}", [name])
|
139
140
|
end
|
140
141
|
end
|
141
142
|
|
@@ -71,7 +71,7 @@ module GraphQL
|
|
71
71
|
# @return [GraphQL::ObjectType, nil] The type named `type_name` if it exists and implements this {InterfaceType}, (else `nil`)
|
72
72
|
def get_possible_type(type_name, ctx)
|
73
73
|
type = ctx.query.get_type(type_name)
|
74
|
-
type if type && ctx.query.
|
74
|
+
type if type && ctx.query.warden.possible_types(self).include?(type)
|
75
75
|
end
|
76
76
|
|
77
77
|
# Check if a type is a possible type of this {InterfaceType}
|
@@ -2,15 +2,12 @@
|
|
2
2
|
module GraphQL
|
3
3
|
module Introspection
|
4
4
|
class BaseObject < GraphQL::Schema::Object
|
5
|
+
introspection(true)
|
6
|
+
|
5
7
|
def self.field(*args, **kwargs, &block)
|
6
8
|
kwargs[:introspection] = true
|
7
9
|
super(*args, **kwargs, &block)
|
8
10
|
end
|
9
|
-
|
10
|
-
def self.inherited(child_class)
|
11
|
-
child_class.introspection(true)
|
12
|
-
super
|
13
|
-
end
|
14
11
|
end
|
15
12
|
end
|
16
13
|
end
|
@@ -9,7 +9,7 @@ module GraphQL
|
|
9
9
|
"in ways field arguments will not suffice, such as conditionally including or "\
|
10
10
|
"skipping a field. Directives provide this by describing additional information "\
|
11
11
|
"to the executor."
|
12
|
-
field :name, String, null: false
|
12
|
+
field :name, String, null: false, method: :graphql_name
|
13
13
|
field :description, String, null: true
|
14
14
|
field :locations, [GraphQL::Schema::LateBoundType.new("__DirectiveLocation")], null: false
|
15
15
|
field :args, [GraphQL::Schema::LateBoundType.new("__InputValue")], null: false
|
@@ -10,22 +10,22 @@ module GraphQL
|
|
10
10
|
def __schema
|
11
11
|
# Apply wrapping manually since this field isn't wrapped by instrumentation
|
12
12
|
schema = @context.query.schema
|
13
|
-
schema_type = schema.introspection_system.
|
14
|
-
schema_type.
|
13
|
+
schema_type = schema.introspection_system.types["__Schema"]
|
14
|
+
schema_type.type_class.authorized_new(schema, @context)
|
15
15
|
end
|
16
16
|
|
17
17
|
def __type(name:)
|
18
18
|
type = context.warden.get_type(name)
|
19
19
|
|
20
|
-
if type && context.interpreter?
|
21
|
-
type = type.
|
20
|
+
if type && context.interpreter? && !type.is_a?(Module)
|
21
|
+
type = type.type_class || raise("Invariant: interpreter requires class-based type for #{name}")
|
22
22
|
end
|
23
23
|
|
24
24
|
# The interpreter provides this wrapping, other execution doesnt, so support both.
|
25
25
|
if type && !context.interpreter?
|
26
26
|
# Apply wrapping manually since this field isn't wrapped by instrumentation
|
27
|
-
type_type = context.schema.introspection_system.
|
28
|
-
type = type_type.
|
27
|
+
type_type = context.schema.introspection_system.types["__Type"]
|
28
|
+
type = type_type.type_class.authorized_new(type, context)
|
29
29
|
end
|
30
30
|
type
|
31
31
|
end
|
@@ -14,12 +14,7 @@ module GraphQL
|
|
14
14
|
field :directives, [GraphQL::Schema::LateBoundType.new("__Directive")], "A list of all directives supported by this server.", null: false
|
15
15
|
|
16
16
|
def types
|
17
|
-
|
18
|
-
if context.interpreter?
|
19
|
-
types.map { |t| t.metadata[:type_class] || raise("Invariant: can't introspect non-class-based type: #{t}") }
|
20
|
-
else
|
21
|
-
types
|
22
|
-
end
|
17
|
+
@context.warden.types.values
|
23
18
|
end
|
24
19
|
|
25
20
|
def query_type
|
@@ -37,7 +37,7 @@ module GraphQL
|
|
37
37
|
if !@object.kind.enum?
|
38
38
|
nil
|
39
39
|
else
|
40
|
-
enum_values = @context.warden.enum_values(@object
|
40
|
+
enum_values = @context.warden.enum_values(@object)
|
41
41
|
|
42
42
|
if !include_deprecated
|
43
43
|
enum_values = enum_values.select {|f| !f.deprecation_reason }
|
@@ -49,7 +49,7 @@ module GraphQL
|
|
49
49
|
|
50
50
|
def interfaces
|
51
51
|
if @object.kind == GraphQL::TypeKinds::OBJECT
|
52
|
-
@context.warden.interfaces(@object
|
52
|
+
@context.warden.interfaces(@object)
|
53
53
|
else
|
54
54
|
nil
|
55
55
|
end
|
@@ -57,7 +57,7 @@ module GraphQL
|
|
57
57
|
|
58
58
|
def input_fields
|
59
59
|
if @object.kind.input_object?
|
60
|
-
@context.warden.arguments(@object
|
60
|
+
@context.warden.arguments(@object)
|
61
61
|
else
|
62
62
|
nil
|
63
63
|
end
|
@@ -65,7 +65,7 @@ module GraphQL
|
|
65
65
|
|
66
66
|
def possible_types
|
67
67
|
if @object.kind.abstract?
|
68
|
-
@context.warden.possible_types(@object.
|
68
|
+
@context.warden.possible_types(@object).sort_by(&:graphql_name)
|
69
69
|
else
|
70
70
|
nil
|
71
71
|
end
|
@@ -75,7 +75,7 @@ module GraphQL
|
|
75
75
|
if !@object.kind.fields?
|
76
76
|
nil
|
77
77
|
else
|
78
|
-
fields = @context.warden.fields(@object
|
78
|
+
fields = @context.warden.fields(@object)
|
79
79
|
if !include_deprecated
|
80
80
|
fields = fields.select {|f| !f.deprecation_reason }
|
81
81
|
end
|
data/lib/graphql/language.rb
CHANGED
@@ -1,7 +1,6 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
require "graphql/language/block_string"
|
3
3
|
require "graphql/language/printer"
|
4
|
-
require "graphql/language/definition_slice"
|
5
4
|
require "graphql/language/document_from_schema_definition"
|
6
5
|
require "graphql/language/generation"
|
7
6
|
require "graphql/language/lexer"
|
@@ -9,6 +8,7 @@ require "graphql/language/nodes"
|
|
9
8
|
require "graphql/language/parser"
|
10
9
|
require "graphql/language/token"
|
11
10
|
require "graphql/language/visitor"
|
11
|
+
require "graphql/language/definition_slice"
|
12
12
|
|
13
13
|
module GraphQL
|
14
14
|
module Language
|
@@ -32,10 +32,10 @@ module GraphQL
|
|
32
32
|
end
|
33
33
|
|
34
34
|
# Remove leading & trailing blank lines
|
35
|
-
while lines.
|
35
|
+
while lines.size > 0 && lines[0].empty?
|
36
36
|
lines.shift
|
37
37
|
end
|
38
|
-
while lines.
|
38
|
+
while lines.size > 0 && lines[-1].empty?
|
39
39
|
lines.pop
|
40
40
|
end
|
41
41
|
|
@@ -7,23 +7,34 @@ module GraphQL
|
|
7
7
|
def slice(document, name)
|
8
8
|
definitions = {}
|
9
9
|
document.definitions.each { |d| definitions[d.name] = d }
|
10
|
-
names =
|
10
|
+
names = Set.new
|
11
|
+
DependencyVisitor.find_definition_dependencies(definitions, name, names)
|
11
12
|
definitions = document.definitions.select { |d| names.include?(d.name) }
|
12
13
|
Nodes::Document.new(definitions: definitions)
|
13
14
|
end
|
14
15
|
|
15
16
|
private
|
16
17
|
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
18
|
+
class DependencyVisitor < GraphQL::Language::Visitor
|
19
|
+
def initialize(doc, definitions, names)
|
20
|
+
@names = names
|
21
|
+
@definitions = definitions
|
22
|
+
super(doc)
|
23
|
+
end
|
24
|
+
|
25
|
+
def on_fragment_spread(node, parent)
|
26
|
+
if fragment = @definitions[node.name]
|
27
|
+
self.class.find_definition_dependencies(@definitions, fragment.name, @names)
|
23
28
|
end
|
24
|
-
|
25
|
-
|
26
|
-
|
29
|
+
super
|
30
|
+
end
|
31
|
+
|
32
|
+
def self.find_definition_dependencies(definitions, name, names)
|
33
|
+
names.add(name)
|
34
|
+
visitor = self.new(definitions[name], definitions, names)
|
35
|
+
visitor.visit
|
36
|
+
nil
|
37
|
+
end
|
27
38
|
end
|
28
39
|
end
|
29
40
|
end
|
@@ -38,9 +38,9 @@ module GraphQL
|
|
38
38
|
|
39
39
|
def build_schema_node
|
40
40
|
GraphQL::Language::Nodes::SchemaDefinition.new(
|
41
|
-
query: warden.root_type_for_operation("query"),
|
42
|
-
mutation: warden.root_type_for_operation("mutation"),
|
43
|
-
subscription: warden.root_type_for_operation("subscription"),
|
41
|
+
query: (q = warden.root_type_for_operation("query")) && q.graphql_name,
|
42
|
+
mutation: (m = warden.root_type_for_operation("mutation")) && m.graphql_name,
|
43
|
+
subscription: (s = warden.root_type_for_operation("subscription")) && s.graphql_name,
|
44
44
|
# This only supports directives from parsing,
|
45
45
|
# use a custom printer to add to this list.
|
46
46
|
directives: @schema.ast_node ? @schema.ast_node.directives : [],
|
@@ -49,8 +49,8 @@ module GraphQL
|
|
49
49
|
|
50
50
|
def build_object_type_node(object_type)
|
51
51
|
GraphQL::Language::Nodes::ObjectTypeDefinition.new(
|
52
|
-
name: object_type.
|
53
|
-
interfaces: warden.interfaces(object_type).sort_by(&:
|
52
|
+
name: object_type.graphql_name,
|
53
|
+
interfaces: warden.interfaces(object_type).sort_by(&:graphql_name).map { |iface| build_type_name_node(iface) },
|
54
54
|
fields: build_field_nodes(warden.fields(object_type)),
|
55
55
|
description: object_type.description,
|
56
56
|
)
|
@@ -58,7 +58,7 @@ module GraphQL
|
|
58
58
|
|
59
59
|
def build_field_node(field)
|
60
60
|
field_node = GraphQL::Language::Nodes::FieldDefinition.new(
|
61
|
-
name: field.
|
61
|
+
name: field.graphql_name,
|
62
62
|
arguments: build_argument_nodes(warden.arguments(field)),
|
63
63
|
type: build_type_name_node(field.type),
|
64
64
|
description: field.description,
|
@@ -66,7 +66,7 @@ module GraphQL
|
|
66
66
|
|
67
67
|
if field.deprecation_reason
|
68
68
|
field_node = field_node.merge_directive(
|
69
|
-
name: GraphQL::Directive::DeprecatedDirective.
|
69
|
+
name: GraphQL::Directive::DeprecatedDirective.graphql_name,
|
70
70
|
arguments: [GraphQL::Language::Nodes::Argument.new(name: "reason", value: field.deprecation_reason)]
|
71
71
|
)
|
72
72
|
end
|
@@ -76,15 +76,15 @@ module GraphQL
|
|
76
76
|
|
77
77
|
def build_union_type_node(union_type)
|
78
78
|
GraphQL::Language::Nodes::UnionTypeDefinition.new(
|
79
|
-
name: union_type.
|
79
|
+
name: union_type.graphql_name,
|
80
80
|
description: union_type.description,
|
81
|
-
types: warden.possible_types(union_type).sort_by(&:
|
81
|
+
types: warden.possible_types(union_type).sort_by(&:graphql_name).map { |type| build_type_name_node(type) }
|
82
82
|
)
|
83
83
|
end
|
84
84
|
|
85
85
|
def build_interface_type_node(interface_type)
|
86
86
|
GraphQL::Language::Nodes::InterfaceTypeDefinition.new(
|
87
|
-
name: interface_type.
|
87
|
+
name: interface_type.graphql_name,
|
88
88
|
description: interface_type.description,
|
89
89
|
fields: build_field_nodes(warden.fields(interface_type))
|
90
90
|
)
|
@@ -92,8 +92,8 @@ module GraphQL
|
|
92
92
|
|
93
93
|
def build_enum_type_node(enum_type)
|
94
94
|
GraphQL::Language::Nodes::EnumTypeDefinition.new(
|
95
|
-
name: enum_type.
|
96
|
-
values: warden.enum_values(enum_type).sort_by(&:
|
95
|
+
name: enum_type.graphql_name,
|
96
|
+
values: warden.enum_values(enum_type).sort_by(&:graphql_name).map do |enum_value|
|
97
97
|
build_enum_value_node(enum_value)
|
98
98
|
end,
|
99
99
|
description: enum_type.description,
|
@@ -102,13 +102,13 @@ module GraphQL
|
|
102
102
|
|
103
103
|
def build_enum_value_node(enum_value)
|
104
104
|
enum_value_node = GraphQL::Language::Nodes::EnumValueDefinition.new(
|
105
|
-
name: enum_value.
|
105
|
+
name: enum_value.graphql_name,
|
106
106
|
description: enum_value.description,
|
107
107
|
)
|
108
108
|
|
109
109
|
if enum_value.deprecation_reason
|
110
110
|
enum_value_node = enum_value_node.merge_directive(
|
111
|
-
name: GraphQL::Directive::DeprecatedDirective.
|
111
|
+
name: GraphQL::Directive::DeprecatedDirective.graphql_name,
|
112
112
|
arguments: [GraphQL::Language::Nodes::Argument.new(name: "reason", value: enum_value.deprecation_reason)]
|
113
113
|
)
|
114
114
|
end
|
@@ -118,7 +118,7 @@ module GraphQL
|
|
118
118
|
|
119
119
|
def build_scalar_type_node(scalar_type)
|
120
120
|
GraphQL::Language::Nodes::ScalarTypeDefinition.new(
|
121
|
-
name: scalar_type.
|
121
|
+
name: scalar_type.graphql_name,
|
122
122
|
description: scalar_type.description,
|
123
123
|
)
|
124
124
|
end
|
@@ -131,7 +131,7 @@ module GraphQL
|
|
131
131
|
end
|
132
132
|
|
133
133
|
argument_node = GraphQL::Language::Nodes::InputValueDefinition.new(
|
134
|
-
name: argument.
|
134
|
+
name: argument.graphql_name,
|
135
135
|
description: argument.description,
|
136
136
|
type: build_type_name_node(argument.type),
|
137
137
|
default_value: default_value,
|
@@ -142,7 +142,7 @@ module GraphQL
|
|
142
142
|
|
143
143
|
def build_input_object_node(input_object)
|
144
144
|
GraphQL::Language::Nodes::InputObjectTypeDefinition.new(
|
145
|
-
name: input_object.
|
145
|
+
name: input_object.graphql_name,
|
146
146
|
fields: build_argument_nodes(warden.arguments(input_object)),
|
147
147
|
description: input_object.description,
|
148
148
|
)
|
@@ -168,17 +168,17 @@ module GraphQL
|
|
168
168
|
end
|
169
169
|
|
170
170
|
def build_type_name_node(type)
|
171
|
-
case type
|
172
|
-
when
|
171
|
+
case type.kind.name
|
172
|
+
when "LIST"
|
173
173
|
GraphQL::Language::Nodes::ListType.new(
|
174
174
|
of_type: build_type_name_node(type.of_type)
|
175
175
|
)
|
176
|
-
when
|
176
|
+
when "NON_NULL"
|
177
177
|
GraphQL::Language::Nodes::NonNullType.new(
|
178
178
|
of_type: build_type_name_node(type.of_type)
|
179
179
|
)
|
180
180
|
else
|
181
|
-
GraphQL::Language::Nodes::TypeName.new(name: type.
|
181
|
+
GraphQL::Language::Nodes::TypeName.new(name: type.graphql_name)
|
182
182
|
end
|
183
183
|
end
|
184
184
|
|
@@ -187,43 +187,43 @@ module GraphQL
|
|
187
187
|
return GraphQL::Language::Nodes::NullValue.new(name: "null")
|
188
188
|
end
|
189
189
|
|
190
|
-
case type
|
191
|
-
when
|
190
|
+
case type.kind.name
|
191
|
+
when "SCALAR"
|
192
192
|
type.coerce_isolated_result(default_value)
|
193
|
-
when
|
193
|
+
when "ENUM"
|
194
194
|
GraphQL::Language::Nodes::Enum.new(name: type.coerce_isolated_result(default_value))
|
195
|
-
when
|
195
|
+
when "INPUT_OBJECT"
|
196
196
|
GraphQL::Language::Nodes::InputObject.new(
|
197
197
|
arguments: default_value.to_h.map do |arg_name, arg_value|
|
198
|
-
arg_type = type.
|
198
|
+
arg_type = type.arguments.fetch(arg_name.to_s).type
|
199
199
|
GraphQL::Language::Nodes::Argument.new(
|
200
|
-
name: arg_name,
|
200
|
+
name: arg_name.to_s,
|
201
201
|
value: build_default_value(arg_value, arg_type)
|
202
202
|
)
|
203
203
|
end
|
204
204
|
)
|
205
|
-
when
|
205
|
+
when "NON_NULL"
|
206
206
|
build_default_value(default_value, type.of_type)
|
207
|
-
when
|
207
|
+
when "LIST"
|
208
208
|
default_value.to_a.map { |v| build_default_value(v, type.of_type) }
|
209
209
|
else
|
210
|
-
raise
|
210
|
+
raise GraphQL::RequiredImplementationMissingError, "Unexpected default value type #{type.inspect}"
|
211
211
|
end
|
212
212
|
end
|
213
213
|
|
214
214
|
def build_type_definition_node(type)
|
215
|
-
case type
|
216
|
-
when
|
215
|
+
case type.kind.name
|
216
|
+
when "OBJECT"
|
217
217
|
build_object_type_node(type)
|
218
|
-
when
|
218
|
+
when "UNION"
|
219
219
|
build_union_type_node(type)
|
220
|
-
when
|
220
|
+
when "INTERFACE"
|
221
221
|
build_interface_type_node(type)
|
222
|
-
when
|
222
|
+
when "SCALAR"
|
223
223
|
build_scalar_type_node(type)
|
224
|
-
when
|
224
|
+
when "ENUM"
|
225
225
|
build_enum_type_node(type)
|
226
|
-
when
|
226
|
+
when "INPUT_OBJECT"
|
227
227
|
build_input_object_node(type)
|
228
228
|
else
|
229
229
|
raise TypeError
|
@@ -250,7 +250,7 @@ module GraphQL
|
|
250
250
|
definitions = []
|
251
251
|
definitions << build_schema_node if include_schema_node?
|
252
252
|
definitions += build_directive_nodes(warden.directives)
|
253
|
-
definitions += build_type_definition_nodes(warden.types)
|
253
|
+
definitions += build_type_definition_nodes(warden.types.values)
|
254
254
|
definitions
|
255
255
|
end
|
256
256
|
|
@@ -260,7 +260,7 @@ module GraphQL
|
|
260
260
|
end
|
261
261
|
|
262
262
|
if !include_built_in_scalars
|
263
|
-
types = types.reject { |type| type.default_scalar? }
|
263
|
+
types = types.reject { |type| type.kind.scalar? && type.default_scalar? }
|
264
264
|
end
|
265
265
|
|
266
266
|
types
|
@@ -281,9 +281,9 @@ module GraphQL
|
|
281
281
|
end
|
282
282
|
|
283
283
|
def schema_respects_root_name_conventions?(schema)
|
284
|
-
(schema.query.nil? || schema.query.
|
285
|
-
(schema.mutation.nil? || schema.mutation.
|
286
|
-
(schema.subscription.nil? || schema.subscription.
|
284
|
+
(schema.query.nil? || schema.query.graphql_name == 'Query') &&
|
285
|
+
(schema.mutation.nil? || schema.mutation.graphql_name == 'Mutation') &&
|
286
|
+
(schema.subscription.nil? || schema.subscription.graphql_name == 'Subscription')
|
287
287
|
end
|
288
288
|
|
289
289
|
attr_reader :schema, :warden, :always_include_schema,
|