Class: GraphQL::Query

Inherits:
Object
  • Object
show all
Extended by:
Delegate
Defined in:
lib/graphql/query.rb,
lib/graphql/query/context.rb,
lib/graphql/query/executor.rb,
lib/graphql/query/arguments.rb,
lib/graphql/query/variables.rb,
lib/graphql/query/null_context.rb,
lib/graphql/query/literal_input.rb,
lib/graphql/query/arguments_cache.rb,
lib/graphql/query/serial_execution.rb,
lib/graphql/query/validation_pipeline.rb,
lib/graphql/query/input_validation_result.rb,
lib/graphql/query/variable_validation_error.rb,
lib/graphql/query/serial_execution/field_resolution.rb,
lib/graphql/query/serial_execution/value_resolution.rb,
lib/graphql/query/serial_execution/operation_resolution.rb,
lib/graphql/query/serial_execution/selection_resolution.rb

Overview

A combination of query string and Schema instance which can be reduced to a #result.

Defined Under Namespace

Modules: ArgumentsCache Classes: Arguments, Context, Executor, InputValidationResult, LiteralInput, NullContext, OperationNameMissingError, SerialExecution, ValidationPipeline, VariableValidationError, Variables

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods included from Delegate

def_delegators

Constructor Details

#initialize(schema, query_string = nil, query: nil, document: nil, context: nil, variables: {}, validate: true, operation_name: nil, root_value: nil, max_depth: nil, max_complexity: nil, except: nil, only: nil) ⇒ Query

Prepare query query_string on schema

Parameters:

  • schema (GraphQL::Schema)
  • query_string (String) (defaults to: nil)
  • context (#[]) (defaults to: nil)

    an arbitrary hash of values which you can access in Field#resolve

  • variables (Hash) (defaults to: {})

    values for $variables in the query

  • operation_name (String) (defaults to: nil)

    if the query string contains many operations, this is the one which should be executed

  • root_value (Object) (defaults to: nil)

    the object used to resolve fields on the root type

  • max_depth (Numeric) (defaults to: nil)

    the maximum number of nested selections allowed for this query (falls back to schema-level value)

  • max_complexity (Numeric) (defaults to: nil)

    the maximum field complexity for this query (falls back to schema-level value)

  • except (<#call(schema_member, context)>) (defaults to: nil)

    If provided, objects will be hidden from the schema when .call(schema_member, context) returns truthy

  • only (<#call(schema_member, context)>) (defaults to: nil)

    If provided, objects will be hidden from the schema when .call(schema_member, context) returns false



58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
# File 'lib/graphql/query.rb', line 58

def initialize(schema, query_string = nil, query: nil, document: nil, context: nil, variables: {}, validate: true, operation_name: nil, root_value: nil, max_depth: nil, max_complexity: nil, except: nil, only: nil)
  @schema = schema
  @filter = schema.default_filter.merge(except: except, only: only)
  @context = Context.new(query: self, values: context)
  @root_value = root_value
  @fragments = nil
  @operations = nil
  @validate = validate

  @analysis_errors = []
  if variables.is_a?(String)
    raise ArgumentError, "Query variables should be a Hash, not a String. Try JSON.parse to prepare variables."
  else
    @provided_variables = variables
  end

  @query_string = query_string || query
  @document = document

  @resolved_types_cache = Hash.new { |h, k| h[k] = @schema.resolve_type(k, @context) }

  @arguments_cache = ArgumentsCache.build(self)

  # Trying to execute a document
  # with no operations returns an empty hash
  @ast_variables = []
  @mutation = false
  @operation_name = operation_name
  @prepared_ast = false

  @validation_pipeline = nil
  @max_depth = max_depth || schema.max_depth
  @max_complexity = max_complexity || schema.max_complexity

  @result = nil
  @executed = false
end

Instance Attribute Details

#analysis_errorsObject

Returns the value of attribute analysis_errors.



176
177
178
# File 'lib/graphql/query.rb', line 176

def analysis_errors
  @analysis_errors
end

#contextObject (readonly)

Returns the value of attribute context.



30
31
32
# File 'lib/graphql/query.rb', line 30

def context
  @context
end

#operation_nameObject (readonly)

Returns the value of attribute operation_name.



30
31
32
# File 'lib/graphql/query.rb', line 30

def operation_name
  @operation_name
end

#provided_variablesObject (readonly)

Returns the value of attribute provided_variables.



30
31
32
# File 'lib/graphql/query.rb', line 30

def provided_variables
  @provided_variables
end

#query_stringObject

Returns the value of attribute query_string.



35
36
37
# File 'lib/graphql/query.rb', line 35

def query_string
  @query_string
end

#root_valueObject (readonly)

Returns the value of attribute root_value.



30
31
32
# File 'lib/graphql/query.rb', line 30

def root_value
  @root_value
end

#schemaObject (readonly)

Returns the value of attribute schema.



30
31
32
# File 'lib/graphql/query.rb', line 30

def schema
  @schema
end

#validateBoolean

Returns if false, static validation is skipped (execution behavior for invalid queries is undefined).

Returns:

  • (Boolean)

    if false, static validation is skipped (execution behavior for invalid queries is undefined)



33
34
35
# File 'lib/graphql/query.rb', line 33

def validate
  @validate
end

#wardenObject (readonly)

Returns the value of attribute warden.



30
31
32
# File 'lib/graphql/query.rb', line 30

def warden
  @warden
end

Instance Method Details

#arguments_for(irep_or_ast_node, definition) ⇒ GraphQL::Query::Arguments

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Node-level cache for calculating arguments. Used during execution and query analysis.

Returns:



161
162
163
# File 'lib/graphql/query.rb', line 161

def arguments_for(irep_or_ast_node, definition)
  @arguments_cache[irep_or_ast_node][definition]
end

#documentGraphQL::Language::Nodes::Document



38
39
40
# File 'lib/graphql/query.rb', line 38

def document
  with_prepared_ast { @document }
end

#fragmentsObject



106
107
108
# File 'lib/graphql/query.rb', line 106

def fragments
  with_prepared_ast { @fragments }
end

#irep_selectionObject



154
155
156
# File 'lib/graphql/query.rb', line 154

def irep_selection
  @selection ||= internal_representation.operation_definitions[selected_operation.name]
end

#merge_filters(only: nil, except: nil) ⇒ void

This method returns an undefined value.



203
204
205
206
207
208
209
210
# File 'lib/graphql/query.rb', line 203

def merge_filters(only: nil, except: nil)
  if @prepared_ast
    raise "Can't add filters after preparing the query"
  else
    @filter = @filter.merge(only: only, except: except)
  end
  nil
end

#mutation?Boolean

Returns:

  • (Boolean)


194
195
196
# File 'lib/graphql/query.rb', line 194

def mutation?
  with_prepared_ast { @mutation }
end

#operationsObject



110
111
112
# File 'lib/graphql/query.rb', line 110

def operations
  with_prepared_ast { @operations }
end

#query?Boolean

Returns:

  • (Boolean)


198
199
200
# File 'lib/graphql/query.rb', line 198

def query?
  with_prepared_ast { @query }
end

#resolve_type(value) ⇒ GraphQL::ObjectType?

Returns The runtime type of value from Schema#resolve_type.

Parameters:

  • value (Object)

    Any runtime value

Returns:

See Also:

  • to apply filtering from `only` / `except`


190
191
192
# File 'lib/graphql/query.rb', line 190

def resolve_type(value)
  @resolved_types_cache[value]
end

#resultHash

Get the result for this query, executing it once

Returns:

  • (Hash)

    A GraphQL response, with "data" and/or "errors" keys



116
117
118
119
120
121
122
123
# File 'lib/graphql/query.rb', line 116

def result
  if !@executed
    with_prepared_ast {
      Execution::Multiplex.run_queries(@schema, [self])
    }
  end
  @result
end

#result=(result_hash) ⇒ Object

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.



97
98
99
100
101
102
103
104
# File 'lib/graphql/query.rb', line 97

def result=(result_hash)
  if @executed
    raise "Invariant: Can't reassign result"
  else
    @executed = true
    @result = result_hash
  end
end

#selected_operationGraphQL::Language::Nodes::OperationDefinition?



132
133
134
# File 'lib/graphql/query.rb', line 132

def selected_operation
  with_prepared_ast { @selected_operation }
end

#selected_operation_nameString?

Returns The name of the operation to run (may be inferred).

Returns:

  • (String, nil)

    The name of the operation to run (may be inferred)



43
44
45
# File 'lib/graphql/query.rb', line 43

def selected_operation_name
  selected_operation.name
end

#static_errorsObject



125
126
127
# File 'lib/graphql/query.rb', line 125

def static_errors
  validation_errors + analysis_errors + context.errors
end

#valid?Boolean

Returns:

  • (Boolean)


177
178
179
# File 'lib/graphql/query.rb', line 177

def valid?
  validation_pipeline.valid? && analysis_errors.none?
end

#validation_pipelineObject



170
171
172
# File 'lib/graphql/query.rb', line 170

def validation_pipeline
  with_prepared_ast { @validation_pipeline }
end

#variablesGraphQL::Query::Variables

Determine the values for variables of this query, using default values if a value isn't provided at runtime.

If some variable is invalid, errors are added to #validation_errors.

Returns:



142
143
144
145
146
147
148
149
150
151
152
# File 'lib/graphql/query.rb', line 142

def variables
  @variables ||= begin
    with_prepared_ast {
      GraphQL::Query::Variables.new(
        @context,
        @ast_variables,
        @provided_variables,
      )
    }
  end
end