Class: GraphQL::Stitching::Gateway
- Inherits:
-
Object
- Object
- GraphQL::Stitching::Gateway
- Defined in:
- lib/graphql/stitching/gateway.rb
Defined Under Namespace
Classes: GatewayError
Instance Attribute Summary collapse
-
#supergraph ⇒ Object
readonly
Returns the value of attribute supergraph.
Instance Method Summary collapse
- #execute(query:, variables: nil, operation_name: nil, context: nil, validate: true) ⇒ Object
-
#initialize(locations: nil, supergraph: nil, composer: nil) ⇒ Gateway
constructor
A new instance of Gateway.
- #on_cache_read(&block) ⇒ Object
- #on_cache_write(&block) ⇒ Object
- #on_error(&block) ⇒ Object
Constructor Details
#initialize(locations: nil, supergraph: nil, composer: nil) ⇒ Gateway
Returns a new instance of Gateway.
12 13 14 15 16 17 18 19 20 21 22 23 |
# File 'lib/graphql/stitching/gateway.rb', line 12 def initialize(locations: nil, supergraph: nil, composer: nil) @supergraph = if locations && supergraph raise GatewayError, "Cannot provide both locations and a supergraph." elsif supergraph && !supergraph.is_a?(GraphQL::Stitching::Supergraph) raise GatewayError, "Provided supergraph must be a GraphQL::Stitching::Supergraph instance." elsif supergraph supergraph else composer ||= GraphQL::Stitching::Composer.new composer.perform(locations) end end |
Instance Attribute Details
#supergraph ⇒ Object (readonly)
Returns the value of attribute supergraph.
10 11 12 |
# File 'lib/graphql/stitching/gateway.rb', line 10 def supergraph @supergraph end |
Instance Method Details
#execute(query:, variables: nil, operation_name: nil, context: nil, validate: true) ⇒ Object
25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 |
# File 'lib/graphql/stitching/gateway.rb', line 25 def execute(query:, variables: nil, operation_name: nil, context: nil, validate: true) request = GraphQL::Stitching::Request.new( query, operation_name: operation_name, variables: variables, context: context, ) if validate validation_errors = @supergraph.schema.validate(request.document) return error_result(validation_errors) if validation_errors.any? end request.prepare! plan = fetch_plan(request) do GraphQL::Stitching::Planner.new( supergraph: @supergraph, request: request, ).perform.to_h end GraphQL::Stitching::Executor.new( supergraph: @supergraph, request: request, plan: plan, ).perform rescue GraphQL::ParseError, GraphQL::ExecutionError => e error_result([e]) rescue StandardError => e = @on_error.call(e, request.context) if @on_error error_result([{ "message" => || "An unexpected error occured." }]) end |
#on_cache_read(&block) ⇒ Object
59 60 61 62 |
# File 'lib/graphql/stitching/gateway.rb', line 59 def on_cache_read(&block) raise GatewayError, "A cache read block is required." unless block_given? @on_cache_read = block end |
#on_cache_write(&block) ⇒ Object
64 65 66 67 |
# File 'lib/graphql/stitching/gateway.rb', line 64 def on_cache_write(&block) raise GatewayError, "A cache write block is required." unless block_given? @on_cache_write = block end |
#on_error(&block) ⇒ Object
69 70 71 72 |
# File 'lib/graphql/stitching/gateway.rb', line 69 def on_error(&block) raise GatewayError, "An error handler block is required." unless block_given? @on_error = block end |