1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 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
|
# frozen_string_literal: true
module GraphQL
module Tracing
class NewRelicTracing < PlatformTracing
self.platform_keys = {
"lex" => "GraphQL/lex",
"parse" => "GraphQL/parse",
"validate" => "GraphQL/validate",
"analyze_query" => "GraphQL/analyze",
"analyze_multiplex" => "GraphQL/analyze",
"execute_multiplex" => "GraphQL/execute",
"execute_query" => "GraphQL/execute",
"execute_query_lazy" => "GraphQL/execute",
}
# @param set_transaction_name [Boolean] If true, the GraphQL operation name will be used as the transaction name.
# This is not advised if you run more than one query per HTTP request, for example, with `graphql-client` or multiplexing.
# It can also be specified per-query with `context[:set_new_relic_transaction_name]`.
def initialize(options = {})
@set_transaction_name = options.fetch(:set_transaction_name, false)
super
end
def platform_trace(platform_key, key, data)
if key == "execute_query"
set_this_txn_name = data[:query].context[:set_new_relic_transaction_name]
if set_this_txn_name == true || (set_this_txn_name.nil? && @set_transaction_name)
NewRelic::Agent.set_transaction_name(transaction_name(data[:query]))
end
end
NewRelic::Agent::MethodTracerHelpers.trace_execution_scoped(platform_key) do
yield
end
end
def platform_field_key(type, field)
"GraphQL/#{type.graphql_name}/#{field.graphql_name}"
end
def platform_authorized_key(type)
"GraphQL/Authorize/#{type.graphql_name}"
end
def platform_resolve_type_key(type)
"GraphQL/ResolveType/#{type.graphql_name}"
end
end
end
end
|