Class: GraphQL::BaseType

Inherits:
Object
  • Object
show all
Includes:
Define::InstanceDefinable, Define::NonNullWithBang
Defined in:
lib/graphql/base_type.rb

Overview

The parent for all type classes.

Defined Under Namespace

Modules: ModifiesAnotherType

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Methods included from Define::InstanceDefinable

#define, #metadata, #redefine

Methods included from Define::NonNullWithBang

#!

Constructor Details

#initializeBaseType

Returns a new instance of BaseType.



20
21
22
23
24
# File 'lib/graphql/base_type.rb', line 20

def initialize
  @introspection = false
  @default_scalar = false
  @default_relay = false
end

Instance Attribute Details

#ast_nodeObject

Returns the value of attribute ast_node.



18
19
20
# File 'lib/graphql/base_type.rb', line 18

def ast_node
  @ast_node
end

#default_relay=(value) ⇒ Object (writeonly)

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.



60
61
62
# File 'lib/graphql/base_type.rb', line 60

def default_relay=(value)
  @default_relay = value
end

#default_scalar=(value) ⇒ Object (writeonly)

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.



60
61
62
# File 'lib/graphql/base_type.rb', line 60

def default_scalar=(value)
  @default_scalar = value
end

#descriptionString?

Returns a description for this type.

Returns:

  • (String, nil)

    a description for this type



42
43
44
# File 'lib/graphql/base_type.rb', line 42

def description
  @description
end

#introspection=(value) ⇒ Object (writeonly)

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.



60
61
62
# File 'lib/graphql/base_type.rb', line 60

def introspection=(value)
  @introspection = value
end

#nameString

Returns the name of this type, must be unique within a Schema.

Returns:

  • (String)

    the name of this type, must be unique within a Schema



34
35
36
# File 'lib/graphql/base_type.rb', line 34

def name
  @name
end

Class Method Details

During schema definition, types can be defined inside procs or as strings. This function converts it to a type instance

Returns:



172
173
174
175
176
177
178
179
180
181
182
183
# File 'lib/graphql/base_type.rb', line 172

def self.resolve_related_type(type_arg)
  case type_arg
  when Proc
    # lazy-eval it
    type_arg.call
  when String
    # Get a constant by this name
    Object.const_get(type_arg)
  else
    type_arg
  end
end

Instance Method Details

#==(other) ⇒ Boolean

Returns are these types equivalent? (incl. non-null, list).

Parameters:

Returns:

  • (Boolean)

    are these types equivalent? (incl. non-null, list)

See Also:

  • for override on List & NonNull types


65
66
67
# File 'lib/graphql/base_type.rb', line 65

def ==(other)
  other.is_a?(GraphQL::BaseType) && self.name == other.name
end

#coerce_input(value, ctx = nil) ⇒ Object



146
147
148
149
150
151
152
153
154
155
156
# File 'lib/graphql/base_type.rb', line 146

def coerce_input(value, ctx = nil)
  if value.nil?
    nil
  else
    if ctx.nil?
      warn_deprecated_coerce("coerce_isolated_input")
      ctx = GraphQL::Query::NullContext
    end
    coerce_non_null_input(value, ctx)
  end
end

#coerce_isolated_input(value) ⇒ Object



116
117
118
# File 'lib/graphql/base_type.rb', line 116

def coerce_isolated_input(value)
  coerce_input(value, GraphQL::Query::NullContext)
end

#coerce_isolated_result(value) ⇒ Object



120
121
122
# File 'lib/graphql/base_type.rb', line 120

def coerce_isolated_result(value)
  coerce_result(value, GraphQL::Query::NullContext)
end

#coerce_result(value, ctx) ⇒ Object

Raises:

  • (NotImplementedError)


158
159
160
# File 'lib/graphql/base_type.rb', line 158

def coerce_result(value, ctx)
  raise NotImplementedError
end

#connection_typeGraphQL::ObjectType

Returns The default connection type for this object type.

Returns:



186
187
188
# File 'lib/graphql/base_type.rb', line 186

def connection_type
  @connection_type ||= define_connection
end

#default_relay?Boolean

Returns Is this type a built-in Relay type? (Node, PageInfo).

Returns:

  • (Boolean)

    Is this type a built-in Relay type? (Node, PageInfo)



55
56
57
# File 'lib/graphql/base_type.rb', line 55

def default_relay?
  @default_relay
end

#default_scalar?Boolean

Returns Is this type a built-in scalar type? (eg, String, Int).

Returns:

  • (Boolean)

    Is this type a built-in scalar type? (eg, String, Int)



50
51
52
# File 'lib/graphql/base_type.rb', line 50

def default_scalar?
  @default_scalar
end

#define_connection(**kwargs, &block) ⇒ GraphQL::ObjectType

Define a custom connection type for this object type

Returns:



192
193
194
# File 'lib/graphql/base_type.rb', line 192

def define_connection(**kwargs, &block)
  GraphQL::Relay::ConnectionType.create_type(self, **kwargs, &block)
end

#define_edge(**kwargs, &block) ⇒ GraphQL::ObjectType

Define a custom edge type for this object type

Returns:



203
204
205
# File 'lib/graphql/base_type.rb', line 203

def define_edge(**kwargs, &block)
  GraphQL::Relay::EdgeType.create_type(self, **kwargs, &block)
end

#edge_typeGraphQL::ObjectType

Returns The default edge type for this object type.

Returns:



197
198
199
# File 'lib/graphql/base_type.rb', line 197

def edge_type
  @edge_type ||= define_edge
end

#get_field(name) ⇒ GraphQL::Field?

Types with fields may override this

Parameters:

  • name (String)

    field name to lookup for this type

Returns:



165
166
167
# File 'lib/graphql/base_type.rb', line 165

def get_field(name)
  nil
end

#initialize_copy(other) ⇒ Object



26
27
28
29
30
31
# File 'lib/graphql/base_type.rb', line 26

def initialize_copy(other)
  super
  # Reset these derived defaults
  @connection_type = nil
  @edge_type = nil
end

#introspection?Boolean

Returns Is this type a predefined introspection type?.

Returns:

  • (Boolean)

    Is this type a predefined introspection type?



45
46
47
# File 'lib/graphql/base_type.rb', line 45

def introspection?
  @introspection
end

#list?Boolean

Returns true if this is a list type. A non-nullable list is considered a list.

Returns:

  • (Boolean)


223
224
225
# File 'lib/graphql/base_type.rb', line 223

def list?
  false
end

#non_null?Boolean

Returns true if this is a non-nullable type. A nullable list of non-nullables is considered nullable.

Returns:

  • (Boolean)


218
219
220
# File 'lib/graphql/base_type.rb', line 218

def non_null?
  false
end

#resolve_type(value, ctx) ⇒ Object

Find out which possible type to use for value. Returns self if there are no possible types (ie, not Union or Interface)



97
98
99
# File 'lib/graphql/base_type.rb', line 97

def resolve_type(value, ctx)
  self
end

#to_definition(schema, printer: nil, **args) ⇒ String

Return a GraphQL string for the type definition

Parameters:

Returns:

  • (String)

    type definition

See Also:

  • for additional options}


212
213
214
215
# File 'lib/graphql/base_type.rb', line 212

def to_definition(schema, printer: nil, **args)
  printer ||= GraphQL::Schema::Printer.new(schema, **args)
  printer.print_type(self)
end

#to_list_typeGraphQL::ListType

Returns a list version of this type.

Returns:



81
82
83
# File 'lib/graphql/base_type.rb', line 81

def to_list_type
  GraphQL::ListType.new(of_type: self)
end

#to_non_null_typeGraphQL::NonNullType

Returns a non-null version of this type.

Returns:



76
77
78
# File 'lib/graphql/base_type.rb', line 76

def to_non_null_type
  GraphQL::NonNullType.new(of_type: self)
end

#to_sObject Also known as: inspect

Print the human-readable name of this type using the query-string naming pattern



102
103
104
# File 'lib/graphql/base_type.rb', line 102

def to_s
  name
end

#unwrapObject

If this type is modifying an underlying type, return the underlying type. (Otherwise, return self.)



71
72
73
# File 'lib/graphql/base_type.rb', line 71

def unwrap
  self
end

#valid_input?(value, ctx = nil) ⇒ Boolean

Returns:

  • (Boolean)


124
125
126
127
128
129
130
131
# File 'lib/graphql/base_type.rb', line 124

def valid_input?(value, ctx = nil)
  if ctx.nil?
    warn_deprecated_coerce("valid_isolated_input?")
    ctx = GraphQL::Query::NullContext
  end

  validate_input(value, ctx).valid?
end

#valid_isolated_input?(value) ⇒ Boolean

Returns:

  • (Boolean)


108
109
110
# File 'lib/graphql/base_type.rb', line 108

def valid_isolated_input?(value)
  valid_input?(value, GraphQL::Query::NullContext)
end

#validate_input(value, ctx = nil) ⇒ Object



133
134
135
136
137
138
139
140
141
142
143
144
# File 'lib/graphql/base_type.rb', line 133

def validate_input(value, ctx = nil)
  if ctx.nil?
    warn_deprecated_coerce("validate_isolated_input")
    ctx = GraphQL::Query::NullContext
  end

  if value.nil?
    GraphQL::Query::InputValidationResult.new
  else
    validate_non_null_input(value, ctx)
  end
end

#validate_isolated_input(value) ⇒ Object



112
113
114
# File 'lib/graphql/base_type.rb', line 112

def validate_isolated_input(value)
  validate_input(value, GraphQL::Query::NullContext)
end