Sha256: b6ab2fabfd3ec207f5c913423568e7e08244013ffc6a4005a4240b591a9d2e7e
Contents?: true
Size: 1.42 KB
Versions: 3
Compression:
Stored size: 1.42 KB
Contents
# frozen_string_literal: true require_relative '../../../../ddtrace/transport/ext' module Datadog module Tracing module Contrib module HTTP # HTTP integration circuit breaker behavior # For avoiding recursive traces. module CircuitBreaker def should_skip_tracing?(request) return true if internal_request?(request) # we don't want a "shotgun" effect with two nested traces for one # logical get, and request is likely to call itself recursively active = Tracing.active_span return true if active && (active.name == Ext::SPAN_REQUEST) false end # We don't want to trace our own call to the API (they use net/http) # TODO: We don't want this kind of soft-check on HTTP requests. # Remove this when transport implements its own "skip tracing" mechanism. def internal_request?(request) !!(request[Datadog::Transport::Ext::HTTP::HEADER_META_TRACER_VERSION] || request[Transport::Ext::HTTP::HEADER_DD_INTERNAL_UNTRACED_REQUEST]) end def should_skip_distributed_tracing?(client_config) return !client_config[:distributed_tracing] if client_config && client_config.key?(:distributed_tracing) !Datadog.configuration.tracing[:http][:distributed_tracing] end end end end end end
Version data entries
3 entries across 3 versions & 1 rubygems