Class: GraphQL::InterfaceType
- Defined in:
- lib/graphql/interface_type.rb
Overview
An Interface contains a collection of types which implement some of the same fields.
Interfaces can have fields, defined with ‘field`, just like an object type.
Objects which implement this field inherit field definitions from the interface. An object type can override the inherited definition by redefining that field.
Instance Attribute Summary
Attributes inherited from BaseType
Instance Method Summary collapse
-
#all_fields ⇒ Array<GraphQL::Field>
All fields on this type.
-
#get_field(field_name) ⇒ GraphQL::Field
The defined field for ‘field_name`.
-
#initialize ⇒ InterfaceType
constructor
A new instance of InterfaceType.
- #kind ⇒ Object
Methods inherited from BaseType
#==, #coerce_input, #connection_type, #define_connection, #define_edge, #edge_type, resolve_related_type, #resolve_type, #to_list_type, #to_non_null_type, #to_s, #unwrap, #valid_input?, #validate_input
Methods included from Define::InstanceDefinable
#define, #definition_proc=, included, #metadata
Methods included from Define::NonNullWithBang
Constructor Details
#initialize ⇒ InterfaceType
Returns a new instance of InterfaceType.
29 30 31 |
# File 'lib/graphql/interface_type.rb', line 29 def initialize @fields = {} end |
Instance Method Details
#all_fields ⇒ Array<GraphQL::Field>
Returns All fields on this type.
43 44 45 |
# File 'lib/graphql/interface_type.rb', line 43 def all_fields fields.values end |
#get_field(field_name) ⇒ GraphQL::Field
Returns The defined field for ‘field_name`.
38 39 40 |
# File 'lib/graphql/interface_type.rb', line 38 def get_field(field_name) fields[field_name] end |