graphql 1.13.19 → 2.0.19
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of graphql might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/lib/generators/graphql/install_generator.rb +1 -1
- data/lib/generators/graphql/relay.rb +3 -17
- data/lib/generators/graphql/templates/schema.erb +3 -0
- data/lib/graphql/analysis/ast/field_usage.rb +3 -1
- data/lib/graphql/analysis/ast/max_query_complexity.rb +0 -1
- data/lib/graphql/analysis/ast/query_complexity.rb +1 -1
- data/lib/graphql/analysis/ast/query_depth.rb +0 -1
- data/lib/graphql/analysis/ast/visitor.rb +43 -36
- data/lib/graphql/analysis/ast.rb +2 -12
- data/lib/graphql/analysis.rb +0 -7
- data/lib/graphql/backtrace/table.rb +2 -20
- data/lib/graphql/backtrace/tracer.rb +2 -3
- data/lib/graphql/backtrace.rb +2 -8
- data/lib/graphql/dataloader/null_dataloader.rb +3 -1
- data/lib/graphql/dataloader/source.rb +9 -0
- data/lib/graphql/dataloader.rb +4 -1
- data/lib/graphql/dig.rb +1 -1
- data/lib/graphql/execution/errors.rb +12 -82
- data/lib/graphql/execution/interpreter/resolve.rb +26 -0
- data/lib/graphql/execution/interpreter/runtime.rb +162 -119
- data/lib/graphql/execution/interpreter.rb +187 -78
- data/lib/graphql/execution/lazy.rb +7 -21
- data/lib/graphql/execution/lookahead.rb +44 -40
- data/lib/graphql/execution/multiplex.rb +3 -174
- data/lib/graphql/execution.rb +11 -4
- data/lib/graphql/introspection/dynamic_fields.rb +3 -8
- data/lib/graphql/introspection/entry_points.rb +2 -15
- data/lib/graphql/introspection/type_type.rb +8 -1
- data/lib/graphql/introspection.rb +4 -3
- data/lib/graphql/language/document_from_schema_definition.rb +18 -35
- data/lib/graphql/language/lexer.rb +216 -1488
- data/lib/graphql/language/lexer.ri +744 -0
- data/lib/graphql/language/nodes.rb +41 -33
- data/lib/graphql/language/parser.rb +375 -363
- data/lib/graphql/language/parser.y +48 -43
- data/lib/graphql/language/printer.rb +37 -21
- data/lib/graphql/language/visitor.rb +191 -83
- data/lib/graphql/pagination/active_record_relation_connection.rb +0 -8
- data/lib/graphql/pagination/array_connection.rb +4 -2
- data/lib/graphql/pagination/connection.rb +31 -4
- data/lib/graphql/pagination/connections.rb +3 -28
- data/lib/graphql/pagination/relation_connection.rb +2 -0
- data/lib/graphql/query/context.rb +155 -196
- data/lib/graphql/query/input_validation_result.rb +1 -1
- data/lib/graphql/query/null_context.rb +0 -3
- data/lib/graphql/query/validation_pipeline.rb +10 -34
- data/lib/graphql/query/variables.rb +7 -20
- data/lib/graphql/query.rb +32 -42
- data/lib/graphql/railtie.rb +0 -104
- data/lib/graphql/rake_task/validate.rb +1 -1
- data/lib/graphql/rake_task.rb +29 -1
- data/lib/graphql/relay/range_add.rb +9 -20
- data/lib/graphql/relay.rb +0 -15
- data/lib/graphql/schema/addition.rb +7 -9
- data/lib/graphql/schema/argument.rb +36 -43
- data/lib/graphql/schema/build_from_definition.rb +32 -18
- data/lib/graphql/schema/directive/one_of.rb +12 -0
- data/lib/graphql/schema/directive/transform.rb +1 -1
- data/lib/graphql/schema/directive.rb +11 -22
- data/lib/graphql/schema/enum.rb +28 -39
- data/lib/graphql/schema/enum_value.rb +5 -25
- data/lib/graphql/schema/field/connection_extension.rb +4 -0
- data/lib/graphql/schema/field.rb +214 -327
- data/lib/graphql/schema/input_object.rb +56 -67
- data/lib/graphql/schema/interface.rb +0 -35
- data/lib/graphql/schema/introspection_system.rb +3 -8
- data/lib/graphql/schema/late_bound_type.rb +8 -2
- data/lib/graphql/schema/list.rb +0 -6
- data/lib/graphql/schema/loader.rb +1 -2
- data/lib/graphql/schema/member/base_dsl_methods.rb +15 -19
- data/lib/graphql/schema/member/build_type.rb +5 -7
- data/lib/graphql/schema/member/has_arguments.rb +144 -53
- data/lib/graphql/schema/member/has_deprecation_reason.rb +3 -4
- data/lib/graphql/schema/member/has_directives.rb +71 -56
- data/lib/graphql/schema/member/has_fields.rb +15 -3
- data/lib/graphql/schema/member/has_interfaces.rb +47 -18
- data/lib/graphql/schema/member/has_validators.rb +31 -5
- data/lib/graphql/schema/member/relay_shortcuts.rb +28 -2
- data/lib/graphql/schema/member/type_system_helpers.rb +17 -0
- data/lib/graphql/schema/member/validates_input.rb +1 -1
- data/lib/graphql/schema/member.rb +0 -6
- data/lib/graphql/schema/mutation.rb +0 -9
- data/lib/graphql/schema/non_null.rb +1 -7
- data/lib/graphql/schema/object.rb +15 -52
- data/lib/graphql/schema/relay_classic_mutation.rb +53 -42
- data/lib/graphql/schema/resolver/has_payload_type.rb +20 -10
- data/lib/graphql/schema/resolver.rb +41 -42
- data/lib/graphql/schema/scalar.rb +7 -22
- data/lib/graphql/schema/subscription.rb +0 -7
- data/lib/graphql/schema/timeout.rb +24 -28
- data/lib/graphql/schema/type_membership.rb +3 -0
- data/lib/graphql/schema/union.rb +10 -17
- data/lib/graphql/schema/warden.rb +23 -6
- data/lib/graphql/schema/wrapper.rb +0 -5
- data/lib/graphql/schema.rb +240 -968
- data/lib/graphql/static_validation/all_rules.rb +1 -0
- data/lib/graphql/static_validation/base_visitor.rb +4 -21
- data/lib/graphql/static_validation/definition_dependencies.rb +7 -1
- data/lib/graphql/static_validation/error.rb +2 -2
- data/lib/graphql/static_validation/literal_validator.rb +19 -1
- data/lib/graphql/static_validation/rules/directives_are_defined.rb +11 -5
- data/lib/graphql/static_validation/rules/directives_are_in_valid_locations.rb +12 -12
- data/lib/graphql/static_validation/rules/one_of_input_objects_are_valid.rb +66 -0
- data/lib/graphql/static_validation/rules/one_of_input_objects_are_valid_error.rb +29 -0
- data/lib/graphql/static_validation/rules/unique_directives_per_location.rb +12 -6
- data/lib/graphql/static_validation/rules/variable_default_values_are_correctly_typed.rb +1 -1
- data/lib/graphql/static_validation/validator.rb +3 -25
- data/lib/graphql/static_validation.rb +0 -2
- data/lib/graphql/subscriptions/action_cable_subscriptions.rb +7 -1
- data/lib/graphql/subscriptions/default_subscription_resolve_extension.rb +38 -1
- data/lib/graphql/subscriptions/event.rb +3 -8
- data/lib/graphql/subscriptions/instrumentation.rb +0 -51
- data/lib/graphql/subscriptions.rb +32 -20
- data/lib/graphql/tracing/active_support_notifications_trace.rb +16 -0
- data/lib/graphql/tracing/appoptics_trace.rb +231 -0
- data/lib/graphql/tracing/appsignal_trace.rb +66 -0
- data/lib/graphql/tracing/data_dog_trace.rb +148 -0
- data/lib/graphql/tracing/data_dog_tracing.rb +2 -0
- data/lib/graphql/tracing/new_relic_trace.rb +75 -0
- data/lib/graphql/tracing/notifications_trace.rb +41 -0
- data/lib/graphql/tracing/platform_trace.rb +107 -0
- data/lib/graphql/tracing/platform_tracing.rb +26 -41
- data/lib/graphql/tracing/prometheus_trace.rb +89 -0
- data/lib/graphql/tracing/prometheus_tracing.rb +3 -3
- data/lib/graphql/tracing/scout_trace.rb +72 -0
- data/lib/graphql/tracing/statsd_trace.rb +56 -0
- data/lib/graphql/tracing.rb +136 -40
- data/lib/graphql/type_kinds.rb +6 -3
- data/lib/graphql/types/iso_8601_date.rb +4 -1
- data/lib/graphql/types/iso_8601_date_time.rb +4 -0
- data/lib/graphql/types/relay/base_connection.rb +16 -6
- data/lib/graphql/types/relay/connection_behaviors.rb +5 -25
- data/lib/graphql/types/relay/default_relay.rb +5 -9
- data/lib/graphql/types/relay/edge_behaviors.rb +1 -4
- data/lib/graphql/types/relay/node_behaviors.rb +5 -1
- data/lib/graphql/types/relay.rb +0 -2
- data/lib/graphql/types/string.rb +1 -1
- data/lib/graphql/version.rb +1 -1
- data/lib/graphql.rb +11 -72
- metadata +31 -132
- data/lib/graphql/analysis/analyze_query.rb +0 -98
- data/lib/graphql/analysis/field_usage.rb +0 -45
- data/lib/graphql/analysis/max_query_complexity.rb +0 -26
- data/lib/graphql/analysis/max_query_depth.rb +0 -26
- data/lib/graphql/analysis/query_complexity.rb +0 -88
- data/lib/graphql/analysis/query_depth.rb +0 -43
- data/lib/graphql/analysis/reducer_state.rb +0 -48
- data/lib/graphql/argument.rb +0 -131
- data/lib/graphql/authorization.rb +0 -82
- data/lib/graphql/backtrace/legacy_tracer.rb +0 -56
- data/lib/graphql/backwards_compatibility.rb +0 -61
- data/lib/graphql/base_type.rb +0 -232
- data/lib/graphql/boolean_type.rb +0 -2
- data/lib/graphql/compatibility/execution_specification/counter_schema.rb +0 -53
- data/lib/graphql/compatibility/execution_specification/specification_schema.rb +0 -200
- data/lib/graphql/compatibility/execution_specification.rb +0 -436
- data/lib/graphql/compatibility/lazy_execution_specification/lazy_schema.rb +0 -111
- data/lib/graphql/compatibility/lazy_execution_specification.rb +0 -215
- data/lib/graphql/compatibility/query_parser_specification/parse_error_specification.rb +0 -87
- data/lib/graphql/compatibility/query_parser_specification/query_assertions.rb +0 -79
- data/lib/graphql/compatibility/query_parser_specification.rb +0 -266
- data/lib/graphql/compatibility/schema_parser_specification.rb +0 -682
- data/lib/graphql/compatibility.rb +0 -5
- data/lib/graphql/define/assign_argument.rb +0 -12
- data/lib/graphql/define/assign_connection.rb +0 -13
- data/lib/graphql/define/assign_enum_value.rb +0 -18
- data/lib/graphql/define/assign_global_id_field.rb +0 -11
- data/lib/graphql/define/assign_mutation_function.rb +0 -34
- data/lib/graphql/define/assign_object_field.rb +0 -42
- data/lib/graphql/define/defined_object_proxy.rb +0 -53
- data/lib/graphql/define/instance_definable.rb +0 -255
- data/lib/graphql/define/no_definition_error.rb +0 -7
- data/lib/graphql/define/non_null_with_bang.rb +0 -16
- data/lib/graphql/define/type_definer.rb +0 -31
- data/lib/graphql/define.rb +0 -31
- data/lib/graphql/deprecated_dsl.rb +0 -55
- data/lib/graphql/directive/deprecated_directive.rb +0 -2
- data/lib/graphql/directive/include_directive.rb +0 -2
- data/lib/graphql/directive/skip_directive.rb +0 -2
- data/lib/graphql/directive.rb +0 -107
- data/lib/graphql/enum_type.rb +0 -133
- data/lib/graphql/execution/execute.rb +0 -333
- data/lib/graphql/execution/flatten.rb +0 -40
- data/lib/graphql/execution/instrumentation.rb +0 -92
- data/lib/graphql/execution/lazy/resolve.rb +0 -91
- data/lib/graphql/execution/typecast.rb +0 -50
- data/lib/graphql/field/resolve.rb +0 -59
- data/lib/graphql/field.rb +0 -226
- data/lib/graphql/float_type.rb +0 -2
- data/lib/graphql/function.rb +0 -128
- data/lib/graphql/id_type.rb +0 -2
- data/lib/graphql/input_object_type.rb +0 -138
- data/lib/graphql/int_type.rb +0 -2
- data/lib/graphql/interface_type.rb +0 -72
- data/lib/graphql/internal_representation/document.rb +0 -27
- data/lib/graphql/internal_representation/node.rb +0 -206
- data/lib/graphql/internal_representation/print.rb +0 -51
- data/lib/graphql/internal_representation/rewrite.rb +0 -184
- data/lib/graphql/internal_representation/scope.rb +0 -88
- data/lib/graphql/internal_representation/visit.rb +0 -36
- data/lib/graphql/internal_representation.rb +0 -7
- data/lib/graphql/language/lexer.rl +0 -260
- data/lib/graphql/list_type.rb +0 -80
- data/lib/graphql/non_null_type.rb +0 -71
- data/lib/graphql/object_type.rb +0 -130
- data/lib/graphql/query/arguments.rb +0 -189
- data/lib/graphql/query/arguments_cache.rb +0 -24
- data/lib/graphql/query/executor.rb +0 -52
- data/lib/graphql/query/literal_input.rb +0 -136
- data/lib/graphql/query/serial_execution/field_resolution.rb +0 -92
- data/lib/graphql/query/serial_execution/operation_resolution.rb +0 -19
- data/lib/graphql/query/serial_execution/selection_resolution.rb +0 -23
- data/lib/graphql/query/serial_execution/value_resolution.rb +0 -87
- data/lib/graphql/query/serial_execution.rb +0 -40
- data/lib/graphql/relay/array_connection.rb +0 -83
- data/lib/graphql/relay/base_connection.rb +0 -189
- data/lib/graphql/relay/connection_instrumentation.rb +0 -54
- data/lib/graphql/relay/connection_resolve.rb +0 -43
- data/lib/graphql/relay/connection_type.rb +0 -54
- data/lib/graphql/relay/edge.rb +0 -27
- data/lib/graphql/relay/edge_type.rb +0 -19
- data/lib/graphql/relay/edges_instrumentation.rb +0 -39
- data/lib/graphql/relay/global_id_resolve.rb +0 -17
- data/lib/graphql/relay/mongo_relation_connection.rb +0 -50
- data/lib/graphql/relay/mutation/instrumentation.rb +0 -23
- data/lib/graphql/relay/mutation/resolve.rb +0 -56
- data/lib/graphql/relay/mutation/result.rb +0 -38
- data/lib/graphql/relay/mutation.rb +0 -106
- data/lib/graphql/relay/node.rb +0 -39
- data/lib/graphql/relay/page_info.rb +0 -7
- data/lib/graphql/relay/relation_connection.rb +0 -188
- data/lib/graphql/relay/type_extensions.rb +0 -32
- data/lib/graphql/scalar_type.rb +0 -91
- data/lib/graphql/schema/catchall_middleware.rb +0 -35
- data/lib/graphql/schema/default_parse_error.rb +0 -10
- data/lib/graphql/schema/default_type_error.rb +0 -17
- data/lib/graphql/schema/member/accepts_definition.rb +0 -164
- data/lib/graphql/schema/member/cached_graphql_definition.rb +0 -58
- data/lib/graphql/schema/member/instrumentation.rb +0 -131
- data/lib/graphql/schema/middleware_chain.rb +0 -82
- data/lib/graphql/schema/possible_types.rb +0 -44
- data/lib/graphql/schema/rescue_middleware.rb +0 -60
- data/lib/graphql/schema/timeout_middleware.rb +0 -88
- data/lib/graphql/schema/traversal.rb +0 -228
- data/lib/graphql/schema/validation.rb +0 -313
- data/lib/graphql/static_validation/default_visitor.rb +0 -15
- data/lib/graphql/static_validation/no_validate_visitor.rb +0 -10
- data/lib/graphql/string_type.rb +0 -2
- data/lib/graphql/subscriptions/subscription_root.rb +0 -76
- data/lib/graphql/tracing/skylight_tracing.rb +0 -70
- data/lib/graphql/types/relay/node_field.rb +0 -24
- data/lib/graphql/types/relay/nodes_field.rb +0 -43
- data/lib/graphql/union_type.rb +0 -115
- data/lib/graphql/upgrader/member.rb +0 -937
- data/lib/graphql/upgrader/schema.rb +0 -38
@@ -1,91 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
module GraphQL
|
3
|
-
module Execution
|
4
|
-
class Lazy
|
5
|
-
# Helpers for dealing with data structures containing {Lazy} instances
|
6
|
-
# @api private
|
7
|
-
module Resolve
|
8
|
-
# Mutate `value`, replacing {Lazy} instances in place with their resolved values
|
9
|
-
# @return [void]
|
10
|
-
|
11
|
-
# This object can be passed like an array, but it doesn't allocate an
|
12
|
-
# array until it's used.
|
13
|
-
#
|
14
|
-
# There's one crucial difference: you have to _capture_ the result
|
15
|
-
# of `#<<`. (This _works_ with arrays but isn't required, since it has a side-effect.)
|
16
|
-
# @api private
|
17
|
-
module NullAccumulator
|
18
|
-
def self.<<(item)
|
19
|
-
[item]
|
20
|
-
end
|
21
|
-
|
22
|
-
def self.empty?
|
23
|
-
true
|
24
|
-
end
|
25
|
-
end
|
26
|
-
|
27
|
-
def self.resolve(value)
|
28
|
-
lazies = resolve_in_place(value)
|
29
|
-
deep_sync(lazies)
|
30
|
-
end
|
31
|
-
|
32
|
-
def self.resolve_in_place(value)
|
33
|
-
acc = each_lazy(NullAccumulator, value)
|
34
|
-
|
35
|
-
if acc.empty?
|
36
|
-
Lazy::NullResult
|
37
|
-
else
|
38
|
-
Lazy.new {
|
39
|
-
acc.each_with_index { |ctx, idx|
|
40
|
-
acc[idx] = ctx.value.value
|
41
|
-
}
|
42
|
-
resolve_in_place(acc)
|
43
|
-
}
|
44
|
-
end
|
45
|
-
end
|
46
|
-
|
47
|
-
# If `value` is a collection,
|
48
|
-
# add any {Lazy} instances in the collection
|
49
|
-
# to `acc`
|
50
|
-
# @return [void]
|
51
|
-
def self.each_lazy(acc, value)
|
52
|
-
case value
|
53
|
-
when Hash
|
54
|
-
value.each do |key, field_result|
|
55
|
-
acc = each_lazy(acc, field_result)
|
56
|
-
end
|
57
|
-
when Array
|
58
|
-
value.each do |field_result|
|
59
|
-
acc = each_lazy(acc, field_result)
|
60
|
-
end
|
61
|
-
when Query::Context::SharedMethods
|
62
|
-
field_value = value.value
|
63
|
-
case field_value
|
64
|
-
when Lazy
|
65
|
-
acc = acc << value
|
66
|
-
when Enumerable # shortcut for Hash & Array
|
67
|
-
acc = each_lazy(acc, field_value)
|
68
|
-
end
|
69
|
-
end
|
70
|
-
|
71
|
-
acc
|
72
|
-
end
|
73
|
-
|
74
|
-
# Traverse `val`, triggering resolution for each {Lazy}.
|
75
|
-
# These {Lazy}s are expected to mutate their owner data structures
|
76
|
-
# during resolution! (They're created with the `.then` calls in `resolve_in_place`).
|
77
|
-
# @return [void]
|
78
|
-
def self.deep_sync(val)
|
79
|
-
case val
|
80
|
-
when Lazy
|
81
|
-
deep_sync(val.value)
|
82
|
-
when Array
|
83
|
-
val.each { |v| deep_sync(v.value) }
|
84
|
-
when Hash
|
85
|
-
val.each { |k, v| deep_sync(v.value) }
|
86
|
-
end
|
87
|
-
end
|
88
|
-
end
|
89
|
-
end
|
90
|
-
end
|
91
|
-
end
|
@@ -1,50 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
module GraphQL
|
3
|
-
module Execution
|
4
|
-
# @api private
|
5
|
-
module Typecast
|
6
|
-
# @return [Boolean]
|
7
|
-
def self.subtype?(parent_type, child_type)
|
8
|
-
if parent_type == child_type
|
9
|
-
# Equivalent types are subtypes
|
10
|
-
true
|
11
|
-
elsif child_type.is_a?(GraphQL::NonNullType)
|
12
|
-
# A non-null type is a subtype of a nullable type
|
13
|
-
# if its inner type is a subtype of that type
|
14
|
-
if parent_type.is_a?(GraphQL::NonNullType)
|
15
|
-
subtype?(parent_type.of_type, child_type.of_type)
|
16
|
-
else
|
17
|
-
subtype?(parent_type, child_type.of_type)
|
18
|
-
end
|
19
|
-
else
|
20
|
-
case parent_type
|
21
|
-
when GraphQL::InterfaceType
|
22
|
-
# A type is a subtype of an interface
|
23
|
-
# if it implements that interface
|
24
|
-
case child_type
|
25
|
-
when GraphQL::ObjectType
|
26
|
-
child_type.interfaces.include?(parent_type)
|
27
|
-
else
|
28
|
-
false
|
29
|
-
end
|
30
|
-
when GraphQL::UnionType
|
31
|
-
# A type is a subtype of that union
|
32
|
-
# if the union includes that type
|
33
|
-
parent_type.possible_types.include?(child_type)
|
34
|
-
when GraphQL::ListType
|
35
|
-
# A list type is a subtype of another list type
|
36
|
-
# if its inner type is a subtype of the other inner type
|
37
|
-
case child_type
|
38
|
-
when GraphQL::ListType
|
39
|
-
subtype?(parent_type.of_type, child_type.of_type)
|
40
|
-
else
|
41
|
-
false
|
42
|
-
end
|
43
|
-
else
|
44
|
-
false
|
45
|
-
end
|
46
|
-
end
|
47
|
-
end
|
48
|
-
end
|
49
|
-
end
|
50
|
-
end
|
@@ -1,59 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
module GraphQL
|
3
|
-
class Field
|
4
|
-
# Create resolve procs ahead of time based on a {GraphQL::Field}'s `name`, `property`, and `hash_key` configuration.
|
5
|
-
module Resolve
|
6
|
-
module_function
|
7
|
-
|
8
|
-
# @param field [GraphQL::Field] A field that needs a resolve proc
|
9
|
-
# @return [Proc] A resolver for this field, based on its config
|
10
|
-
def create_proc(field)
|
11
|
-
if field.property
|
12
|
-
MethodResolve.new(field)
|
13
|
-
elsif !field.hash_key.nil?
|
14
|
-
HashKeyResolve.new(field.hash_key)
|
15
|
-
else
|
16
|
-
NameResolve.new(field)
|
17
|
-
end
|
18
|
-
end
|
19
|
-
|
20
|
-
# These only require `obj` as input
|
21
|
-
class BuiltInResolve
|
22
|
-
end
|
23
|
-
|
24
|
-
# Resolve the field by `public_send`ing `@method_name`
|
25
|
-
class MethodResolve < BuiltInResolve
|
26
|
-
def initialize(field)
|
27
|
-
@method_name = field.property.to_sym
|
28
|
-
end
|
29
|
-
|
30
|
-
def call(obj, args, ctx)
|
31
|
-
obj.public_send(@method_name)
|
32
|
-
end
|
33
|
-
end
|
34
|
-
|
35
|
-
# Resolve the field by looking up `@hash_key` with `#[]`
|
36
|
-
class HashKeyResolve < BuiltInResolve
|
37
|
-
def initialize(hash_key)
|
38
|
-
@hash_key = hash_key
|
39
|
-
end
|
40
|
-
|
41
|
-
def call(obj, args, ctx)
|
42
|
-
obj[@hash_key]
|
43
|
-
end
|
44
|
-
end
|
45
|
-
|
46
|
-
# Call the field's name at query-time since
|
47
|
-
# it might have changed
|
48
|
-
class NameResolve < BuiltInResolve
|
49
|
-
def initialize(field)
|
50
|
-
@field = field
|
51
|
-
end
|
52
|
-
|
53
|
-
def call(obj, args, ctx)
|
54
|
-
obj.public_send(@field.name)
|
55
|
-
end
|
56
|
-
end
|
57
|
-
end
|
58
|
-
end
|
59
|
-
end
|
data/lib/graphql/field.rb
DELETED
@@ -1,226 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
require "graphql/field/resolve"
|
3
|
-
|
4
|
-
module GraphQL
|
5
|
-
# @api deprecated
|
6
|
-
class Field
|
7
|
-
include GraphQL::Define::InstanceDefinable
|
8
|
-
deprecated_accepts_definitions :name, :description, :deprecation_reason,
|
9
|
-
:resolve, :lazy_resolve,
|
10
|
-
:type, :arguments,
|
11
|
-
:property, :hash_key, :complexity,
|
12
|
-
:mutation, :function,
|
13
|
-
:edge_class,
|
14
|
-
:relay_node_field,
|
15
|
-
:relay_nodes_field,
|
16
|
-
:subscription_scope,
|
17
|
-
:trace,
|
18
|
-
:introspection,
|
19
|
-
argument: GraphQL::Define::AssignArgument
|
20
|
-
|
21
|
-
ensure_defined(
|
22
|
-
:name, :deprecation_reason, :description, :description=, :property, :hash_key,
|
23
|
-
:mutation, :arguments, :complexity, :function,
|
24
|
-
:resolve, :resolve=, :lazy_resolve, :lazy_resolve=, :lazy_resolve_proc, :resolve_proc,
|
25
|
-
:type, :type=, :name=, :property=, :hash_key=,
|
26
|
-
:relay_node_field, :relay_nodes_field, :edges?, :edge_class, :subscription_scope,
|
27
|
-
:introspection?
|
28
|
-
)
|
29
|
-
|
30
|
-
# @return [Boolean] True if this is the Relay find-by-id field
|
31
|
-
attr_accessor :relay_node_field
|
32
|
-
|
33
|
-
# @return [Boolean] True if this is the Relay find-by-ids field
|
34
|
-
attr_accessor :relay_nodes_field
|
35
|
-
|
36
|
-
# @return [<#call(obj, args, ctx)>] A proc-like object which can be called to return the field's value
|
37
|
-
attr_reader :resolve_proc
|
38
|
-
|
39
|
-
# @return [<#call(obj, args, ctx)>] A proc-like object which can be called trigger a lazy resolution
|
40
|
-
attr_reader :lazy_resolve_proc
|
41
|
-
|
42
|
-
# @return [String] The name of this field on its {GraphQL::ObjectType} (or {GraphQL::InterfaceType})
|
43
|
-
attr_reader :name
|
44
|
-
alias :graphql_name :name
|
45
|
-
|
46
|
-
# @return [String, nil] The client-facing description of this field
|
47
|
-
attr_accessor :description
|
48
|
-
|
49
|
-
# @return [String, nil] The client-facing reason why this field is deprecated (if present, the field is deprecated)
|
50
|
-
attr_accessor :deprecation_reason
|
51
|
-
|
52
|
-
# @return [Hash<String => GraphQL::Argument>] Map String argument names to their {GraphQL::Argument} implementations
|
53
|
-
attr_accessor :arguments
|
54
|
-
|
55
|
-
# @return [GraphQL::Relay::Mutation, nil] The mutation this field was derived from, if it was derived from a mutation
|
56
|
-
attr_accessor :mutation
|
57
|
-
|
58
|
-
# @return [Numeric, Proc] The complexity for this field (default: 1), as a constant or a proc like `->(query_ctx, args, child_complexity) { } # Numeric`
|
59
|
-
attr_accessor :complexity
|
60
|
-
|
61
|
-
# @return [Symbol, nil] The method to call on `obj` to return this field (overrides {#name} if present)
|
62
|
-
attr_reader :property
|
63
|
-
|
64
|
-
# @return [Object, nil] The key to access with `obj.[]` to resolve this field (overrides {#name} if present)
|
65
|
-
attr_reader :hash_key
|
66
|
-
|
67
|
-
# @return [Object, GraphQL::Function] The function used to derive this field
|
68
|
-
attr_accessor :function
|
69
|
-
|
70
|
-
attr_accessor :arguments_class
|
71
|
-
|
72
|
-
attr_writer :connection
|
73
|
-
attr_writer :introspection
|
74
|
-
|
75
|
-
# @return [nil, String] Prefix for subscription names from this field
|
76
|
-
attr_accessor :subscription_scope
|
77
|
-
|
78
|
-
# @return [Boolean] True if this field should be traced. By default, fields are only traced if they are not a ScalarType or EnumType.
|
79
|
-
attr_accessor :trace
|
80
|
-
|
81
|
-
attr_accessor :ast_node
|
82
|
-
|
83
|
-
# Future-compatible alias
|
84
|
-
# @see {GraphQL::SchemaMember}
|
85
|
-
alias :graphql_definition :itself
|
86
|
-
|
87
|
-
# @return [Boolean]
|
88
|
-
def connection?
|
89
|
-
@connection
|
90
|
-
end
|
91
|
-
|
92
|
-
# @return [nil, Class]
|
93
|
-
# @api private
|
94
|
-
attr_accessor :edge_class
|
95
|
-
|
96
|
-
# @return [Boolean]
|
97
|
-
def edges?
|
98
|
-
!!@edge_class
|
99
|
-
end
|
100
|
-
|
101
|
-
# @return [nil, Integer]
|
102
|
-
attr_accessor :connection_max_page_size
|
103
|
-
|
104
|
-
def initialize
|
105
|
-
@complexity = 1
|
106
|
-
@arguments = {}
|
107
|
-
@resolve_proc = build_default_resolver
|
108
|
-
@lazy_resolve_proc = DefaultLazyResolve
|
109
|
-
@relay_node_field = false
|
110
|
-
@connection = false
|
111
|
-
@connection_max_page_size = nil
|
112
|
-
@edge_class = nil
|
113
|
-
@trace = nil
|
114
|
-
@introspection = false
|
115
|
-
end
|
116
|
-
|
117
|
-
def initialize_copy(other)
|
118
|
-
ensure_defined
|
119
|
-
super
|
120
|
-
@arguments = other.arguments.dup
|
121
|
-
end
|
122
|
-
|
123
|
-
# @return [Boolean] Is this field a predefined introspection field?
|
124
|
-
def introspection?
|
125
|
-
@introspection
|
126
|
-
end
|
127
|
-
|
128
|
-
# Get a value for this field
|
129
|
-
# @example resolving a field value
|
130
|
-
# field.resolve(obj, args, ctx)
|
131
|
-
#
|
132
|
-
# @param object [Object] The object this field belongs to
|
133
|
-
# @param arguments [Hash] Arguments declared in the query
|
134
|
-
# @param context [GraphQL::Query::Context]
|
135
|
-
def resolve(object, arguments, context)
|
136
|
-
resolve_proc.call(object, arguments, context)
|
137
|
-
end
|
138
|
-
|
139
|
-
# Provide a new callable for this field's resolve function. If `nil`,
|
140
|
-
# a new resolve proc will be build based on its {#name}, {#property} or {#hash_key}.
|
141
|
-
# @param new_resolve_proc [<#call(obj, args, ctx)>, nil]
|
142
|
-
def resolve=(new_resolve_proc)
|
143
|
-
@resolve_proc = new_resolve_proc || build_default_resolver
|
144
|
-
end
|
145
|
-
|
146
|
-
def type=(new_return_type)
|
147
|
-
@clean_type = nil
|
148
|
-
@dirty_type = new_return_type
|
149
|
-
end
|
150
|
-
|
151
|
-
# Get the return type for this field.
|
152
|
-
def type
|
153
|
-
@clean_type ||= GraphQL::BaseType.resolve_related_type(@dirty_type)
|
154
|
-
end
|
155
|
-
|
156
|
-
def name=(new_name)
|
157
|
-
old_name = defined?(@name) ? @name : nil
|
158
|
-
@name = new_name
|
159
|
-
|
160
|
-
if old_name != new_name && @resolve_proc.is_a?(Field::Resolve::NameResolve)
|
161
|
-
# Since the NameResolve would use the old field name,
|
162
|
-
# reset resolve proc when the name has changed
|
163
|
-
self.resolve = nil
|
164
|
-
end
|
165
|
-
end
|
166
|
-
|
167
|
-
# @param new_property [Symbol] A method to call to resolve this field. Overrides the existing resolve proc.
|
168
|
-
def property=(new_property)
|
169
|
-
@property = new_property
|
170
|
-
self.resolve = nil # reset resolve proc
|
171
|
-
end
|
172
|
-
|
173
|
-
# @param new_hash_key [Symbol] A key to access with `#[key]` to resolve this field. Overrides the existing resolve proc.
|
174
|
-
def hash_key=(new_hash_key)
|
175
|
-
@hash_key = new_hash_key
|
176
|
-
self.resolve = nil # reset resolve proc
|
177
|
-
end
|
178
|
-
|
179
|
-
def to_s
|
180
|
-
"<Field name:#{name || "not-named"} desc:#{description} resolve:#{resolve_proc}>"
|
181
|
-
end
|
182
|
-
|
183
|
-
# If {#resolve} returned an object which should be handled lazily,
|
184
|
-
# this method will be called later to force the object to return its value.
|
185
|
-
# @param obj [Object] The {#resolve}-provided object, registered with {Schema#lazy_resolve}
|
186
|
-
# @param args [GraphQL::Query::Arguments] Arguments to this field
|
187
|
-
# @param ctx [GraphQL::Query::Context] Context for this field
|
188
|
-
# @return [Object] The result of calling the registered method on `obj`
|
189
|
-
def lazy_resolve(obj, args, ctx)
|
190
|
-
@lazy_resolve_proc.call(obj, args, ctx)
|
191
|
-
end
|
192
|
-
|
193
|
-
# Assign a new resolve proc to this field. Used for {#lazy_resolve}
|
194
|
-
def lazy_resolve=(new_lazy_resolve_proc)
|
195
|
-
@lazy_resolve_proc = new_lazy_resolve_proc
|
196
|
-
end
|
197
|
-
|
198
|
-
# Prepare a lazy value for this field. It may be `then`-ed and resolved later.
|
199
|
-
# @return [GraphQL::Execution::Lazy] A lazy wrapper around `obj` and its registered method name
|
200
|
-
def prepare_lazy(obj, args, ctx)
|
201
|
-
GraphQL::Execution::Lazy.new {
|
202
|
-
lazy_resolve(obj, args, ctx)
|
203
|
-
}
|
204
|
-
end
|
205
|
-
|
206
|
-
def type_class
|
207
|
-
metadata[:type_class]
|
208
|
-
end
|
209
|
-
|
210
|
-
def get_argument(argument_name)
|
211
|
-
arguments[argument_name]
|
212
|
-
end
|
213
|
-
|
214
|
-
private
|
215
|
-
|
216
|
-
def build_default_resolver
|
217
|
-
GraphQL::Field::Resolve.create_proc(self)
|
218
|
-
end
|
219
|
-
|
220
|
-
module DefaultLazyResolve
|
221
|
-
def self.call(obj, args, ctx)
|
222
|
-
ctx.schema.sync_lazy(obj)
|
223
|
-
end
|
224
|
-
end
|
225
|
-
end
|
226
|
-
end
|
data/lib/graphql/float_type.rb
DELETED
data/lib/graphql/function.rb
DELETED
@@ -1,128 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
module GraphQL
|
3
|
-
# @api deprecated
|
4
|
-
class Function
|
5
|
-
def self.inherited(subclass)
|
6
|
-
GraphQL::Deprecation.warn "GraphQL::Function (used for #{subclass}) will be removed from GraphQL-Ruby 2.0, please upgrade to resolvers: https://graphql-ruby.org/fields/resolvers.html"
|
7
|
-
end
|
8
|
-
|
9
|
-
# @return [Hash<String => GraphQL::Argument>] Arguments, keyed by name
|
10
|
-
def arguments
|
11
|
-
self.class.arguments
|
12
|
-
end
|
13
|
-
|
14
|
-
# @return [GraphQL::BaseType] Return type
|
15
|
-
def type
|
16
|
-
self.class.type
|
17
|
-
end
|
18
|
-
|
19
|
-
# @return [Object] This function's resolver
|
20
|
-
def call(obj, args, ctx)
|
21
|
-
raise GraphQL::RequiredImplementationMissingError
|
22
|
-
end
|
23
|
-
|
24
|
-
# @return [String, nil]
|
25
|
-
def description
|
26
|
-
self.class.description
|
27
|
-
end
|
28
|
-
|
29
|
-
# @return [String, nil]
|
30
|
-
def deprecation_reason
|
31
|
-
self.class.deprecation_reason
|
32
|
-
end
|
33
|
-
|
34
|
-
# @return [Integer, Proc]
|
35
|
-
def complexity
|
36
|
-
self.class.complexity || 1
|
37
|
-
end
|
38
|
-
|
39
|
-
class << self
|
40
|
-
# Define an argument for this function & its subclasses
|
41
|
-
# @see {GraphQL::Field} same arguments as the `argument` definition helper
|
42
|
-
# @return [void]
|
43
|
-
def argument(*args, **kwargs, &block)
|
44
|
-
argument = GraphQL::Argument.from_dsl(*args, **kwargs, &block)
|
45
|
-
own_arguments[argument.name] = argument
|
46
|
-
nil
|
47
|
-
end
|
48
|
-
|
49
|
-
# @return [Hash<String => GraphQL::Argument>] Arguments for this function class, including inherited arguments
|
50
|
-
def arguments
|
51
|
-
if parent_function?
|
52
|
-
own_arguments.merge(superclass.arguments)
|
53
|
-
else
|
54
|
-
own_arguments.dup
|
55
|
-
end
|
56
|
-
end
|
57
|
-
|
58
|
-
# Provides shorthand access to GraphQL's built-in types
|
59
|
-
def types
|
60
|
-
GraphQL::Define::TypeDefiner.instance
|
61
|
-
end
|
62
|
-
|
63
|
-
# Get or set the return type for this function class & descendants
|
64
|
-
# @return [GraphQL::BaseType]
|
65
|
-
def type(premade_type = nil, &block)
|
66
|
-
if block_given?
|
67
|
-
@type = GraphQL::ObjectType.define(&block)
|
68
|
-
elsif premade_type
|
69
|
-
@type = premade_type
|
70
|
-
elsif parent_function?
|
71
|
-
@type || superclass.type
|
72
|
-
else
|
73
|
-
@type
|
74
|
-
end
|
75
|
-
end
|
76
|
-
|
77
|
-
def build_field(function)
|
78
|
-
GraphQL::Field.define(
|
79
|
-
arguments: function.arguments,
|
80
|
-
complexity: function.complexity,
|
81
|
-
type: function.type,
|
82
|
-
resolve: function,
|
83
|
-
description: function.description,
|
84
|
-
function: function,
|
85
|
-
deprecation_reason: function.deprecation_reason,
|
86
|
-
)
|
87
|
-
end
|
88
|
-
|
89
|
-
# Class-level reader/writer which is inherited
|
90
|
-
# @api private
|
91
|
-
def self.inherited_value(name)
|
92
|
-
self.class_eval <<-RUBY
|
93
|
-
def #{name}(new_value = nil)
|
94
|
-
if new_value
|
95
|
-
@#{name} = new_value
|
96
|
-
elsif parent_function?
|
97
|
-
@#{name} || superclass.#{name}
|
98
|
-
else
|
99
|
-
@#{name}
|
100
|
-
end
|
101
|
-
end
|
102
|
-
RUBY
|
103
|
-
end
|
104
|
-
|
105
|
-
# @!method description(new_value = nil)
|
106
|
-
# Get or set this class's description
|
107
|
-
inherited_value(:description)
|
108
|
-
# @!method deprecation_reason(new_value = nil)
|
109
|
-
# Get or set this class's deprecation_reason
|
110
|
-
inherited_value(:deprecation_reason)
|
111
|
-
# @!method complexity(new_value = nil)
|
112
|
-
# Get or set this class's complexity
|
113
|
-
inherited_value(:complexity)
|
114
|
-
|
115
|
-
private
|
116
|
-
|
117
|
-
# Does this function inherit from another function?
|
118
|
-
def parent_function?
|
119
|
-
superclass <= GraphQL::Function
|
120
|
-
end
|
121
|
-
|
122
|
-
# Arguments defined on this class (not superclasses)
|
123
|
-
def own_arguments
|
124
|
-
@own_arguments ||= {}
|
125
|
-
end
|
126
|
-
end
|
127
|
-
end
|
128
|
-
end
|
data/lib/graphql/id_type.rb
DELETED
@@ -1,138 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
module GraphQL
|
3
|
-
# @api deprecated
|
4
|
-
class InputObjectType < GraphQL::BaseType
|
5
|
-
extend Define::InstanceDefinable::DeprecatedDefine
|
6
|
-
|
7
|
-
deprecated_accepts_definitions(
|
8
|
-
:arguments, :mutation,
|
9
|
-
input_field: GraphQL::Define::AssignArgument,
|
10
|
-
argument: GraphQL::Define::AssignArgument
|
11
|
-
)
|
12
|
-
|
13
|
-
attr_accessor :mutation, :arguments, :arguments_class
|
14
|
-
ensure_defined(:mutation, :arguments, :input_fields)
|
15
|
-
alias :input_fields :arguments
|
16
|
-
|
17
|
-
# @!attribute mutation
|
18
|
-
# @return [GraphQL::Relay::Mutation, nil] The mutation this field was derived from, if it was derived from a mutation
|
19
|
-
|
20
|
-
# @!attribute arguments
|
21
|
-
# @return [Hash<String => GraphQL::Argument>] Map String argument names to their {GraphQL::Argument} implementations
|
22
|
-
|
23
|
-
|
24
|
-
def initialize
|
25
|
-
super
|
26
|
-
@arguments = {}
|
27
|
-
end
|
28
|
-
|
29
|
-
def initialize_copy(other)
|
30
|
-
super
|
31
|
-
@arguments = other.arguments.dup
|
32
|
-
end
|
33
|
-
|
34
|
-
def kind
|
35
|
-
GraphQL::TypeKinds::INPUT_OBJECT
|
36
|
-
end
|
37
|
-
|
38
|
-
def coerce_result(value, ctx = nil)
|
39
|
-
if ctx.nil?
|
40
|
-
warn_deprecated_coerce("coerce_isolated_result")
|
41
|
-
ctx = GraphQL::Query::NullContext
|
42
|
-
end
|
43
|
-
|
44
|
-
# Allow the application to provide values as :symbols, and convert them to the strings
|
45
|
-
value = value.reduce({}) { |memo, (k, v)| memo[k.to_s] = v; memo }
|
46
|
-
|
47
|
-
result = {}
|
48
|
-
|
49
|
-
arguments.each do |input_key, input_field_defn|
|
50
|
-
input_value = value[input_key]
|
51
|
-
if value.key?(input_key)
|
52
|
-
result[input_key] = if input_value.nil?
|
53
|
-
nil
|
54
|
-
else
|
55
|
-
input_field_defn.type.coerce_result(input_value, ctx)
|
56
|
-
end
|
57
|
-
end
|
58
|
-
end
|
59
|
-
|
60
|
-
result
|
61
|
-
end
|
62
|
-
|
63
|
-
def get_argument(argument_name)
|
64
|
-
arguments[argument_name]
|
65
|
-
end
|
66
|
-
|
67
|
-
private
|
68
|
-
|
69
|
-
def coerce_non_null_input(value, ctx)
|
70
|
-
input_values = {}
|
71
|
-
defaults_used = Set.new
|
72
|
-
|
73
|
-
arguments.each do |input_key, input_field_defn|
|
74
|
-
field_value = value[input_key]
|
75
|
-
|
76
|
-
if value.key?(input_key)
|
77
|
-
coerced_value = input_field_defn.type.coerce_input(field_value, ctx)
|
78
|
-
input_values[input_key] = input_field_defn.prepare(coerced_value, ctx)
|
79
|
-
elsif input_field_defn.default_value?
|
80
|
-
coerced_value = input_field_defn.type.coerce_input(input_field_defn.default_value, ctx)
|
81
|
-
input_values[input_key] = coerced_value
|
82
|
-
defaults_used << input_key
|
83
|
-
end
|
84
|
-
end
|
85
|
-
|
86
|
-
result = arguments_class.new(input_values, context: ctx, defaults_used: defaults_used)
|
87
|
-
result.prepare
|
88
|
-
end
|
89
|
-
|
90
|
-
# @api private
|
91
|
-
INVALID_OBJECT_MESSAGE = "Expected %{object} to be a key, value object responding to `to_h` or `to_unsafe_h`."
|
92
|
-
|
93
|
-
def validate_non_null_input(input, ctx)
|
94
|
-
warden = ctx.warden
|
95
|
-
result = GraphQL::Query::InputValidationResult.new
|
96
|
-
|
97
|
-
if input.is_a?(Array)
|
98
|
-
result.add_problem(INVALID_OBJECT_MESSAGE % { object: JSON.generate(input, quirks_mode: true) })
|
99
|
-
return result
|
100
|
-
end
|
101
|
-
|
102
|
-
# We're not actually _using_ the coerced result, we're just
|
103
|
-
# using these methods to make sure that the object will
|
104
|
-
# behave like a hash below, when we call `each` on it.
|
105
|
-
begin
|
106
|
-
input.to_h
|
107
|
-
rescue
|
108
|
-
begin
|
109
|
-
# Handle ActionController::Parameters:
|
110
|
-
input.to_unsafe_h
|
111
|
-
rescue
|
112
|
-
# We're not sure it'll act like a hash, so reject it:
|
113
|
-
result.add_problem(INVALID_OBJECT_MESSAGE % { object: JSON.generate(input, quirks_mode: true) })
|
114
|
-
return result
|
115
|
-
end
|
116
|
-
end
|
117
|
-
|
118
|
-
visible_arguments_map = warden.arguments(self).reduce({}) { |m, f| m[f.name] = f; m}
|
119
|
-
|
120
|
-
# Items in the input that are unexpected
|
121
|
-
input.each do |name, value|
|
122
|
-
if visible_arguments_map[name].nil?
|
123
|
-
result.add_problem("Field is not defined on #{self.graphql_name}", [name])
|
124
|
-
end
|
125
|
-
end
|
126
|
-
|
127
|
-
# Items in the input that are expected, but have invalid values
|
128
|
-
visible_arguments_map.map do |name, field|
|
129
|
-
field_result = field.type.validate_input(input[name], ctx)
|
130
|
-
if !field_result.valid?
|
131
|
-
result.merge_result!(name, field_result)
|
132
|
-
end
|
133
|
-
end
|
134
|
-
|
135
|
-
result
|
136
|
-
end
|
137
|
-
end
|
138
|
-
end
|
data/lib/graphql/int_type.rb
DELETED