Class: GraphQL::Pagination::Connections
- Inherits:
- 
      Object
      
        - Object
- GraphQL::Pagination::Connections
 
- Defined in:
- lib/graphql/pagination/connections.rb
Overview
A schema-level connection wrapper manager.
Attach as a plugin.
Defined Under Namespace
Classes: ImplementationMissingError
Class Method Summary collapse
Instance Method Summary collapse
- 
  
    
      #add(nodes_class, implementation)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
- 
  
    
      #all_wrappers  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
- 
  
    
      #delete(nodes_class)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
- 
  
    
      #edge_class_for_field(field)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  private
  
    use an override if there is one. 
- 
  
    
      #initialize(schema:)  ⇒ Connections 
    
    
  
  
  
    constructor
  
  
  
  
  
  
  
    A new instance of Connections. 
- 
  
    
      #wrap(field, parent, items, arguments, context, wrappers: all_wrappers)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Used by the runtime to wrap values in connection wrappers. 
- 
  
    
      #wrapper_for(items, wrappers: all_wrappers)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
Constructor Details
#initialize(schema:) ⇒ Connections
Returns a new instance of Connections.
| 42 43 44 45 46 | # File 'lib/graphql/pagination/connections.rb', line 42 def initialize(schema:) @schema = schema @wrappers = {} add_default end | 
Class Method Details
.use(schema_defn) ⇒ Object
| 31 32 33 34 35 36 37 38 39 40 | # File 'lib/graphql/pagination/connections.rb', line 31 def self.use(schema_defn) if schema_defn.is_a?(Class) schema_defn.connections = self.new(schema: schema_defn) else # Unwrap a `.define` object schema_defn = schema_defn.target schema_defn.connections = self.new(schema: schema_defn) schema_defn.class.connections = schema_defn.connections end end | 
Instance Method Details
#add(nodes_class, implementation) ⇒ Object
| 48 49 50 | # File 'lib/graphql/pagination/connections.rb', line 48 def add(nodes_class, implementation) @wrappers[nodes_class] = implementation end | 
#all_wrappers ⇒ Object
| 56 57 58 59 60 61 62 63 64 | # File 'lib/graphql/pagination/connections.rb', line 56 def all_wrappers all_wrappers = {} @schema.ancestors.reverse_each do |schema_class| if schema_class.respond_to?(:connections) && (c = schema_class.connections) all_wrappers.merge!(c.wrappers) end end all_wrappers end | 
#delete(nodes_class) ⇒ Object
| 52 53 54 | # File 'lib/graphql/pagination/connections.rb', line 52 def delete(nodes_class) @wrappers.delete(nodes_class) end | 
#edge_class_for_field(field) ⇒ 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.
use an override if there is one
| 103 104 105 106 107 108 109 110 111 | # File 'lib/graphql/pagination/connections.rb', line 103 def edge_class_for_field(field) conn_type = field.type.unwrap conn_type_edge_type = conn_type.respond_to?(:edge_class) && conn_type.edge_class if conn_type_edge_type && conn_type_edge_type != Relay::Edge conn_type_edge_type else nil end end | 
#wrap(field, parent, items, arguments, context, wrappers: all_wrappers) ⇒ Object
Used by the runtime to wrap values in connection wrappers.
| 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 | # File 'lib/graphql/pagination/connections.rb', line 79 def wrap(field, parent, items, arguments, context, wrappers: all_wrappers) return items if GraphQL::Execution::Interpreter::RawValue === items impl = wrapper_for(items, wrappers: wrappers) if impl.nil? raise ImplementationMissingError, "Couldn't find a connection wrapper for #{items.class} during #{field.path} (#{items.inspect})" end impl.new( items, context: context, parent: parent, max_page_size: field.max_page_size || context.schema.default_max_page_size, first: arguments[:first], after: arguments[:after], last: arguments[:last], before: arguments[:before], edge_class: edge_class_for_field(field), ) end | 
#wrapper_for(items, wrappers: all_wrappers) ⇒ Object
| 66 67 68 69 70 71 72 73 74 75 | # File 'lib/graphql/pagination/connections.rb', line 66 def wrapper_for(items, wrappers: all_wrappers) impl = nil items.class.ancestors.each { |cls| impl = wrappers[cls] break if impl } impl end |