Module: Datadog::Tracing::Contrib::GraphQL::UnifiedTrace
- Includes:
- GraphQL::Tracing::PlatformTrace
- Defined in:
- lib/datadog/tracing/contrib/graphql/unified_trace.rb
Overview
These methods will be called by the GraphQL runtime to trace the execution of queries. This tracer differs from the upstream one as it follows the unified naming convention specification, which is required to use features such as API Catalog. DEV-3.0: This tracer should be the default one in the next major version.
Instance Method Summary collapse
- #analyze_multiplex(*args, multiplex:, **kwargs) ⇒ Object
- #analyze_query(*args, query:, **kwargs) ⇒ Object
- #authorized(*args, **kwargs) ⇒ Object
- #authorized_lazy(*args, **kwargs) ⇒ Object
- #authorized_span(callable, span_key, **kwargs) ⇒ Object
- #execute_field(*args, **kwargs) ⇒ Object
- #execute_field_lazy(*args, **kwargs) ⇒ Object
- #execute_field_span(callable, span_key, **kwargs) ⇒ Object
- #execute_multiplex(*args, multiplex:, **kwargs) ⇒ Object
- #execute_query(*args, query:, **kwargs) ⇒ Object
- #execute_query_lazy(*args, query:, multiplex:, **kwargs) ⇒ Object
- #initialize(*args, **kwargs) ⇒ Object
- #lex(*args, query_string:, **kwargs) ⇒ Object
- #parse(*args, query_string:, **kwargs) ⇒ Object
- #platform_authorized_key(type, *args, **kwargs) ⇒ Object
- #platform_field_key(field, *args, **kwargs) ⇒ Object
- #platform_resolve_type_key(type, *args, **kwargs) ⇒ Object
- #resolve_type(*args, **kwargs) ⇒ Object
- #resolve_type_lazy(*args, **kwargs) ⇒ Object
- #resolve_type_span(callable, span_key, **kwargs) ⇒ Object
- #validate(*args, query:, validate:, **kwargs) ⇒ Object
Instance Method Details
#analyze_multiplex(*args, multiplex:, **kwargs) ⇒ Object
35 36 37 |
# File 'lib/datadog/tracing/contrib/graphql/unified_trace.rb', line 35 def analyze_multiplex(*args, multiplex:, **kwargs) trace(proc { super }, 'analyze_multiplex', multiplex_resource(multiplex), multiplex: multiplex) end |
#analyze_query(*args, query:, **kwargs) ⇒ Object
39 40 41 |
# File 'lib/datadog/tracing/contrib/graphql/unified_trace.rb', line 39 def analyze_query(*args, query:, **kwargs) trace(proc { super }, 'analyze', query.query_string, query: query) end |
#authorized(*args, **kwargs) ⇒ Object
109 110 111 |
# File 'lib/datadog/tracing/contrib/graphql/unified_trace.rb', line 109 def (*args, **kwargs) (proc { super }, 'authorized', **kwargs) end |
#authorized_lazy(*args, **kwargs) ⇒ Object
113 114 115 |
# File 'lib/datadog/tracing/contrib/graphql/unified_trace.rb', line 113 def (*args, **kwargs) (proc { super }, 'authorized_lazy', **kwargs) end |
#authorized_span(callable, span_key, **kwargs) ⇒ Object
104 105 106 107 |
# File 'lib/datadog/tracing/contrib/graphql/unified_trace.rb', line 104 def (callable, span_key, **kwargs) platform_key = @platform_key_cache[UnifiedTrace].[kwargs[:type]] trace(callable, span_key, platform_key, **kwargs) end |
#execute_field(*args, **kwargs) ⇒ Object
96 97 98 |
# File 'lib/datadog/tracing/contrib/graphql/unified_trace.rb', line 96 def execute_field(*args, **kwargs) execute_field_span(proc { super }, 'resolve', **kwargs) end |
#execute_field_lazy(*args, **kwargs) ⇒ Object
100 101 102 |
# File 'lib/datadog/tracing/contrib/graphql/unified_trace.rb', line 100 def execute_field_lazy(*args, **kwargs) execute_field_span(proc { super }, 'resolve_lazy', **kwargs) end |
#execute_field_span(callable, span_key, **kwargs) ⇒ Object
81 82 83 84 85 86 87 88 89 90 91 92 93 94 |
# File 'lib/datadog/tracing/contrib/graphql/unified_trace.rb', line 81 def execute_field_span(callable, span_key, **kwargs) # @platform_key_cache is initialized upstream, in ::GraphQL::Tracing::PlatformTrace platform_key = @platform_key_cache[UnifiedTrace].platform_field_key_cache[kwargs[:field]] if platform_key trace(callable, span_key, platform_key, **kwargs) do |span| kwargs[:arguments].each do |key, value| span.set_tag("graphql.variables.#{key}", value) end end else callable.call end end |
#execute_multiplex(*args, multiplex:, **kwargs) ⇒ Object
43 44 45 46 47 |
# File 'lib/datadog/tracing/contrib/graphql/unified_trace.rb', line 43 def execute_multiplex(*args, multiplex:, **kwargs) trace(proc { super }, 'execute_multiplex', multiplex_resource(multiplex), multiplex: multiplex) do |span| span.set_tag('graphql.source', "Multiplex[#{multiplex.queries.map(&:query_string).join(', ')}]") end end |
#execute_query(*args, query:, **kwargs) ⇒ Object
49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 |
# File 'lib/datadog/tracing/contrib/graphql/unified_trace.rb', line 49 def execute_query(*args, query:, **kwargs) trace( proc { super }, 'execute', query.selected_operation_name, lambda { |span| span.set_tag('graphql.source', query.query_string) span.set_tag('graphql.operation.type', query.selected_operation.operation_type) if query.selected_operation_name span.set_tag( 'graphql.operation.name', query.selected_operation_name ) end query.variables.instance_variable_get(:@storage).each do |key, value| span.set_tag("graphql.variables.#{key}", value) end }, ->(span) { add_query_error_events(span, query.context.errors) }, query: query, ) end |
#execute_query_lazy(*args, query:, multiplex:, **kwargs) ⇒ Object
72 73 74 75 76 77 78 79 |
# File 'lib/datadog/tracing/contrib/graphql/unified_trace.rb', line 72 def execute_query_lazy(*args, query:, multiplex:, **kwargs) resource = if query query.selected_operation_name || fallback_transaction_name(query.context) else multiplex_resource(multiplex) end trace(proc { super }, 'execute_lazy', resource, query: query, multiplex: multiplex) end |
#initialize(*args, **kwargs) ⇒ Object
14 15 16 17 |
# File 'lib/datadog/tracing/contrib/graphql/unified_trace.rb', line 14 def initialize(*args, **kwargs) @has_prepare_span = respond_to?(:prepare_span) super end |
#lex(*args, query_string:, **kwargs) ⇒ Object
19 20 21 |
# File 'lib/datadog/tracing/contrib/graphql/unified_trace.rb', line 19 def lex(*args, query_string:, **kwargs) trace(proc { super }, 'lex', query_string, query_string: query_string) end |
#parse(*args, query_string:, **kwargs) ⇒ Object
23 24 25 26 27 |
# File 'lib/datadog/tracing/contrib/graphql/unified_trace.rb', line 23 def parse(*args, query_string:, **kwargs) trace(proc { super }, 'parse', query_string, query_string: query_string) do |span| span.set_tag('graphql.source', query_string) end end |
#platform_authorized_key(type, *args, **kwargs) ⇒ Object
136 137 138 |
# File 'lib/datadog/tracing/contrib/graphql/unified_trace.rb', line 136 def (type, *args, **kwargs) "#{type.graphql_name}.authorized" end |
#platform_field_key(field, *args, **kwargs) ⇒ Object
132 133 134 |
# File 'lib/datadog/tracing/contrib/graphql/unified_trace.rb', line 132 def platform_field_key(field, *args, **kwargs) field.path end |
#platform_resolve_type_key(type, *args, **kwargs) ⇒ Object
140 141 142 |
# File 'lib/datadog/tracing/contrib/graphql/unified_trace.rb', line 140 def platform_resolve_type_key(type, *args, **kwargs) "#{type.graphql_name}.resolve_type" end |
#resolve_type(*args, **kwargs) ⇒ Object
122 123 124 |
# File 'lib/datadog/tracing/contrib/graphql/unified_trace.rb', line 122 def resolve_type(*args, **kwargs) resolve_type_span(proc { super }, 'resolve_type', **kwargs) end |
#resolve_type_lazy(*args, **kwargs) ⇒ Object
126 127 128 |
# File 'lib/datadog/tracing/contrib/graphql/unified_trace.rb', line 126 def resolve_type_lazy(*args, **kwargs) resolve_type_span(proc { super }, 'resolve_type_lazy', **kwargs) end |
#resolve_type_span(callable, span_key, **kwargs) ⇒ Object
117 118 119 120 |
# File 'lib/datadog/tracing/contrib/graphql/unified_trace.rb', line 117 def resolve_type_span(callable, span_key, **kwargs) platform_key = @platform_key_cache[UnifiedTrace].platform_resolve_type_key_cache[kwargs[:type]] trace(callable, span_key, platform_key, **kwargs) end |
#validate(*args, query:, validate:, **kwargs) ⇒ Object
29 30 31 32 33 |
# File 'lib/datadog/tracing/contrib/graphql/unified_trace.rb', line 29 def validate(*args, query:, validate:, **kwargs) trace(proc { super }, 'validate', query.selected_operation_name, query: query, validate: validate) do |span| span.set_tag('graphql.source', query.query_string) end end |