ddtrace 1.12.1 → 1.23.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/CHANGELOG.md +613 -9
- data/LICENSE-3rdparty.csv +1 -1
- data/bin/ddprofrb +15 -0
- data/bin/ddtracerb +3 -1
- data/ext/{ddtrace_profiling_loader/ddtrace_profiling_loader.c → datadog_profiling_loader/datadog_profiling_loader.c} +2 -2
- data/ext/{ddtrace_profiling_loader → datadog_profiling_loader}/extconf.rb +3 -3
- data/ext/{ddtrace_profiling_native_extension → datadog_profiling_native_extension}/NativeExtensionDesign.md +3 -5
- data/ext/{ddtrace_profiling_native_extension → datadog_profiling_native_extension}/clock_id.h +0 -3
- data/ext/{ddtrace_profiling_native_extension → datadog_profiling_native_extension}/clock_id_from_pthread.c +3 -22
- data/ext/{ddtrace_profiling_native_extension → datadog_profiling_native_extension}/clock_id_noop.c +0 -1
- data/ext/{ddtrace_profiling_native_extension → datadog_profiling_native_extension}/collectors_cpu_and_wall_time_worker.c +338 -108
- data/ext/datadog_profiling_native_extension/collectors_discrete_dynamic_sampler.c +422 -0
- data/ext/datadog_profiling_native_extension/collectors_discrete_dynamic_sampler.h +101 -0
- data/ext/{ddtrace_profiling_native_extension → datadog_profiling_native_extension}/collectors_dynamic_sampling_rate.c +22 -14
- data/ext/{ddtrace_profiling_native_extension → datadog_profiling_native_extension}/collectors_dynamic_sampling_rate.h +4 -0
- data/ext/datadog_profiling_native_extension/collectors_gc_profiling_helper.c +156 -0
- data/ext/datadog_profiling_native_extension/collectors_gc_profiling_helper.h +5 -0
- data/ext/{ddtrace_profiling_native_extension → datadog_profiling_native_extension}/collectors_idle_sampling_helper.c +3 -0
- data/ext/{ddtrace_profiling_native_extension → datadog_profiling_native_extension}/collectors_stack.c +111 -118
- data/ext/{ddtrace_profiling_native_extension → datadog_profiling_native_extension}/collectors_stack.h +11 -4
- data/ext/{ddtrace_profiling_native_extension → datadog_profiling_native_extension}/collectors_thread_context.c +545 -144
- data/ext/{ddtrace_profiling_native_extension → datadog_profiling_native_extension}/collectors_thread_context.h +3 -2
- data/ext/{ddtrace_profiling_native_extension → datadog_profiling_native_extension}/extconf.rb +68 -17
- data/ext/datadog_profiling_native_extension/heap_recorder.c +1047 -0
- data/ext/datadog_profiling_native_extension/heap_recorder.h +166 -0
- data/ext/{ddtrace_profiling_native_extension → datadog_profiling_native_extension}/helpers.h +6 -0
- data/ext/{ddtrace_profiling_native_extension → datadog_profiling_native_extension}/http_transport.c +60 -32
- data/ext/datadog_profiling_native_extension/libdatadog_helpers.c +62 -0
- data/ext/datadog_profiling_native_extension/libdatadog_helpers.h +42 -0
- data/ext/{ddtrace_profiling_native_extension → datadog_profiling_native_extension}/native_extension_helpers.rb +50 -4
- data/ext/{ddtrace_profiling_native_extension → datadog_profiling_native_extension}/private_vm_api_access.c +155 -32
- data/ext/{ddtrace_profiling_native_extension → datadog_profiling_native_extension}/private_vm_api_access.h +16 -0
- data/ext/{ddtrace_profiling_native_extension → datadog_profiling_native_extension}/profiling.c +19 -3
- data/ext/datadog_profiling_native_extension/ruby_helpers.c +267 -0
- data/ext/{ddtrace_profiling_native_extension → datadog_profiling_native_extension}/ruby_helpers.h +33 -0
- data/ext/datadog_profiling_native_extension/stack_recorder.c +1040 -0
- data/ext/datadog_profiling_native_extension/stack_recorder.h +27 -0
- data/ext/datadog_profiling_native_extension/time_helpers.c +53 -0
- data/ext/datadog_profiling_native_extension/time_helpers.h +26 -0
- data/lib/datadog/appsec/assets/waf_rules/processors.json +92 -0
- data/lib/datadog/appsec/assets/waf_rules/recommended.json +698 -75
- data/lib/datadog/appsec/assets/waf_rules/scanners.json +114 -0
- data/lib/datadog/appsec/assets/waf_rules/strict.json +98 -8
- data/lib/datadog/appsec/assets.rb +8 -0
- data/lib/datadog/appsec/component.rb +21 -2
- data/lib/datadog/appsec/configuration/settings.rb +167 -189
- data/lib/datadog/appsec/configuration.rb +0 -79
- data/lib/datadog/appsec/contrib/auto_instrument.rb +2 -4
- data/lib/datadog/appsec/contrib/devise/event.rb +57 -0
- data/lib/datadog/appsec/contrib/devise/ext.rb +13 -0
- data/lib/datadog/appsec/contrib/devise/integration.rb +42 -0
- data/lib/datadog/appsec/contrib/devise/patcher/authenticatable_patch.rb +76 -0
- data/lib/datadog/appsec/contrib/devise/patcher/registration_controller_patch.rb +54 -0
- data/lib/datadog/appsec/contrib/devise/patcher.rb +45 -0
- data/lib/datadog/appsec/contrib/devise/resource.rb +35 -0
- data/lib/datadog/appsec/contrib/devise/tracking.rb +57 -0
- data/lib/datadog/appsec/contrib/rack/ext.rb +2 -1
- data/lib/datadog/appsec/contrib/rack/gateway/request.rb +6 -2
- data/lib/datadog/appsec/contrib/rack/gateway/watcher.rb +8 -6
- data/lib/datadog/appsec/contrib/rack/reactive/request.rb +3 -8
- data/lib/datadog/appsec/contrib/rack/reactive/request_body.rb +3 -6
- data/lib/datadog/appsec/contrib/rack/reactive/response.rb +3 -6
- data/lib/datadog/appsec/contrib/rack/request_body_middleware.rb +3 -2
- data/lib/datadog/appsec/contrib/rack/request_middleware.rb +77 -27
- data/lib/datadog/appsec/contrib/rails/ext.rb +3 -2
- data/lib/datadog/appsec/contrib/rails/framework.rb +1 -3
- data/lib/datadog/appsec/contrib/rails/gateway/watcher.rb +3 -2
- data/lib/datadog/appsec/contrib/rails/patcher.rb +17 -11
- data/lib/datadog/appsec/contrib/rails/reactive/action.rb +3 -6
- data/lib/datadog/appsec/contrib/sinatra/ext.rb +2 -1
- data/lib/datadog/appsec/contrib/sinatra/framework.rb +1 -3
- data/lib/datadog/appsec/contrib/sinatra/gateway/watcher.rb +6 -4
- data/lib/datadog/appsec/contrib/sinatra/patcher.rb +13 -7
- data/lib/datadog/appsec/contrib/sinatra/reactive/routed.rb +3 -6
- data/lib/datadog/appsec/event.rb +106 -50
- data/lib/datadog/appsec/extensions.rb +1 -130
- data/lib/datadog/appsec/monitor/gateway/watcher.rb +3 -3
- data/lib/datadog/appsec/monitor/reactive/set_user.rb +3 -6
- data/lib/datadog/appsec/processor/actions.rb +49 -0
- data/lib/datadog/appsec/processor/rule_loader.rb +60 -0
- data/lib/datadog/appsec/processor/rule_merger.rb +22 -2
- data/lib/datadog/appsec/processor.rb +35 -7
- data/lib/datadog/appsec/rate_limiter.rb +1 -1
- data/lib/datadog/appsec/remote.rb +17 -11
- data/lib/datadog/appsec/response.rb +82 -4
- data/lib/datadog/appsec/sample_rate.rb +21 -0
- data/lib/datadog/appsec.rb +3 -4
- data/lib/datadog/auto_instrument.rb +3 -0
- data/lib/datadog/core/backport.rb +51 -0
- data/lib/datadog/core/configuration/agent_settings_resolver.rb +38 -29
- data/lib/datadog/core/configuration/base.rb +6 -16
- data/lib/datadog/core/configuration/components.rb +20 -7
- data/lib/datadog/core/configuration/ext.rb +28 -5
- data/lib/datadog/core/configuration/option.rb +271 -21
- data/lib/datadog/core/configuration/option_definition.rb +73 -32
- data/lib/datadog/core/configuration/options.rb +27 -15
- data/lib/datadog/core/configuration/settings.rb +398 -119
- data/lib/datadog/core/configuration.rb +24 -4
- data/lib/datadog/core/diagnostics/environment_logger.rb +132 -235
- data/lib/datadog/core/environment/class_count.rb +6 -6
- data/lib/datadog/core/environment/execution.rb +103 -0
- data/lib/datadog/core/environment/ext.rb +13 -11
- data/lib/datadog/core/environment/git.rb +25 -0
- data/lib/datadog/core/environment/identity.rb +18 -48
- data/lib/datadog/core/environment/platform.rb +7 -1
- data/lib/datadog/core/environment/variable_helpers.rb +0 -69
- data/lib/datadog/core/environment/yjit.rb +58 -0
- data/lib/datadog/core/error.rb +1 -0
- data/lib/datadog/core/git/ext.rb +6 -23
- data/lib/datadog/core/logging/ext.rb +3 -1
- data/lib/datadog/core/metrics/ext.rb +7 -5
- data/lib/datadog/core/remote/client/capabilities.rb +7 -2
- data/lib/datadog/core/remote/client.rb +3 -0
- data/lib/datadog/core/remote/component.rb +52 -48
- data/lib/datadog/core/remote/configuration/content.rb +28 -1
- data/lib/datadog/core/remote/configuration/repository.rb +3 -1
- data/lib/datadog/core/remote/ext.rb +2 -1
- data/lib/datadog/core/remote/negotiation.rb +20 -7
- data/lib/datadog/core/remote/tie/tracing.rb +39 -0
- data/lib/datadog/core/remote/tie.rb +27 -0
- data/lib/datadog/core/remote/transport/config.rb +60 -0
- data/lib/datadog/core/remote/transport/http/api/instance.rb +39 -0
- data/lib/datadog/core/remote/transport/http/api/spec.rb +21 -0
- data/lib/datadog/core/remote/transport/http/api.rb +58 -0
- data/lib/datadog/core/remote/transport/http/builder.rb +219 -0
- data/lib/datadog/core/remote/transport/http/client.rb +48 -0
- data/lib/datadog/core/remote/transport/http/config.rb +280 -0
- data/lib/datadog/core/remote/transport/http/negotiation.rb +146 -0
- data/lib/datadog/core/remote/transport/http.rb +179 -0
- data/lib/datadog/core/{transport → remote/transport}/negotiation.rb +25 -23
- data/lib/datadog/core/remote/worker.rb +11 -5
- data/lib/datadog/core/runtime/ext.rb +22 -12
- data/lib/datadog/core/runtime/metrics.rb +43 -0
- data/lib/datadog/core/telemetry/client.rb +28 -10
- data/lib/datadog/core/telemetry/emitter.rb +9 -11
- data/lib/datadog/core/telemetry/event.rb +250 -44
- data/lib/datadog/core/telemetry/ext.rb +8 -1
- data/lib/datadog/core/telemetry/heartbeat.rb +3 -7
- data/lib/datadog/core/telemetry/http/ext.rb +13 -8
- data/lib/datadog/core/telemetry/http/response.rb +4 -0
- data/lib/datadog/core/telemetry/http/transport.rb +10 -3
- data/lib/datadog/core/telemetry/request.rb +59 -0
- data/lib/datadog/core/transport/ext.rb +49 -0
- data/lib/datadog/core/transport/http/adapters/net.rb +168 -0
- data/lib/datadog/core/transport/http/adapters/registry.rb +29 -0
- data/lib/datadog/core/transport/http/adapters/test.rb +89 -0
- data/lib/datadog/core/transport/http/adapters/unix_socket.rb +83 -0
- data/lib/datadog/core/transport/http/api/endpoint.rb +31 -0
- data/lib/datadog/core/transport/http/api/fallbacks.rb +26 -0
- data/lib/datadog/core/transport/http/api/map.rb +18 -0
- data/lib/datadog/core/transport/http/env.rb +62 -0
- data/lib/datadog/core/transport/http/response.rb +60 -0
- data/lib/datadog/core/transport/parcel.rb +22 -0
- data/lib/datadog/core/transport/request.rb +17 -0
- data/lib/datadog/core/transport/response.rb +64 -0
- data/lib/datadog/core/utils/duration.rb +52 -0
- data/lib/datadog/core/utils/hash.rb +47 -0
- data/lib/datadog/core/utils/network.rb +1 -1
- data/lib/datadog/core/utils/safe_dup.rb +27 -20
- data/lib/datadog/core/utils/url.rb +25 -0
- data/lib/datadog/core/utils.rb +1 -1
- data/lib/datadog/core/workers/async.rb +3 -2
- data/lib/datadog/core/workers/polling.rb +2 -2
- data/lib/datadog/kit/appsec/events.rb +139 -89
- data/lib/datadog/kit/enable_core_dumps.rb +5 -6
- data/lib/datadog/kit/identity.rb +80 -65
- data/lib/datadog/opentelemetry/api/context.rb +10 -3
- data/lib/datadog/opentelemetry/sdk/propagator.rb +5 -3
- data/lib/datadog/opentelemetry/sdk/span_processor.rb +48 -5
- data/lib/datadog/opentelemetry/sdk/trace/span.rb +167 -0
- data/lib/datadog/opentelemetry/trace.rb +58 -0
- data/lib/datadog/opentelemetry.rb +4 -0
- data/lib/datadog/opentracer/text_map_propagator.rb +2 -1
- data/lib/datadog/opentracer.rb +9 -0
- data/lib/datadog/profiling/collectors/code_provenance.rb +10 -4
- data/lib/datadog/profiling/collectors/cpu_and_wall_time_worker.rb +43 -20
- data/lib/datadog/profiling/collectors/idle_sampling_helper.rb +3 -1
- data/lib/datadog/profiling/collectors/info.rb +101 -0
- data/lib/datadog/profiling/collectors/thread_context.rb +17 -2
- data/lib/datadog/profiling/component.rb +248 -97
- data/lib/datadog/profiling/exporter.rb +26 -5
- data/lib/datadog/profiling/ext.rb +2 -12
- data/lib/datadog/profiling/flush.rb +10 -5
- data/lib/datadog/profiling/http_transport.rb +23 -6
- data/lib/datadog/profiling/load_native_extension.rb +25 -6
- data/lib/datadog/profiling/native_extension.rb +1 -22
- data/lib/datadog/profiling/profiler.rb +36 -13
- data/lib/datadog/profiling/scheduler.rb +20 -15
- data/lib/datadog/profiling/stack_recorder.rb +19 -4
- data/lib/datadog/profiling/tag_builder.rb +5 -0
- data/lib/datadog/profiling/tasks/exec.rb +3 -3
- data/lib/datadog/profiling/tasks/help.rb +3 -3
- data/lib/datadog/profiling.rb +28 -79
- data/lib/datadog/tracing/component.rb +70 -11
- data/lib/datadog/tracing/configuration/agent_settings_resolver.rb +13 -0
- data/lib/datadog/tracing/configuration/dynamic/option.rb +71 -0
- data/lib/datadog/tracing/configuration/dynamic.rb +64 -0
- data/lib/datadog/tracing/configuration/ext.rb +40 -33
- data/lib/datadog/tracing/configuration/http.rb +74 -0
- data/lib/datadog/tracing/configuration/settings.rb +136 -99
- data/lib/datadog/tracing/contrib/action_cable/configuration/settings.rb +10 -6
- data/lib/datadog/tracing/contrib/action_cable/ext.rb +21 -18
- data/lib/datadog/tracing/contrib/action_mailer/configuration/settings.rb +10 -6
- data/lib/datadog/tracing/contrib/action_mailer/events/deliver.rb +1 -1
- data/lib/datadog/tracing/contrib/action_mailer/ext.rb +21 -18
- data/lib/datadog/tracing/contrib/action_pack/configuration/settings.rb +10 -7
- data/lib/datadog/tracing/contrib/action_pack/ext.rb +11 -8
- data/lib/datadog/tracing/contrib/action_view/configuration/settings.rb +10 -6
- data/lib/datadog/tracing/contrib/action_view/ext.rb +13 -10
- data/lib/datadog/tracing/contrib/active_job/configuration/settings.rb +14 -7
- data/lib/datadog/tracing/contrib/active_job/ext.rb +26 -23
- data/lib/datadog/tracing/contrib/active_job/log_injection.rb +1 -1
- data/lib/datadog/tracing/contrib/active_job/patcher.rb +1 -1
- data/lib/datadog/tracing/contrib/active_model_serializers/configuration/settings.rb +10 -6
- data/lib/datadog/tracing/contrib/active_model_serializers/ext.rb +13 -10
- data/lib/datadog/tracing/contrib/active_record/configuration/resolver.rb +29 -15
- data/lib/datadog/tracing/contrib/active_record/configuration/settings.rb +10 -7
- data/lib/datadog/tracing/contrib/active_record/events/sql.rb +2 -6
- data/lib/datadog/tracing/contrib/active_record/ext.rb +18 -15
- data/lib/datadog/tracing/contrib/active_record/utils.rb +1 -1
- data/lib/datadog/tracing/contrib/active_support/cache/instrumentation.rb +106 -202
- data/lib/datadog/tracing/contrib/active_support/cache/patcher.rb +3 -0
- data/lib/datadog/tracing/contrib/active_support/configuration/settings.rb +10 -7
- data/lib/datadog/tracing/contrib/active_support/ext.rb +19 -16
- data/lib/datadog/tracing/contrib/analytics.rb +0 -1
- data/lib/datadog/tracing/contrib/aws/configuration/settings.rb +15 -7
- data/lib/datadog/tracing/contrib/aws/ext.rb +38 -24
- data/lib/datadog/tracing/contrib/aws/instrumentation.rb +16 -5
- data/lib/datadog/tracing/contrib/concurrent_ruby/async_patch.rb +20 -0
- data/lib/datadog/tracing/contrib/concurrent_ruby/configuration/settings.rb +3 -2
- data/lib/datadog/tracing/contrib/concurrent_ruby/context_composite_executor_service.rb +14 -14
- data/lib/datadog/tracing/contrib/concurrent_ruby/ext.rb +4 -2
- data/lib/datadog/tracing/contrib/concurrent_ruby/future_patch.rb +3 -10
- data/lib/datadog/tracing/contrib/concurrent_ruby/integration.rb +2 -1
- data/lib/datadog/tracing/contrib/concurrent_ruby/patcher.rb +19 -2
- data/lib/datadog/tracing/contrib/concurrent_ruby/promises_future_patch.rb +22 -0
- data/lib/datadog/tracing/contrib/configurable.rb +1 -1
- data/lib/datadog/tracing/contrib/configuration/settings.rb +1 -1
- data/lib/datadog/tracing/contrib/dalli/configuration/settings.rb +21 -7
- data/lib/datadog/tracing/contrib/dalli/ext.rb +27 -11
- data/lib/datadog/tracing/contrib/dalli/instrumentation.rb +17 -8
- data/lib/datadog/tracing/contrib/delayed_job/configuration/settings.rb +14 -7
- data/lib/datadog/tracing/contrib/delayed_job/ext.rb +17 -14
- data/lib/datadog/tracing/contrib/elasticsearch/configuration/settings.rb +15 -7
- data/lib/datadog/tracing/contrib/elasticsearch/ext.rb +22 -15
- data/lib/datadog/tracing/contrib/elasticsearch/patcher.rb +104 -99
- data/lib/datadog/tracing/contrib/ethon/configuration/settings.rb +17 -9
- data/lib/datadog/tracing/contrib/ethon/easy_patch.rb +48 -3
- data/lib/datadog/tracing/contrib/ethon/ext.rb +20 -11
- data/lib/datadog/tracing/contrib/ethon/multi_patch.rb +6 -3
- data/lib/datadog/tracing/contrib/excon/configuration/settings.rb +20 -10
- data/lib/datadog/tracing/contrib/excon/ext.rb +17 -8
- data/lib/datadog/tracing/contrib/excon/middleware.rb +25 -5
- data/lib/datadog/tracing/contrib/ext.rb +26 -1
- data/lib/datadog/tracing/contrib/extensions.rb +38 -2
- data/lib/datadog/tracing/contrib/faraday/configuration/settings.rb +27 -10
- data/lib/datadog/tracing/contrib/faraday/ext.rb +17 -8
- data/lib/datadog/tracing/contrib/faraday/middleware.rb +22 -6
- data/lib/datadog/tracing/contrib/grape/configuration/settings.rb +9 -6
- data/lib/datadog/tracing/contrib/grape/ext.rb +17 -14
- data/lib/datadog/tracing/contrib/graphql/configuration/settings.rb +9 -6
- data/lib/datadog/tracing/contrib/graphql/ext.rb +8 -5
- data/lib/datadog/tracing/contrib/grpc/configuration/settings.rb +40 -9
- data/lib/datadog/tracing/contrib/grpc/datadog_interceptor/client.rb +39 -20
- data/lib/datadog/tracing/contrib/grpc/datadog_interceptor/server.rb +37 -18
- data/lib/datadog/tracing/contrib/grpc/datadog_interceptor.rb +0 -4
- data/lib/datadog/tracing/contrib/grpc/ext.rb +17 -13
- data/lib/datadog/tracing/contrib/grpc/formatting.rb +127 -0
- data/lib/datadog/tracing/contrib/hanami/configuration/settings.rb +3 -2
- data/lib/datadog/tracing/contrib/hanami/ext.rb +10 -8
- data/lib/datadog/tracing/contrib/http/circuit_breaker.rb +5 -8
- data/lib/datadog/tracing/contrib/http/configuration/settings.rb +34 -11
- data/lib/datadog/tracing/contrib/http/distributed/fetcher.rb +2 -2
- data/lib/datadog/tracing/contrib/http/ext.rb +17 -9
- data/lib/datadog/tracing/contrib/http/instrumentation.rb +27 -7
- data/lib/datadog/tracing/contrib/httpclient/configuration/settings.rb +34 -11
- data/lib/datadog/tracing/contrib/httpclient/ext.rb +18 -9
- data/lib/datadog/tracing/contrib/httpclient/instrumentation.rb +22 -5
- data/lib/datadog/tracing/contrib/httprb/configuration/settings.rb +34 -11
- data/lib/datadog/tracing/contrib/httprb/ext.rb +17 -9
- data/lib/datadog/tracing/contrib/httprb/instrumentation.rb +22 -5
- data/lib/datadog/tracing/contrib/kafka/configuration/settings.rb +10 -6
- data/lib/datadog/tracing/contrib/kafka/ext.rb +43 -39
- data/lib/datadog/tracing/contrib/lograge/configuration/settings.rb +3 -2
- data/lib/datadog/tracing/contrib/lograge/ext.rb +3 -1
- data/lib/datadog/tracing/contrib/lograge/instrumentation.rb +2 -17
- data/lib/datadog/tracing/contrib/mongodb/configuration/settings.rb +15 -7
- data/lib/datadog/tracing/contrib/mongodb/ext.rb +21 -16
- data/lib/datadog/tracing/contrib/mongodb/subscribers.rb +16 -5
- data/lib/datadog/tracing/contrib/mysql2/configuration/settings.rb +22 -14
- data/lib/datadog/tracing/contrib/mysql2/ext.rb +16 -10
- data/lib/datadog/tracing/contrib/mysql2/instrumentation.rb +22 -7
- data/lib/datadog/tracing/contrib/opensearch/configuration/settings.rb +53 -0
- data/lib/datadog/tracing/contrib/opensearch/ext.rb +38 -0
- data/lib/datadog/tracing/contrib/opensearch/integration.rb +44 -0
- data/lib/datadog/tracing/contrib/opensearch/patcher.rb +135 -0
- data/lib/datadog/tracing/contrib/opensearch/quantize.rb +81 -0
- data/lib/datadog/tracing/contrib/pg/configuration/settings.rb +23 -14
- data/lib/datadog/tracing/contrib/pg/ext.rb +23 -19
- data/lib/datadog/tracing/contrib/pg/instrumentation.rb +49 -9
- data/lib/datadog/tracing/contrib/presto/configuration/settings.rb +15 -7
- data/lib/datadog/tracing/contrib/presto/ext.rb +26 -20
- data/lib/datadog/tracing/contrib/presto/instrumentation.rb +14 -5
- data/lib/datadog/tracing/contrib/propagation/sql_comment/ext.rb +12 -10
- data/lib/datadog/tracing/contrib/propagation/sql_comment.rb +1 -1
- data/lib/datadog/tracing/contrib/qless/configuration/settings.rb +13 -8
- data/lib/datadog/tracing/contrib/qless/ext.rb +15 -12
- data/lib/datadog/tracing/contrib/que/configuration/settings.rb +22 -12
- data/lib/datadog/tracing/contrib/que/ext.rb +1 -0
- data/lib/datadog/tracing/contrib/racecar/configuration/settings.rb +10 -7
- data/lib/datadog/tracing/contrib/racecar/event.rb +5 -5
- data/lib/datadog/tracing/contrib/racecar/ext.rb +21 -18
- data/lib/datadog/tracing/contrib/rack/configuration/settings.rb +17 -12
- data/lib/datadog/tracing/contrib/rack/ext.rb +19 -16
- data/lib/datadog/tracing/contrib/rack/header_collection.rb +3 -0
- data/lib/datadog/tracing/contrib/rack/header_tagging.rb +63 -0
- data/lib/datadog/tracing/contrib/rack/middlewares.rb +16 -50
- data/lib/datadog/tracing/contrib/rails/auto_instrument_railtie.rb +0 -2
- data/lib/datadog/tracing/contrib/rails/configuration/settings.rb +20 -15
- data/lib/datadog/tracing/contrib/rails/ext.rb +8 -5
- data/lib/datadog/tracing/contrib/rails/log_injection.rb +7 -10
- data/lib/datadog/tracing/contrib/rails/patcher.rb +10 -41
- data/lib/datadog/tracing/contrib/rails/railtie.rb +3 -3
- data/lib/datadog/tracing/contrib/rake/configuration/settings.rb +14 -10
- data/lib/datadog/tracing/contrib/rake/ext.rb +15 -12
- data/lib/datadog/tracing/contrib/redis/configuration/settings.rb +18 -9
- data/lib/datadog/tracing/contrib/redis/ext.rb +23 -15
- data/lib/datadog/tracing/contrib/redis/instrumentation.rb +5 -40
- data/lib/datadog/tracing/contrib/redis/patcher.rb +34 -21
- data/lib/datadog/tracing/contrib/redis/tags.rb +16 -7
- data/lib/datadog/tracing/contrib/redis/trace_middleware.rb +46 -33
- data/lib/datadog/tracing/contrib/resque/configuration/settings.rb +14 -7
- data/lib/datadog/tracing/contrib/resque/ext.rb +10 -7
- data/lib/datadog/tracing/contrib/rest_client/configuration/settings.rb +17 -9
- data/lib/datadog/tracing/contrib/rest_client/ext.rb +16 -8
- data/lib/datadog/tracing/contrib/rest_client/request_patch.rb +25 -5
- data/lib/datadog/tracing/contrib/roda/configuration/settings.rb +10 -6
- data/lib/datadog/tracing/contrib/roda/ext.rb +1 -0
- data/lib/datadog/tracing/contrib/semantic_logger/configuration/settings.rb +3 -2
- data/lib/datadog/tracing/contrib/semantic_logger/ext.rb +3 -1
- data/lib/datadog/tracing/contrib/semantic_logger/instrumentation.rb +4 -20
- data/lib/datadog/tracing/contrib/sequel/configuration/settings.rb +10 -6
- data/lib/datadog/tracing/contrib/sequel/ext.rb +11 -8
- data/lib/datadog/tracing/contrib/sequel/utils.rb +7 -7
- data/lib/datadog/tracing/contrib/shoryuken/configuration/settings.rb +15 -8
- data/lib/datadog/tracing/contrib/shoryuken/ext.rb +15 -12
- data/lib/datadog/tracing/contrib/sidekiq/configuration/settings.rb +19 -11
- data/lib/datadog/tracing/contrib/sidekiq/ext.rb +33 -30
- data/lib/datadog/tracing/contrib/sinatra/configuration/settings.rb +12 -9
- data/lib/datadog/tracing/contrib/sinatra/env.rb +0 -17
- data/lib/datadog/tracing/contrib/sinatra/ext.rb +22 -19
- data/lib/datadog/tracing/contrib/sinatra/tracer_middleware.rb +3 -14
- data/lib/datadog/tracing/contrib/sneakers/configuration/settings.rb +15 -8
- data/lib/datadog/tracing/contrib/sneakers/ext.rb +2 -0
- data/lib/datadog/tracing/contrib/sneakers/tracer.rb +1 -1
- data/lib/datadog/tracing/contrib/span_attribute_schema.rb +74 -10
- data/lib/datadog/tracing/contrib/stripe/configuration/settings.rb +10 -6
- data/lib/datadog/tracing/contrib/stripe/ext.rb +1 -0
- data/lib/datadog/tracing/contrib/sucker_punch/configuration/settings.rb +10 -6
- data/lib/datadog/tracing/contrib/sucker_punch/ext.rb +16 -13
- data/lib/datadog/tracing/contrib/trilogy/configuration/settings.rb +58 -0
- data/lib/datadog/tracing/contrib/trilogy/ext.rb +27 -0
- data/lib/datadog/tracing/contrib/trilogy/instrumentation.rb +94 -0
- data/lib/datadog/tracing/contrib/trilogy/integration.rb +43 -0
- data/lib/datadog/{ci/contrib/cucumber → tracing/contrib/trilogy}/patcher.rb +10 -6
- data/lib/datadog/tracing/contrib/utils/database.rb +5 -3
- data/lib/datadog/tracing/contrib/utils/quantization/http.rb +11 -11
- data/lib/datadog/tracing/contrib.rb +2 -0
- data/lib/datadog/tracing/correlation.rb +29 -12
- data/lib/datadog/tracing/diagnostics/environment_logger.rb +165 -0
- data/lib/datadog/tracing/diagnostics/ext.rb +21 -19
- data/lib/datadog/tracing/distributed/b3_multi.rb +2 -2
- data/lib/datadog/tracing/distributed/b3_single.rb +1 -1
- data/lib/datadog/tracing/distributed/datadog.rb +0 -1
- data/lib/datadog/tracing/distributed/propagation.rb +35 -34
- data/lib/datadog/tracing/distributed/trace_context.rb +52 -17
- data/lib/datadog/tracing/metadata/ext.rb +9 -6
- data/lib/datadog/tracing/metadata/tagging.rb +3 -3
- data/lib/datadog/tracing/remote.rb +78 -0
- data/lib/datadog/tracing/sampling/matcher.rb +23 -3
- data/lib/datadog/tracing/sampling/rule.rb +7 -2
- data/lib/datadog/tracing/sampling/rule_sampler.rb +31 -0
- data/lib/datadog/tracing/span_operation.rb +3 -15
- data/lib/datadog/tracing/sync_writer.rb +3 -3
- data/lib/datadog/tracing/trace_digest.rb +31 -0
- data/lib/datadog/tracing/trace_operation.rb +17 -5
- data/lib/datadog/tracing/trace_segment.rb +5 -2
- data/lib/datadog/tracing/tracer.rb +12 -1
- data/lib/datadog/{core → tracing}/transport/http/api/instance.rb +1 -1
- data/lib/datadog/{core → tracing}/transport/http/api/spec.rb +1 -1
- data/lib/datadog/tracing/transport/http/api.rb +43 -0
- data/lib/datadog/{core → tracing}/transport/http/builder.rb +13 -68
- data/lib/datadog/tracing/transport/http/client.rb +57 -0
- data/lib/datadog/tracing/transport/http/statistics.rb +47 -0
- data/lib/datadog/tracing/transport/http/traces.rb +152 -0
- data/lib/datadog/tracing/transport/http.rb +125 -0
- data/lib/datadog/tracing/transport/io/client.rb +89 -0
- data/lib/datadog/tracing/transport/io/response.rb +27 -0
- data/lib/datadog/tracing/transport/io/traces.rb +101 -0
- data/lib/datadog/tracing/transport/io.rb +30 -0
- data/lib/datadog/tracing/transport/serializable_trace.rb +126 -0
- data/lib/datadog/tracing/transport/statistics.rb +77 -0
- data/lib/datadog/tracing/transport/trace_formatter.rb +240 -0
- data/lib/datadog/tracing/transport/traces.rb +224 -0
- data/lib/datadog/tracing/workers/trace_writer.rb +6 -4
- data/lib/datadog/tracing/workers.rb +4 -2
- data/lib/datadog/tracing/writer.rb +5 -2
- data/lib/datadog/tracing.rb +8 -2
- data/lib/ddtrace/transport/ext.rb +22 -14
- data/lib/ddtrace/version.rb +9 -12
- data/lib/ddtrace.rb +1 -1
- metadata +157 -139
- data/ext/ddtrace_profiling_native_extension/libdatadog_helpers.h +0 -25
- data/ext/ddtrace_profiling_native_extension/ruby_helpers.c +0 -110
- data/ext/ddtrace_profiling_native_extension/stack_recorder.c +0 -591
- data/ext/ddtrace_profiling_native_extension/stack_recorder.h +0 -14
- data/ext/ddtrace_profiling_native_extension/time_helpers.c +0 -17
- data/ext/ddtrace_profiling_native_extension/time_helpers.h +0 -10
- data/lib/datadog/ci/configuration/components.rb +0 -32
- data/lib/datadog/ci/configuration/settings.rb +0 -53
- data/lib/datadog/ci/contrib/cucumber/configuration/settings.rb +0 -33
- data/lib/datadog/ci/contrib/cucumber/ext.rb +0 -20
- data/lib/datadog/ci/contrib/cucumber/formatter.rb +0 -94
- data/lib/datadog/ci/contrib/cucumber/instrumentation.rb +0 -28
- data/lib/datadog/ci/contrib/cucumber/integration.rb +0 -47
- data/lib/datadog/ci/contrib/rspec/configuration/settings.rb +0 -33
- data/lib/datadog/ci/contrib/rspec/example.rb +0 -68
- data/lib/datadog/ci/contrib/rspec/ext.rb +0 -19
- data/lib/datadog/ci/contrib/rspec/integration.rb +0 -48
- data/lib/datadog/ci/contrib/rspec/patcher.rb +0 -27
- data/lib/datadog/ci/ext/app_types.rb +0 -9
- data/lib/datadog/ci/ext/environment.rb +0 -575
- data/lib/datadog/ci/ext/settings.rb +0 -10
- data/lib/datadog/ci/ext/test.rb +0 -35
- data/lib/datadog/ci/extensions.rb +0 -19
- data/lib/datadog/ci/flush.rb +0 -38
- data/lib/datadog/ci/test.rb +0 -81
- data/lib/datadog/ci.rb +0 -20
- data/lib/datadog/core/configuration/dependency_resolver.rb +0 -28
- data/lib/datadog/core/configuration/option_definition_set.rb +0 -22
- data/lib/datadog/core/configuration/option_set.rb +0 -10
- data/lib/datadog/core/telemetry/collector.rb +0 -231
- data/lib/datadog/core/telemetry/v1/app_event.rb +0 -52
- data/lib/datadog/core/telemetry/v1/application.rb +0 -92
- data/lib/datadog/core/telemetry/v1/configuration.rb +0 -25
- data/lib/datadog/core/telemetry/v1/dependency.rb +0 -43
- data/lib/datadog/core/telemetry/v1/host.rb +0 -59
- data/lib/datadog/core/telemetry/v1/integration.rb +0 -64
- data/lib/datadog/core/telemetry/v1/product.rb +0 -36
- data/lib/datadog/core/telemetry/v1/telemetry_request.rb +0 -106
- data/lib/datadog/core/transport/config.rb +0 -58
- data/lib/datadog/core/transport/http/api.rb +0 -57
- data/lib/datadog/core/transport/http/client.rb +0 -45
- data/lib/datadog/core/transport/http/config.rb +0 -268
- data/lib/datadog/core/transport/http/negotiation.rb +0 -144
- data/lib/datadog/core/transport/http.rb +0 -169
- data/lib/datadog/core/utils/object_set.rb +0 -43
- data/lib/datadog/core/utils/string_table.rb +0 -47
- data/lib/datadog/profiling/backtrace_location.rb +0 -34
- data/lib/datadog/profiling/buffer.rb +0 -43
- data/lib/datadog/profiling/collectors/old_stack.rb +0 -301
- data/lib/datadog/profiling/encoding/profile.rb +0 -41
- data/lib/datadog/profiling/event.rb +0 -15
- data/lib/datadog/profiling/events/stack.rb +0 -82
- data/lib/datadog/profiling/old_recorder.rb +0 -107
- data/lib/datadog/profiling/pprof/builder.rb +0 -125
- data/lib/datadog/profiling/pprof/converter.rb +0 -102
- data/lib/datadog/profiling/pprof/message_set.rb +0 -16
- data/lib/datadog/profiling/pprof/payload.rb +0 -20
- data/lib/datadog/profiling/pprof/pprof.proto +0 -212
- data/lib/datadog/profiling/pprof/pprof_pb.rb +0 -81
- data/lib/datadog/profiling/pprof/stack_sample.rb +0 -139
- data/lib/datadog/profiling/pprof/string_table.rb +0 -12
- data/lib/datadog/profiling/pprof/template.rb +0 -118
- data/lib/datadog/profiling/trace_identifiers/ddtrace.rb +0 -43
- data/lib/datadog/profiling/trace_identifiers/helper.rb +0 -45
- data/lib/datadog/tracing/contrib/sinatra/headers.rb +0 -35
- data/lib/ddtrace/transport/http/adapters/net.rb +0 -168
- data/lib/ddtrace/transport/http/adapters/registry.rb +0 -27
- data/lib/ddtrace/transport/http/adapters/test.rb +0 -85
- data/lib/ddtrace/transport/http/adapters/unix_socket.rb +0 -77
- data/lib/ddtrace/transport/http/api/endpoint.rb +0 -29
- data/lib/ddtrace/transport/http/api/fallbacks.rb +0 -24
- data/lib/ddtrace/transport/http/api/instance.rb +0 -35
- data/lib/ddtrace/transport/http/api/map.rb +0 -16
- data/lib/ddtrace/transport/http/api/spec.rb +0 -17
- data/lib/ddtrace/transport/http/api.rb +0 -39
- data/lib/ddtrace/transport/http/builder.rb +0 -176
- data/lib/ddtrace/transport/http/client.rb +0 -52
- data/lib/ddtrace/transport/http/env.rb +0 -58
- data/lib/ddtrace/transport/http/response.rb +0 -58
- data/lib/ddtrace/transport/http/statistics.rb +0 -43
- data/lib/ddtrace/transport/http/traces.rb +0 -144
- data/lib/ddtrace/transport/http.rb +0 -117
- data/lib/ddtrace/transport/io/client.rb +0 -85
- data/lib/ddtrace/transport/io/response.rb +0 -25
- data/lib/ddtrace/transport/io/traces.rb +0 -99
- data/lib/ddtrace/transport/io.rb +0 -28
- data/lib/ddtrace/transport/parcel.rb +0 -20
- data/lib/ddtrace/transport/request.rb +0 -15
- data/lib/ddtrace/transport/response.rb +0 -60
- data/lib/ddtrace/transport/serializable_trace.rb +0 -122
- data/lib/ddtrace/transport/statistics.rb +0 -75
- data/lib/ddtrace/transport/trace_formatter.rb +0 -198
- data/lib/ddtrace/transport/traces.rb +0 -216
- /data/ext/{ddtrace_profiling_native_extension → datadog_profiling_native_extension}/collectors_idle_sampling_helper.h +0 -0
- /data/ext/{ddtrace_profiling_native_extension → datadog_profiling_native_extension}/setup_signal_handler.c +0 -0
- /data/ext/{ddtrace_profiling_native_extension → datadog_profiling_native_extension}/setup_signal_handler.h +0 -0
|
@@ -9,109 +9,159 @@ module Datadog
|
|
|
9
9
|
module Events
|
|
10
10
|
LOGIN_SUCCESS_EVENT = 'users.login.success'
|
|
11
11
|
LOGIN_FAILURE_EVENT = 'users.login.failure'
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
span
|
|
12
|
+
SIGNUP_EVENT = 'users.signup'
|
|
13
|
+
|
|
14
|
+
class << self
|
|
15
|
+
# Attach login success event information to the trace
|
|
16
|
+
#
|
|
17
|
+
# This method is experimental and may change in the future.
|
|
18
|
+
#
|
|
19
|
+
# @param trace [TraceOperation] Trace to attach data to. Defaults to
|
|
20
|
+
# active trace.
|
|
21
|
+
# @param span [SpanOperation] Span to attach data to. Defaults to
|
|
22
|
+
# active span on trace. Note that this should be a service entry span.
|
|
23
|
+
# When AppSec is enabled, the expected span and trace are automatically
|
|
24
|
+
# used as defaults.
|
|
25
|
+
# @param user [Hash<Symbol, String>] User information to pass to
|
|
26
|
+
# Datadog::Kit::Identity.set_user. Must contain at least :id as key.
|
|
27
|
+
# @param others [Hash<String || Symbol, String>] Additional free-form
|
|
28
|
+
# event information to attach to the trace.
|
|
29
|
+
def track_login_success(trace = nil, span = nil, user:, **others)
|
|
30
|
+
set_trace_and_span_context('track_login_success', trace, span) do |active_trace, active_span|
|
|
31
|
+
user_options = user.dup
|
|
32
|
+
user_id = user_options.delete(:id)
|
|
33
|
+
|
|
34
|
+
raise ArgumentError, 'missing required key: :user => { :id }' if user_id.nil?
|
|
35
|
+
|
|
36
|
+
track(LOGIN_SUCCESS_EVENT, active_trace, active_span, **others)
|
|
37
|
+
|
|
38
|
+
Kit::Identity.set_user(active_trace, active_span, id: user_id, **user_options)
|
|
39
|
+
end
|
|
31
40
|
end
|
|
32
41
|
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
42
|
+
# Attach login failure event information to the trace
|
|
43
|
+
#
|
|
44
|
+
# This method is experimental and may change in the future.
|
|
45
|
+
#
|
|
46
|
+
# @param trace [TraceOperation] Trace to attach data to. Defaults to
|
|
47
|
+
# active trace.
|
|
48
|
+
# @param span [SpanOperation] Span to attach data to. Defaults to
|
|
49
|
+
# active span on trace. Note that this should be a service entry span.
|
|
50
|
+
# When AppSec is enabled, the expected span and trace are automatically
|
|
51
|
+
# used as defaults.
|
|
52
|
+
# @param user_id [String] User id that attempted login
|
|
53
|
+
# @param user_exists [bool] Whether the user id that did a login attempt exists.
|
|
54
|
+
# @param others [Hash<String || Symbol, String>] Additional free-form
|
|
55
|
+
# event information to attach to the trace.
|
|
56
|
+
def track_login_failure(trace = nil, span = nil, user_id:, user_exists:, **others)
|
|
57
|
+
set_trace_and_span_context('track_login_failure', trace, span) do |active_trace, active_span|
|
|
58
|
+
raise ArgumentError, 'user_id cannot be nil' if user_id.nil?
|
|
59
|
+
|
|
60
|
+
track(LOGIN_FAILURE_EVENT, active_trace, active_span, **others)
|
|
61
|
+
|
|
62
|
+
active_span.set_tag('appsec.events.users.login.failure.usr.id', user_id)
|
|
63
|
+
active_span.set_tag('appsec.events.users.login.failure.usr.exists', user_exists)
|
|
64
|
+
end
|
|
65
|
+
end
|
|
44
66
|
|
|
45
|
-
|
|
46
|
-
|
|
67
|
+
# Attach signup event information to the trace
|
|
68
|
+
#
|
|
69
|
+
# This method is experimental and may change in the future.
|
|
70
|
+
#
|
|
71
|
+
# @param trace [TraceOperation] Trace to attach data to. Defaults to
|
|
72
|
+
# active trace.
|
|
73
|
+
# @param span [SpanOperation] Span to attach data to. Defaults to
|
|
74
|
+
# active span on trace. Note that this should be a service entry span.
|
|
75
|
+
# When AppSec is enabled, the expected span and trace are automatically
|
|
76
|
+
# used as defaults.
|
|
77
|
+
# @param user [Hash<Symbol, String>] User information to pass to
|
|
78
|
+
# Datadog::Kit::Identity.set_user. Must contain at least :id as key.
|
|
79
|
+
# @param others [Hash<String || Symbol, String>] Additional free-form
|
|
80
|
+
# event information to attach to the trace.
|
|
81
|
+
def track_signup(trace = nil, span = nil, user:, **others)
|
|
82
|
+
set_trace_and_span_context('track_signup', trace, span) do |active_trace, active_span|
|
|
83
|
+
user_options = user.dup
|
|
84
|
+
user_id = user_options.delete(:id)
|
|
85
|
+
|
|
86
|
+
raise ArgumentError, 'missing required key: :user => { :id }' if user_id.nil?
|
|
87
|
+
|
|
88
|
+
track(SIGNUP_EVENT, active_trace, active_span, **others)
|
|
89
|
+
|
|
90
|
+
Kit::Identity.set_user(trace, id: user_id, **user_options)
|
|
91
|
+
end
|
|
92
|
+
end
|
|
47
93
|
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
94
|
+
# Attach custom event information to the trace
|
|
95
|
+
#
|
|
96
|
+
# This method is experimental and may change in the future.
|
|
97
|
+
#
|
|
98
|
+
# @param event [String] Mandatory. Event code.
|
|
99
|
+
# @param trace [TraceOperation] Trace to attach data to. Defaults to
|
|
100
|
+
# active trace.
|
|
101
|
+
# @param span [SpanOperation] Span to attach data to. Defaults to
|
|
102
|
+
# active span on trace. Note that this should be a service entry span.
|
|
103
|
+
# When AppSec is enabled, the expected span and trace are automatically
|
|
104
|
+
# used as defaults.
|
|
105
|
+
# @param others [Hash<Symbol, String>] Additional free-form
|
|
106
|
+
# event information to attach to the trace. Key must not
|
|
107
|
+
# be :track.
|
|
108
|
+
def track(event, trace = nil, span = nil, **others)
|
|
109
|
+
if trace && span
|
|
110
|
+
check_trace_span_integrity(trace, span)
|
|
111
|
+
|
|
112
|
+
span.set_tag("appsec.events.#{event}.track", 'true')
|
|
113
|
+
span.set_tag("_dd.appsec.events.#{event}.sdk", 'true')
|
|
114
|
+
|
|
115
|
+
others.each do |k, v|
|
|
116
|
+
raise ArgumentError, 'key cannot be :track' if k.to_sym == :track
|
|
117
|
+
|
|
118
|
+
span.set_tag("appsec.events.#{event}.#{k}", v) unless v.nil?
|
|
119
|
+
end
|
|
120
|
+
|
|
121
|
+
trace.keep!
|
|
122
|
+
else
|
|
123
|
+
set_trace_and_span_context('track', trace, span) do |active_trace, active_span|
|
|
124
|
+
active_span.set_tag("appsec.events.#{event}.track", 'true')
|
|
125
|
+
active_span.set_tag("_dd.appsec.events.#{event}.sdk", 'true')
|
|
126
|
+
|
|
127
|
+
others.each do |k, v|
|
|
128
|
+
raise ArgumentError, 'key cannot be :track' if k.to_sym == :track
|
|
129
|
+
|
|
130
|
+
active_span.set_tag("appsec.events.#{event}.#{k}", v) unless v.nil?
|
|
131
|
+
end
|
|
132
|
+
|
|
133
|
+
active_trace.keep!
|
|
134
|
+
end
|
|
135
|
+
end
|
|
66
136
|
end
|
|
67
137
|
|
|
68
|
-
|
|
69
|
-
span ||= trace.active_span || Datadog::Tracing.active_span
|
|
138
|
+
private
|
|
70
139
|
|
|
71
|
-
|
|
140
|
+
def set_trace_and_span_context(method, trace = nil, span = nil)
|
|
141
|
+
if (appsec_scope = Datadog::AppSec.active_scope)
|
|
142
|
+
trace = appsec_scope.trace
|
|
143
|
+
span = appsec_scope.service_entry_span
|
|
144
|
+
end
|
|
72
145
|
|
|
73
|
-
|
|
146
|
+
trace ||= Datadog::Tracing.active_trace
|
|
147
|
+
span ||= trace && trace.active_span || Datadog::Tracing.active_span
|
|
74
148
|
|
|
75
|
-
|
|
149
|
+
unless trace && span
|
|
150
|
+
Datadog.logger.debug(
|
|
151
|
+
"Tracing not enabled. Method ##{method} is a no-op. Please enable tracing if you want ##{method}"\
|
|
152
|
+
' to track this events'
|
|
153
|
+
)
|
|
154
|
+
return
|
|
155
|
+
end
|
|
76
156
|
|
|
77
|
-
|
|
78
|
-
span.set_tag('appsec.events.users.login.failure.usr.exists', user_exists)
|
|
79
|
-
end
|
|
157
|
+
check_trace_span_integrity(trace, span)
|
|
80
158
|
|
|
81
|
-
|
|
82
|
-
#
|
|
83
|
-
# This method is experimental and may change in the future.
|
|
84
|
-
#
|
|
85
|
-
# @param event [String] Mandatory. Event code.
|
|
86
|
-
# @param trace [TraceOperation] Trace to attach data to. Defaults to
|
|
87
|
-
# active trace.
|
|
88
|
-
# @param span [SpanOperation] Span to attach data to. Defaults to
|
|
89
|
-
# active span on trace. Note that this should be a service entry span.
|
|
90
|
-
# When AppSec is enabled, the expected span and trace are automatically
|
|
91
|
-
# used as defaults.
|
|
92
|
-
# @param others [Hash<Symbol, String>] Additional free-form
|
|
93
|
-
# event information to attach to the trace. Key must not
|
|
94
|
-
# be :track.
|
|
95
|
-
def self.track(event, trace = nil, span = nil, **others)
|
|
96
|
-
if (appsec_scope = Datadog::AppSec.active_scope)
|
|
97
|
-
trace = appsec_scope.trace
|
|
98
|
-
span = appsec_scope.service_entry_span
|
|
159
|
+
yield(trace, span)
|
|
99
160
|
end
|
|
100
161
|
|
|
101
|
-
trace
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
raise ArgumentError, "span #{span.span_id} does not belong to trace #{trace.id}" if trace.id != span.trace_id
|
|
105
|
-
|
|
106
|
-
span.set_tag("appsec.events.#{event}.track", 'true')
|
|
107
|
-
|
|
108
|
-
others.each do |k, v|
|
|
109
|
-
raise ArgumentError, 'key cannot be :track' if k.to_sym == :track
|
|
110
|
-
|
|
111
|
-
span.set_tag("appsec.events.#{event}.#{k}", v) unless v.nil?
|
|
162
|
+
def check_trace_span_integrity(trace, span)
|
|
163
|
+
raise ArgumentError, "span #{span.span_id} does not belong to trace #{trace.id}" if trace.id != span.trace_id
|
|
112
164
|
end
|
|
113
|
-
|
|
114
|
-
trace.keep!
|
|
115
165
|
end
|
|
116
166
|
end
|
|
117
167
|
end
|
|
@@ -16,11 +16,13 @@ module Datadog
|
|
|
16
16
|
'(Could not open /proc/sys/kernel/core_pattern)'
|
|
17
17
|
end
|
|
18
18
|
|
|
19
|
+
enabled_status = "Maximum size: #{maximum_size} Output pattern: '#{core_pattern}'"
|
|
20
|
+
|
|
19
21
|
if maximum_size <= 0
|
|
20
22
|
Kernel.warn("[ddtrace] Could not enable core dumps on crash, maximum size is #{maximum_size} (disabled).")
|
|
21
23
|
return
|
|
22
24
|
elsif maximum_size == current_size
|
|
23
|
-
Kernel.warn(
|
|
25
|
+
Kernel.warn("[ddtrace] Core dumps already enabled, nothing to do. #{enabled_status}")
|
|
24
26
|
return
|
|
25
27
|
end
|
|
26
28
|
|
|
@@ -35,12 +37,9 @@ module Datadog
|
|
|
35
37
|
end
|
|
36
38
|
|
|
37
39
|
if current_size == 0
|
|
38
|
-
Kernel.warn("[ddtrace] Enabled core dumps.
|
|
40
|
+
Kernel.warn("[ddtrace] Enabled core dumps. #{enabled_status}")
|
|
39
41
|
else
|
|
40
|
-
Kernel.warn(
|
|
41
|
-
"[ddtrace] Raised core dump limit. Old size: #{current_size} " \
|
|
42
|
-
"Maximum size: #{maximum_size} Output pattern: '#{core_pattern}'"
|
|
43
|
-
)
|
|
42
|
+
Kernel.warn("[ddtrace] Raised core dump limit. Old size: #{current_size} #{enabled_status}")
|
|
44
43
|
end
|
|
45
44
|
end
|
|
46
45
|
end
|
data/lib/datadog/kit/identity.rb
CHANGED
|
@@ -6,84 +6,99 @@ module Datadog
|
|
|
6
6
|
module Kit
|
|
7
7
|
# Tracking identity via traces
|
|
8
8
|
module Identity
|
|
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
|
-
|
|
9
|
+
class << self
|
|
10
|
+
# Attach user information to the trace
|
|
11
|
+
#
|
|
12
|
+
# @param trace [TraceOperation] Trace to attach data to. Defaults to
|
|
13
|
+
# active trace.
|
|
14
|
+
# @param span [SpanOperation] Span to attach data to. Defaults to
|
|
15
|
+
# active span on trace. Note that this should be a service entry span.
|
|
16
|
+
# When AppSec is enabled, the expected span and trace are automatically
|
|
17
|
+
# used as defaults.
|
|
18
|
+
# @param id [String] Mandatory. Username or client id extracted
|
|
19
|
+
# from the access token or Authorization header in the inbound request
|
|
20
|
+
# from outside the system.
|
|
21
|
+
# @param email [String] Email of the authenticated user associated
|
|
22
|
+
# to the trace.
|
|
23
|
+
# @param name [String] User-friendly name. To be displayed in the
|
|
24
|
+
# UI if set.
|
|
25
|
+
# @param session_id [String] Session ID of the authenticated user.
|
|
26
|
+
# @param role [String] Actual/assumed role the client is making
|
|
27
|
+
# the request under extracted from token or application security
|
|
28
|
+
# context.
|
|
29
|
+
# @param scope [String] Scopes or granted authorities the client
|
|
30
|
+
# currently possesses extracted from token or application security
|
|
31
|
+
# context. The value would come from the scope associated with an OAuth
|
|
32
|
+
# 2.0 Access Token or an attribute value in a SAML 2.0 Assertion.
|
|
33
|
+
# @param others [Hash<Symbol, String>] Additional free-form
|
|
34
|
+
# user information to attach to the trace.
|
|
35
|
+
#
|
|
36
|
+
# rubocop:disable Metrics/CyclomaticComplexity
|
|
37
|
+
# rubocop:disable Metrics/PerceivedComplexity
|
|
38
|
+
def set_user(
|
|
39
|
+
trace = nil, span = nil, id:, email: nil, name: nil, session_id: nil, role: nil, scope: nil, **others
|
|
40
|
+
)
|
|
41
|
+
raise ArgumentError, 'missing required key: :id' if id.nil?
|
|
42
42
|
|
|
43
|
-
|
|
43
|
+
# enforce types
|
|
44
44
|
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
45
|
+
raise TypeError, ':id must be a String' unless id.is_a?(String)
|
|
46
|
+
raise TypeError, ':email must be a String' unless email.nil? || email.is_a?(String)
|
|
47
|
+
raise TypeError, ':name must be a String' unless name.nil? || name.is_a?(String)
|
|
48
|
+
raise TypeError, ':session_id must be a String' unless session_id.nil? || session_id.is_a?(String)
|
|
49
|
+
raise TypeError, ':role must be a String' unless role.nil? || role.is_a?(String)
|
|
50
|
+
raise TypeError, ':scope must be a String' unless scope.nil? || scope.is_a?(String)
|
|
51
51
|
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
52
|
+
others.each do |k, v|
|
|
53
|
+
raise TypeError, "#{k.inspect} must be a String" unless v.nil? || v.is_a?(String)
|
|
54
|
+
end
|
|
55
|
+
|
|
56
|
+
set_trace_and_span_context('set_user', trace, span) do |_active_trace, active_span|
|
|
57
|
+
# set tags once data is known consistent
|
|
58
|
+
active_span.set_tag('usr.id', id)
|
|
59
|
+
active_span.set_tag('usr.email', email) unless email.nil?
|
|
60
|
+
active_span.set_tag('usr.name', name) unless name.nil?
|
|
61
|
+
active_span.set_tag('usr.session_id', session_id) unless session_id.nil?
|
|
62
|
+
active_span.set_tag('usr.role', role) unless role.nil?
|
|
63
|
+
active_span.set_tag('usr.scope', scope) unless scope.nil?
|
|
55
64
|
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
65
|
+
others.each do |k, v|
|
|
66
|
+
active_span.set_tag("usr.#{k}", v) unless v.nil?
|
|
67
|
+
end
|
|
68
|
+
|
|
69
|
+
if Datadog::AppSec.active_scope
|
|
70
|
+
user = ::Datadog::AppSec::Instrumentation::Gateway::User.new(id)
|
|
71
|
+
::Datadog::AppSec::Instrumentation.gateway.push('identity.set_user', user)
|
|
72
|
+
end
|
|
73
|
+
end
|
|
59
74
|
end
|
|
75
|
+
# rubocop:enable Metrics/PerceivedComplexity
|
|
76
|
+
# rubocop:enable Metrics/CyclomaticComplexity
|
|
60
77
|
|
|
61
|
-
|
|
62
|
-
span ||= trace.active_span || Datadog::Tracing.active_span
|
|
78
|
+
private
|
|
63
79
|
|
|
64
|
-
|
|
80
|
+
def set_trace_and_span_context(method, trace = nil, span = nil)
|
|
81
|
+
if (appsec_scope = Datadog::AppSec.active_scope)
|
|
82
|
+
trace = appsec_scope.trace
|
|
83
|
+
span = appsec_scope.service_entry_span
|
|
84
|
+
end
|
|
65
85
|
|
|
66
|
-
|
|
86
|
+
trace ||= Datadog::Tracing.active_trace
|
|
87
|
+
span ||= trace && trace.active_span || Datadog::Tracing.active_span
|
|
67
88
|
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
89
|
+
unless trace && span
|
|
90
|
+
Datadog.logger.debug(
|
|
91
|
+
"Tracing not enabled. Method ##{method} is a no-op. Please enable tracing if you want ##{method}"\
|
|
92
|
+
' to track this events'
|
|
93
|
+
)
|
|
94
|
+
return
|
|
95
|
+
end
|
|
74
96
|
|
|
75
|
-
|
|
76
|
-
span.set_tag("usr.#{k}", v) unless v.nil?
|
|
77
|
-
end
|
|
97
|
+
raise ArgumentError, "span #{span.span_id} does not belong to trace #{trace.id}" if trace.id != span.trace_id
|
|
78
98
|
|
|
79
|
-
|
|
80
|
-
user = ::Datadog::AppSec::Instrumentation::Gateway::User.new(id)
|
|
81
|
-
::Datadog::AppSec::Instrumentation.gateway.push('identity.set_user', user)
|
|
99
|
+
yield(trace, span)
|
|
82
100
|
end
|
|
83
101
|
end
|
|
84
|
-
# rubocop:enable Metrics/AbcSize
|
|
85
|
-
# rubocop:enable Metrics/PerceivedComplexity
|
|
86
|
-
# rubocop:enable Metrics/CyclomaticComplexity
|
|
87
102
|
end
|
|
88
103
|
end
|
|
89
104
|
end
|
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
require_relative 'trace/span'
|
|
4
4
|
require_relative '../../tracing/trace_operation'
|
|
5
|
+
require_relative '../trace'
|
|
5
6
|
|
|
6
7
|
module Datadog
|
|
7
8
|
module OpenTelemetry
|
|
@@ -66,9 +67,15 @@ module Datadog
|
|
|
66
67
|
# @param [Object] value Object to be stored under key
|
|
67
68
|
# @return [Context]
|
|
68
69
|
def set_values(values)
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
trace
|
|
70
|
+
if (current_span = values[CURRENT_SPAN_KEY]) && current_span.datadog_trace
|
|
71
|
+
# Because `#set_value` returns new context, we have to create
|
|
72
|
+
# a new copy of the active trace to ensure there's no conflict with
|
|
73
|
+
# other users of the active trace.
|
|
74
|
+
# It effectively becomes an internal trace propagation.
|
|
75
|
+
trace = Datadog::OpenTelemetry::Trace.start_trace_copy(
|
|
76
|
+
current_span.datadog_trace,
|
|
77
|
+
parent_span: current_span.datadog_span
|
|
78
|
+
)
|
|
72
79
|
end
|
|
73
80
|
|
|
74
81
|
existing_values = @trace && @trace.otel_values || {}
|
|
@@ -29,9 +29,10 @@ module Datadog
|
|
|
29
29
|
carrier, context: ::OpenTelemetry::Context.current,
|
|
30
30
|
getter: ::OpenTelemetry::Context::Propagation.text_map_getter
|
|
31
31
|
)
|
|
32
|
-
|
|
32
|
+
if getter != ::OpenTelemetry::Context::Propagation.text_map_getter &&
|
|
33
|
+
getter != ::OpenTelemetry::Common::Propagation.rack_env_getter
|
|
33
34
|
Datadog.logger.error(
|
|
34
|
-
|
|
35
|
+
"Custom getter #{getter} is not supported. Please inform the `ddtrace` team at " \
|
|
35
36
|
' https://github.com/DataDog/dd-trace-rb of your use case so we can best support you. Using the default ' \
|
|
36
37
|
'OpenTelemetry::Context::Propagation.text_map_getter as a fallback getter.'
|
|
37
38
|
)
|
|
@@ -81,8 +82,9 @@ module Datadog
|
|
|
81
82
|
private
|
|
82
83
|
|
|
83
84
|
# Converts the {Numeric} Datadog id object to OpenTelemetry's byte array format.
|
|
85
|
+
# This method currently converts an unsigned 64-bit Integer to a binary String.
|
|
84
86
|
def to_otel_id(dd_id)
|
|
85
|
-
Array(dd_id).pack('
|
|
87
|
+
Array(dd_id).pack('Q')
|
|
86
88
|
end
|
|
87
89
|
end
|
|
88
90
|
end
|
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
# frozen_string_literal: true
|
|
2
2
|
|
|
3
|
+
require_relative 'trace/span'
|
|
4
|
+
|
|
3
5
|
module Datadog
|
|
4
6
|
module OpenTelemetry
|
|
5
7
|
module SDK
|
|
@@ -27,7 +29,7 @@ module Datadog
|
|
|
27
29
|
#
|
|
28
30
|
# @param [Span] span the {Span} that just ended.
|
|
29
31
|
def on_finish(span)
|
|
30
|
-
span.datadog_span.finish
|
|
32
|
+
span.datadog_span.finish(ns_to_time(span.end_timestamp))
|
|
31
33
|
end
|
|
32
34
|
|
|
33
35
|
# Export all ended spans to the configured `Exporter` that have not yet
|
|
@@ -76,15 +78,56 @@ module Datadog
|
|
|
76
78
|
end
|
|
77
79
|
|
|
78
80
|
def start_datadog_span(span)
|
|
79
|
-
|
|
81
|
+
attributes = span.attributes.dup # Dup to allow modification of frozen Hash
|
|
82
|
+
|
|
83
|
+
name, kwargs = span_arguments(span, attributes)
|
|
80
84
|
|
|
81
|
-
|
|
82
|
-
tags[Tracing::Metadata::Ext::TAG_KIND] = kind
|
|
85
|
+
datadog_span = Tracing.trace(name, **kwargs)
|
|
83
86
|
|
|
84
|
-
datadog_span = Tracing.trace(span.name, tags: tags)
|
|
85
87
|
datadog_span.set_error([nil, span.status.description]) unless span.status.ok?
|
|
88
|
+
datadog_span.set_tags(span.attributes)
|
|
89
|
+
|
|
86
90
|
datadog_span
|
|
87
91
|
end
|
|
92
|
+
|
|
93
|
+
# Some special attributes can override Datadog Span fields
|
|
94
|
+
def span_arguments(span, attributes)
|
|
95
|
+
if attributes.key?('analytics.event') && (analytics_event = attributes['analytics.event']).respond_to?(:casecmp)
|
|
96
|
+
attributes[Tracing::Metadata::Ext::Analytics::TAG_SAMPLE_RATE] = analytics_event.casecmp('true') == 0 ? 1 : 0
|
|
97
|
+
end
|
|
98
|
+
attributes[Tracing::Metadata::Ext::TAG_KIND] = span.kind || 'internal'
|
|
99
|
+
|
|
100
|
+
kwargs = { start_time: ns_to_time(span.start_timestamp) }
|
|
101
|
+
|
|
102
|
+
name = if attributes.key?('operation.name')
|
|
103
|
+
attributes['operation.name']
|
|
104
|
+
elsif (rich_name = Datadog::OpenTelemetry::Trace::Span.enrich_name(span.kind, attributes))
|
|
105
|
+
rich_name.downcase
|
|
106
|
+
else
|
|
107
|
+
span.kind
|
|
108
|
+
end
|
|
109
|
+
|
|
110
|
+
kwargs[:resource] = attributes.key?('resource.name') ? attributes['resource.name'] : span.name
|
|
111
|
+
kwargs[:service] = attributes['service.name'] if attributes.key?('service.name')
|
|
112
|
+
kwargs[:type] = attributes['span.type'] if attributes.key?('span.type')
|
|
113
|
+
|
|
114
|
+
attributes.reject! { |key, _| OpenTelemetry::Trace::Span::DATADOG_SPAN_ATTRIBUTE_OVERRIDES.include?(key) }
|
|
115
|
+
|
|
116
|
+
# DEV: There's no `flat_map!`; we have to split it into two operations
|
|
117
|
+
attributes = attributes.map do |key, value|
|
|
118
|
+
Datadog::OpenTelemetry::Trace::Span.serialize_attribute(key, value)
|
|
119
|
+
end
|
|
120
|
+
attributes.flatten!(1)
|
|
121
|
+
|
|
122
|
+
kwargs[:tags] = attributes
|
|
123
|
+
|
|
124
|
+
[name, kwargs]
|
|
125
|
+
end
|
|
126
|
+
|
|
127
|
+
# From nanoseconds, used by OpenTelemetry, to a {Time} object, used by the Datadog Tracer.
|
|
128
|
+
def ns_to_time(timestamp_ns)
|
|
129
|
+
Time.at(timestamp_ns / 1000000000.0)
|
|
130
|
+
end
|
|
88
131
|
end
|
|
89
132
|
end
|
|
90
133
|
end
|