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
52
53
54
55
|
# File 'lib/datadog/tracing/contrib/httpclient/instrumentation.rb', line 23
def do_get_block(req, proxy, conn, &block)
host = req..request_uri.host
request_options = datadog_configuration(host)
client_config = Datadog.configuration_for(self)
Tracing.trace(Ext::SPAN_REQUEST, on_error: method(:annotate_span_with_error!)) do |span, trace|
begin
span.service = service_name(host, request_options, client_config)
span.type = Tracing::Metadata::Ext::HTTP::TYPE_OUTBOUND
if Tracing::Distributed::PropagationPolicy.enabled?(
pin_config: client_config,
global_config: Datadog.configuration.tracing[:httpclient],
trace: trace
)
Contrib::HTTP.inject(trace, req.)
end
annotate_span_with_request!(span, req, request_options)
rescue StandardError => e
Datadog.logger.error("error preparing span for httpclient request: #{e}, Source: #{e.backtrace}")
Datadog::Core::Telemetry::Logger.report(e)
ensure
res = super
end
annotate_span_with_response!(span, res, request_options)
res
end
end
|