Class: GraphQL::Schema::Printer
- Inherits:
-
Language::Printer
- Object
- Language::Printer
- GraphQL::Schema::Printer
- Defined in:
- lib/graphql/schema/printer.rb
Overview
Used to convert your GraphQL::Schema to a GraphQL schema string
Defined Under Namespace
Classes: IntrospectionPrinter
Instance Attribute Summary collapse
-
#schema ⇒ Object
readonly
Returns the value of attribute schema.
-
#warden ⇒ Object
readonly
Returns the value of attribute warden.
Class Method Summary collapse
-
.print_introspection_schema ⇒ Object
Return the GraphQL schema string for the introspection type system.
-
.print_schema(schema, **args) ⇒ Object
Return a GraphQL schema string for the defined types in the schema.
Instance Method Summary collapse
-
#initialize(schema, context: nil, only: nil, except: nil, introspection: false) ⇒ Printer
constructor
A new instance of Printer.
-
#print_directive(directive) ⇒ Object
-
#print_schema ⇒ Object
Return a GraphQL schema string for the defined types in the schema.
-
#print_type(type) ⇒ Object
Methods inherited from Language::Printer
Constructor Details
#initialize(schema, context: nil, only: nil, except: nil, introspection: false) ⇒ Printer
Returns a new instance of Printer.
47 48 49 50 51 52 53 54 55 56 57 58 |
# File 'lib/graphql/schema/printer.rb', line 47 def initialize(schema, context: nil, only: nil, except: nil, introspection: false) @document_from_schema = GraphQL::Language::DocumentFromSchemaDefinition.new( schema, context: context, only: only, except: except, include_introspection_types: introspection, ) @document = @document_from_schema.document @schema = schema end |
Instance Attribute Details
#schema ⇒ Object (readonly)
Returns the value of attribute schema.
40 41 42 |
# File 'lib/graphql/schema/printer.rb', line 40 def schema @schema end |
#warden ⇒ Object (readonly)
Returns the value of attribute warden.
40 41 42 |
# File 'lib/graphql/schema/printer.rb', line 40 def warden @warden end |
Class Method Details
.print_introspection_schema ⇒ Object
Return the GraphQL schema string for the introspection type system
61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 |
# File 'lib/graphql/schema/printer.rb', line 61 def self.print_introspection_schema query_root = ObjectType.define(name: "Root") do field :throwaway_field, types.String end schema = GraphQL::Schema.define(query: query_root) introspection_schema_ast = GraphQL::Language::DocumentFromSchemaDefinition.new( schema, except: ->(member, _) { member.name == "Root" }, include_introspection_types: true, include_built_in_directives: true, ).document introspection_schema_ast.to_query_string(printer: IntrospectionPrinter.new) end |
.print_schema(schema, **args) ⇒ Object
Return a GraphQL schema string for the defined types in the schema
82 83 84 85 |
# File 'lib/graphql/schema/printer.rb', line 82 def self.print_schema(schema, **args) printer = new(schema, **args) printer.print_schema end |
Instance Method Details
#print_directive(directive) ⇒ Object
97 98 99 100 101 102 103 104 105 106 107 108 109 |
# File 'lib/graphql/schema/printer.rb', line 97 def print_directive(directive) if directive.name == "deprecated" reason = directive.arguments.find { |arg| arg.name == "reason" } if reason.value == GraphQL::Schema::Directive::DEFAULT_DEPRECATION_REASON "@deprecated" else "@deprecated(reason: #{reason.value.to_s.inspect})" end else super end end |
#print_schema ⇒ Object
Return a GraphQL schema string for the defined types in the schema
88 89 90 |
# File 'lib/graphql/schema/printer.rb', line 88 def print_schema print(@document) end |
#print_type(type) ⇒ Object
92 93 94 95 |
# File 'lib/graphql/schema/printer.rb', line 92 def print_type(type) node = @document_from_schema.build_type_definition_node(type) print(node) end |