in lib/elastic_apm/spies/net_http.rb [51:104]
def request(req, body = nil, &block)
unless (transaction = ElasticAPM.current_transaction)
return super(req, body, &block)
end
if ElasticAPM::Spies::NetHTTPSpy.disabled?
return super(req, body, &block)
end
host = req['host']&.split(':')&.first || address || 'localhost'
method = req.method.to_s.upcase
uri_or_path = URI(req.path)
uri =
if uri_or_path.host
uri_or_path
else
path, query = req.path.split('?')
url = use_ssl? ? +'https://' : +'http://'
url << host
url << ":#{port}" if port
url << path
url << "?#{query}" if query
URI(url)
end
context =
ElasticAPM::Span::Context.new(
http: { url: uri, method: method },
destination: ElasticAPM::Span::Context::Destination.from_uri(uri, type: SUBTYPE)
)
ElasticAPM.with_span(
"#{method} #{host}",
TYPE,
subtype: SUBTYPE,
context: context
) do |span|
trace_context = span&.trace_context || transaction.trace_context
trace_context.apply_headers { |key, value| req[key] = value }
result = super(req, body, &block)
if (http = span&.context&.http)
http.status_code = result.code
end
span&.outcome = Span::Outcome.from_http_status(result.code)
result
end
end