Module: GraphQL::Types::Relay
- Defined in:
- lib/graphql/types/relay.rb,
lib/graphql/types/relay/node.rb,
lib/graphql/types/relay/base_edge.rb,
lib/graphql/types/relay/page_info.rb,
lib/graphql/types/relay/base_field.rb,
lib/graphql/types/relay/node_field.rb,
lib/graphql/types/relay/base_object.rb,
lib/graphql/types/relay/nodes_field.rb,
lib/graphql/types/relay/base_interface.rb,
lib/graphql/types/relay/base_connection.rb
Overview
This module contains some types and fields that could support Relay conventions in GraphQL.
You can use these classes out of the box if you want, but if you want to use your own GraphQL extensions along with the features in this code, you could also open up the source files and copy the relevant methods and configuration into your own classes.
For example, the provided object types extend BaseObject, but you might want to:
- Migrate the extensions from BaseObject into your app’s base object
- Copy BaseConnection, BaseEdge, etc into your app, and change them to extend your base object.
Similarly, BaseField
’s extensions could be migrated to your app
and Node
could be implemented to mix in your base interface module.
Defined Under Namespace
Modules: BaseInterface, Node Classes: BaseConnection, BaseEdge, BaseField, BaseObject, PageInfo
Constant Summary
- NodeField =
This can be used for implementing
Query.node(id: ...)
, or use it for inspiration for your own field definition. GraphQL::Schema::Field.new( name: "node", owner: nil, type: GraphQL::Types::Relay::Node, null: true, description: "Fetches an object given its ID.", relay_node_field: true, ) do argument :id, "ID!", required: true, description: "ID of the object." def resolve(obj, args, ctx) ctx.schema.object_from_id(args[:id], ctx) end def resolve_field(obj, args, ctx) resolve(obj, args, ctx) end end
- NodesField =
This can be used for implementing
Query.nodes(ids: ...)
, or use it for inspiration for your own field definition. GraphQL::Schema::Field.new( name: "nodes", owner: nil, type: [GraphQL::Types::Relay::Node, null: true], null: false, description: "Fetches a list of objects given a list of IDs.", relay_nodes_field: true, ) do argument :ids, "[ID!]!", required: true, description: "IDs of the objects." def resolve(obj, args, ctx) args[:ids].map { |id| ctx.schema.object_from_id(id, ctx) } end def resolve_field(obj, args, ctx) resolve(obj, args, ctx) end end