ddtrace 0.52.0 → 1.8.0

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.
Files changed (1169) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +701 -12
  3. data/LICENSE-3rdparty.csv +6 -1
  4. data/README.md +10 -1
  5. data/bin/ddtracerb +5 -5
  6. data/ext/ddtrace_profiling_loader/ddtrace_profiling_loader.c +134 -0
  7. data/ext/ddtrace_profiling_loader/extconf.rb +74 -0
  8. data/ext/ddtrace_profiling_native_extension/NativeExtensionDesign.md +156 -0
  9. data/ext/ddtrace_profiling_native_extension/clock_id.h +25 -0
  10. data/ext/ddtrace_profiling_native_extension/clock_id_from_pthread.c +75 -0
  11. data/ext/ddtrace_profiling_native_extension/clock_id_noop.c +23 -0
  12. data/ext/ddtrace_profiling_native_extension/collectors_cpu_and_wall_time.c +899 -0
  13. data/ext/ddtrace_profiling_native_extension/collectors_cpu_and_wall_time.h +9 -0
  14. data/ext/ddtrace_profiling_native_extension/collectors_cpu_and_wall_time_worker.c +776 -0
  15. data/ext/ddtrace_profiling_native_extension/collectors_dynamic_sampling_rate.c +142 -0
  16. data/ext/ddtrace_profiling_native_extension/collectors_dynamic_sampling_rate.h +14 -0
  17. data/ext/ddtrace_profiling_native_extension/collectors_idle_sampling_helper.c +241 -0
  18. data/ext/ddtrace_profiling_native_extension/collectors_idle_sampling_helper.h +3 -0
  19. data/ext/ddtrace_profiling_native_extension/collectors_stack.c +390 -0
  20. data/ext/ddtrace_profiling_native_extension/collectors_stack.h +18 -0
  21. data/ext/ddtrace_profiling_native_extension/extconf.rb +234 -14
  22. data/ext/ddtrace_profiling_native_extension/helpers.h +17 -0
  23. data/ext/ddtrace_profiling_native_extension/http_transport.c +353 -0
  24. data/ext/ddtrace_profiling_native_extension/libdatadog_helpers.h +14 -0
  25. data/ext/ddtrace_profiling_native_extension/native_extension_helpers.rb +297 -0
  26. data/ext/ddtrace_profiling_native_extension/private_vm_api_access.c +836 -0
  27. data/ext/ddtrace_profiling_native_extension/private_vm_api_access.h +45 -0
  28. data/ext/ddtrace_profiling_native_extension/profiling.c +237 -3
  29. data/ext/ddtrace_profiling_native_extension/ruby_helpers.c +110 -0
  30. data/ext/ddtrace_profiling_native_extension/ruby_helpers.h +89 -0
  31. data/ext/ddtrace_profiling_native_extension/setup_signal_handler.c +115 -0
  32. data/ext/ddtrace_profiling_native_extension/setup_signal_handler.h +11 -0
  33. data/ext/ddtrace_profiling_native_extension/stack_recorder.c +487 -0
  34. data/ext/ddtrace_profiling_native_extension/stack_recorder.h +39 -0
  35. data/ext/ddtrace_profiling_native_extension/time_helpers.c +17 -0
  36. data/ext/ddtrace_profiling_native_extension/time_helpers.h +10 -0
  37. data/lib/datadog/appsec/assets/blocked.html +99 -0
  38. data/lib/datadog/appsec/assets/blocked.json +1 -0
  39. data/lib/datadog/appsec/assets/blocked.text +5 -0
  40. data/lib/datadog/appsec/assets/waf_rules/README.md +7 -0
  41. data/lib/datadog/appsec/assets/waf_rules/recommended.json +6521 -0
  42. data/lib/datadog/appsec/assets/waf_rules/risky.json +1499 -0
  43. data/lib/datadog/appsec/assets/waf_rules/strict.json +1533 -0
  44. data/lib/datadog/appsec/assets.rb +38 -0
  45. data/lib/datadog/appsec/autoload.rb +18 -0
  46. data/lib/datadog/appsec/configuration/settings.rb +198 -0
  47. data/lib/datadog/appsec/configuration.rb +84 -0
  48. data/lib/datadog/appsec/contrib/auto_instrument.rb +27 -0
  49. data/lib/datadog/appsec/contrib/configuration/settings.rb +20 -0
  50. data/lib/datadog/appsec/contrib/integration.rb +37 -0
  51. data/lib/datadog/appsec/contrib/patcher.rb +12 -0
  52. data/lib/datadog/appsec/contrib/rack/configuration/settings.rb +22 -0
  53. data/lib/datadog/appsec/contrib/rack/ext.rb +15 -0
  54. data/lib/datadog/appsec/contrib/rack/gateway/watcher.rb +174 -0
  55. data/lib/datadog/appsec/contrib/rack/integration.rb +49 -0
  56. data/lib/datadog/appsec/contrib/rack/patcher.rb +32 -0
  57. data/lib/datadog/appsec/contrib/rack/reactive/request.rb +83 -0
  58. data/lib/datadog/appsec/contrib/rack/reactive/request_body.rb +64 -0
  59. data/lib/datadog/appsec/contrib/rack/reactive/response.rb +64 -0
  60. data/lib/datadog/appsec/contrib/rack/request.rb +78 -0
  61. data/lib/datadog/appsec/contrib/rack/request_body_middleware.rb +41 -0
  62. data/lib/datadog/appsec/contrib/rack/request_middleware.rb +139 -0
  63. data/lib/datadog/appsec/contrib/rack/response.rb +24 -0
  64. data/lib/datadog/appsec/contrib/rails/configuration/settings.rb +22 -0
  65. data/lib/datadog/appsec/contrib/rails/ext.rb +15 -0
  66. data/lib/datadog/appsec/contrib/rails/framework.rb +30 -0
  67. data/lib/datadog/appsec/contrib/rails/gateway/watcher.rb +82 -0
  68. data/lib/datadog/appsec/contrib/rails/integration.rb +48 -0
  69. data/lib/datadog/appsec/contrib/rails/patcher.rb +159 -0
  70. data/lib/datadog/appsec/contrib/rails/reactive/action.rb +68 -0
  71. data/lib/datadog/appsec/contrib/rails/request.rb +36 -0
  72. data/lib/datadog/appsec/contrib/rails/request_middleware.rb +20 -0
  73. data/lib/datadog/appsec/contrib/sinatra/configuration/settings.rb +22 -0
  74. data/lib/datadog/appsec/contrib/sinatra/ext.rb +16 -0
  75. data/lib/datadog/appsec/contrib/sinatra/framework.rb +34 -0
  76. data/lib/datadog/appsec/contrib/sinatra/gateway/watcher.rb +126 -0
  77. data/lib/datadog/appsec/contrib/sinatra/integration.rb +48 -0
  78. data/lib/datadog/appsec/contrib/sinatra/patcher.rb +151 -0
  79. data/lib/datadog/appsec/contrib/sinatra/reactive/routed.rb +63 -0
  80. data/lib/datadog/appsec/contrib/sinatra/request_middleware.rb +20 -0
  81. data/lib/datadog/appsec/event.rb +117 -0
  82. data/lib/datadog/appsec/extensions.rb +128 -0
  83. data/lib/datadog/appsec/instrumentation/gateway.rb +58 -0
  84. data/lib/datadog/appsec/processor.rb +198 -0
  85. data/lib/datadog/appsec/rate_limiter.rb +60 -0
  86. data/lib/datadog/appsec/reactive/address_hash.rb +18 -0
  87. data/lib/datadog/appsec/reactive/engine.rb +44 -0
  88. data/lib/datadog/appsec/reactive/operation.rb +51 -0
  89. data/lib/datadog/appsec/reactive/subscriber.rb +18 -0
  90. data/lib/datadog/appsec/response.rb +54 -0
  91. data/lib/datadog/appsec.rb +23 -0
  92. data/lib/datadog/ci/configuration/components.rb +9 -8
  93. data/lib/datadog/ci/configuration/settings.rb +20 -4
  94. data/lib/datadog/ci/contrib/cucumber/configuration/settings.rb +5 -3
  95. data/lib/datadog/ci/contrib/cucumber/ext.rb +2 -0
  96. data/lib/datadog/ci/contrib/cucumber/formatter.rb +9 -13
  97. data/lib/datadog/ci/contrib/cucumber/instrumentation.rb +3 -2
  98. data/lib/datadog/ci/contrib/cucumber/integration.rb +6 -5
  99. data/lib/datadog/ci/contrib/cucumber/patcher.rb +4 -3
  100. data/lib/datadog/ci/contrib/rspec/configuration/settings.rb +5 -3
  101. data/lib/datadog/ci/contrib/rspec/example.rb +9 -13
  102. data/lib/datadog/ci/contrib/rspec/ext.rb +2 -0
  103. data/lib/datadog/ci/contrib/rspec/integration.rb +8 -7
  104. data/lib/datadog/ci/contrib/rspec/patcher.rb +4 -3
  105. data/lib/datadog/ci/ext/app_types.rb +2 -1
  106. data/lib/datadog/ci/ext/environment.rb +189 -115
  107. data/lib/datadog/ci/ext/settings.rb +2 -1
  108. data/lib/datadog/ci/ext/test.rb +2 -0
  109. data/lib/datadog/ci/extensions.rb +7 -6
  110. data/lib/datadog/ci/flush.rb +38 -0
  111. data/lib/datadog/ci/test.rb +22 -16
  112. data/lib/datadog/ci.rb +7 -4
  113. data/lib/datadog/core/buffer/cruby.rb +55 -0
  114. data/lib/datadog/core/buffer/random.rb +134 -0
  115. data/lib/datadog/core/buffer/thread_safe.rb +58 -0
  116. data/lib/datadog/core/chunker.rb +35 -0
  117. data/lib/datadog/core/configuration/agent_settings_resolver.rb +362 -0
  118. data/lib/datadog/core/configuration/base.rb +98 -0
  119. data/lib/datadog/core/configuration/components.rb +462 -0
  120. data/lib/datadog/core/configuration/dependency_resolver.rb +28 -0
  121. data/lib/datadog/core/configuration/ext.rb +18 -0
  122. data/lib/datadog/core/configuration/option.rb +69 -0
  123. data/lib/datadog/core/configuration/option_definition.rb +126 -0
  124. data/lib/datadog/core/configuration/option_definition_set.rb +22 -0
  125. data/lib/datadog/core/configuration/option_set.rb +10 -0
  126. data/lib/datadog/core/configuration/options.rb +118 -0
  127. data/lib/datadog/core/configuration/settings.rb +444 -0
  128. data/lib/datadog/core/configuration.rb +289 -0
  129. data/lib/datadog/core/diagnostics/environment_logger.rb +287 -0
  130. data/lib/datadog/core/diagnostics/health.rb +19 -0
  131. data/lib/datadog/core/encoding.rb +76 -0
  132. data/lib/datadog/core/environment/cgroup.rb +5 -2
  133. data/lib/datadog/core/environment/class_count.rb +1 -0
  134. data/lib/datadog/core/environment/container.rb +4 -2
  135. data/lib/datadog/core/environment/ext.rb +29 -10
  136. data/lib/datadog/core/environment/gc.rb +1 -0
  137. data/lib/datadog/core/environment/identity.rb +12 -5
  138. data/lib/datadog/core/environment/platform.rb +40 -0
  139. data/lib/datadog/core/environment/socket.rb +9 -2
  140. data/lib/datadog/core/environment/thread_count.rb +1 -0
  141. data/lib/datadog/core/environment/variable_helpers.rb +85 -11
  142. data/lib/datadog/core/environment/vm_cache.rb +47 -0
  143. data/lib/datadog/core/error.rb +101 -0
  144. data/lib/datadog/core/extensions.rb +16 -0
  145. data/lib/datadog/core/git/ext.rb +35 -0
  146. data/lib/datadog/core/header_collection.rb +41 -0
  147. data/lib/datadog/core/logger.rb +46 -0
  148. data/lib/datadog/core/logging/ext.rb +11 -0
  149. data/lib/datadog/core/metrics/client.rb +198 -0
  150. data/lib/datadog/core/metrics/ext.rb +20 -0
  151. data/lib/datadog/core/metrics/helpers.rb +25 -0
  152. data/lib/datadog/core/metrics/logging.rb +44 -0
  153. data/lib/datadog/core/metrics/metric.rb +14 -0
  154. data/lib/datadog/core/metrics/options.rb +50 -0
  155. data/lib/datadog/core/pin.rb +75 -0
  156. data/lib/datadog/core/runtime/ext.rb +28 -0
  157. data/lib/datadog/core/runtime/metrics.rb +126 -0
  158. data/lib/datadog/core/telemetry/client.rb +79 -0
  159. data/lib/datadog/core/telemetry/collector.rb +232 -0
  160. data/lib/datadog/core/telemetry/emitter.rb +48 -0
  161. data/lib/datadog/core/telemetry/event.rb +71 -0
  162. data/lib/datadog/core/telemetry/ext.rb +11 -0
  163. data/lib/datadog/core/telemetry/heartbeat.rb +37 -0
  164. data/lib/datadog/core/telemetry/http/adapters/net.rb +113 -0
  165. data/lib/datadog/core/telemetry/http/env.rb +20 -0
  166. data/lib/datadog/core/telemetry/http/ext.rb +20 -0
  167. data/lib/datadog/core/telemetry/http/response.rb +68 -0
  168. data/lib/datadog/core/telemetry/http/transport.rb +53 -0
  169. data/lib/datadog/core/telemetry/v1/app_event.rb +52 -0
  170. data/lib/datadog/core/telemetry/v1/application.rb +86 -0
  171. data/lib/datadog/core/telemetry/v1/configuration.rb +25 -0
  172. data/lib/datadog/core/telemetry/v1/dependency.rb +36 -0
  173. data/lib/datadog/core/telemetry/v1/host.rb +51 -0
  174. data/lib/datadog/core/telemetry/v1/integration.rb +58 -0
  175. data/lib/datadog/core/telemetry/v1/product.rb +28 -0
  176. data/lib/datadog/core/telemetry/v1/telemetry_request.rb +100 -0
  177. data/lib/datadog/core/utils/compression.rb +36 -0
  178. data/lib/datadog/core/utils/forking.rb +63 -0
  179. data/lib/datadog/core/utils/object_set.rb +43 -0
  180. data/lib/datadog/core/utils/only_once.rb +44 -0
  181. data/lib/datadog/core/utils/safe_dup.rb +27 -0
  182. data/lib/datadog/core/utils/sequence.rb +26 -0
  183. data/lib/datadog/core/utils/string_table.rb +49 -0
  184. data/lib/datadog/core/utils/time.rb +54 -0
  185. data/lib/datadog/core/utils.rb +94 -0
  186. data/lib/datadog/core/vendor/multipart-post/multipart/post/composite_read_io.rb +120 -0
  187. data/lib/datadog/core/vendor/multipart-post/multipart/post/multipartable.rb +61 -0
  188. data/lib/datadog/core/vendor/multipart-post/multipart/post/parts.rb +139 -0
  189. data/lib/datadog/core/vendor/multipart-post/multipart/post/version.rb +13 -0
  190. data/lib/datadog/core/vendor/multipart-post/multipart/post.rb +12 -0
  191. data/lib/datadog/core/vendor/multipart-post/multipart.rb +16 -0
  192. data/lib/datadog/core/vendor/multipart-post/net/http/post/multipart.rb +36 -0
  193. data/lib/datadog/core/worker.rb +24 -0
  194. data/lib/datadog/core/workers/async.rb +180 -0
  195. data/lib/datadog/core/workers/interval_loop.rb +119 -0
  196. data/lib/datadog/core/workers/polling.rb +59 -0
  197. data/lib/datadog/core/workers/queue.rb +44 -0
  198. data/lib/datadog/core/workers/runtime_metrics.rb +62 -0
  199. data/lib/datadog/core.rb +46 -0
  200. data/lib/datadog/kit/enable_core_dumps.rb +50 -0
  201. data/lib/datadog/kit/identity.rb +63 -0
  202. data/lib/datadog/kit.rb +11 -0
  203. data/lib/datadog/opentracer/binary_propagator.rb +26 -0
  204. data/lib/datadog/opentracer/carrier.rb +9 -0
  205. data/lib/datadog/opentracer/distributed_headers.rb +56 -0
  206. data/lib/datadog/opentracer/global_tracer.rb +17 -0
  207. data/lib/datadog/opentracer/propagator.rb +26 -0
  208. data/lib/datadog/opentracer/rack_propagator.rb +73 -0
  209. data/lib/datadog/opentracer/scope.rb +18 -0
  210. data/lib/datadog/opentracer/scope_manager.rb +9 -0
  211. data/lib/datadog/opentracer/span.rb +101 -0
  212. data/lib/datadog/opentracer/span_context.rb +19 -0
  213. data/lib/datadog/opentracer/span_context_factory.rb +27 -0
  214. data/lib/datadog/opentracer/text_map_propagator.rb +88 -0
  215. data/lib/datadog/opentracer/thread_local_scope.rb +34 -0
  216. data/lib/datadog/opentracer/thread_local_scope_manager.rb +66 -0
  217. data/lib/datadog/opentracer/tracer.rb +214 -0
  218. data/lib/datadog/opentracer.rb +24 -0
  219. data/lib/datadog/profiling/backtrace_location.rb +34 -0
  220. data/lib/datadog/profiling/buffer.rb +43 -0
  221. data/lib/datadog/profiling/collectors/code_provenance.rb +115 -0
  222. data/lib/datadog/profiling/collectors/cpu_and_wall_time.rb +43 -0
  223. data/lib/datadog/profiling/collectors/cpu_and_wall_time_worker.rb +91 -0
  224. data/lib/datadog/profiling/collectors/dynamic_sampling_rate.rb +14 -0
  225. data/lib/datadog/profiling/collectors/idle_sampling_helper.rb +68 -0
  226. data/lib/datadog/profiling/collectors/old_stack.rb +305 -0
  227. data/lib/datadog/profiling/collectors/stack.rb +13 -0
  228. data/lib/datadog/profiling/encoding/profile.rb +43 -0
  229. data/lib/datadog/profiling/event.rb +15 -0
  230. data/lib/datadog/profiling/events/stack.rb +82 -0
  231. data/lib/datadog/profiling/exporter.rb +85 -0
  232. data/lib/datadog/profiling/ext/forking.rb +98 -0
  233. data/lib/datadog/profiling/ext.rb +45 -0
  234. data/lib/datadog/profiling/flush.rb +38 -0
  235. data/lib/datadog/profiling/http_transport.rb +132 -0
  236. data/lib/datadog/profiling/load_native_extension.rb +22 -0
  237. data/lib/datadog/profiling/native_extension.rb +41 -0
  238. data/lib/datadog/profiling/old_recorder.rb +109 -0
  239. data/lib/datadog/profiling/pprof/builder.rb +127 -0
  240. data/lib/datadog/profiling/pprof/converter.rb +104 -0
  241. data/lib/datadog/profiling/pprof/message_set.rb +16 -0
  242. data/lib/datadog/profiling/pprof/payload.rb +20 -0
  243. data/lib/datadog/profiling/pprof/pprof_pb.rb +83 -0
  244. data/lib/datadog/profiling/pprof/stack_sample.rb +141 -0
  245. data/lib/datadog/profiling/pprof/string_table.rb +12 -0
  246. data/lib/datadog/profiling/pprof/template.rb +120 -0
  247. data/lib/datadog/profiling/preload.rb +5 -0
  248. data/lib/datadog/profiling/profiler.rb +41 -0
  249. data/lib/datadog/profiling/scheduler.rb +130 -0
  250. data/lib/datadog/profiling/stack_recorder.rb +79 -0
  251. data/lib/datadog/profiling/tag_builder.rb +53 -0
  252. data/lib/datadog/profiling/tasks/exec.rb +50 -0
  253. data/lib/datadog/profiling/tasks/help.rb +18 -0
  254. data/lib/datadog/profiling/tasks/setup.rb +86 -0
  255. data/lib/datadog/profiling/trace_identifiers/ddtrace.rb +45 -0
  256. data/lib/datadog/profiling/trace_identifiers/helper.rb +47 -0
  257. data/lib/datadog/profiling.rb +173 -0
  258. data/lib/datadog/tracing/analytics.rb +25 -0
  259. data/lib/datadog/tracing/buffer.rb +132 -0
  260. data/lib/datadog/tracing/client_ip.rb +164 -0
  261. data/lib/datadog/tracing/configuration/ext.rb +95 -0
  262. data/lib/datadog/tracing/configuration/settings.rb +433 -0
  263. data/lib/datadog/tracing/context.rb +68 -0
  264. data/lib/datadog/tracing/context_provider.rb +82 -0
  265. data/lib/datadog/tracing/contrib/action_cable/configuration/settings.rb +35 -0
  266. data/lib/datadog/tracing/contrib/action_cable/event.rb +71 -0
  267. data/lib/datadog/tracing/contrib/action_cable/events/broadcast.rb +58 -0
  268. data/lib/datadog/tracing/contrib/action_cable/events/perform_action.rb +63 -0
  269. data/lib/datadog/tracing/contrib/action_cable/events/transmit.rb +59 -0
  270. data/lib/datadog/tracing/contrib/action_cable/events.rb +37 -0
  271. data/lib/datadog/tracing/contrib/action_cable/ext.rb +32 -0
  272. data/lib/datadog/tracing/contrib/action_cable/instrumentation.rb +90 -0
  273. data/lib/datadog/tracing/contrib/action_cable/integration.rb +50 -0
  274. data/lib/datadog/tracing/contrib/action_cable/patcher.rb +31 -0
  275. data/lib/datadog/tracing/contrib/action_mailer/configuration/settings.rb +36 -0
  276. data/lib/datadog/tracing/contrib/action_mailer/event.rb +52 -0
  277. data/lib/datadog/tracing/contrib/action_mailer/events/deliver.rb +60 -0
  278. data/lib/datadog/tracing/contrib/action_mailer/events/process.rb +47 -0
  279. data/lib/datadog/tracing/contrib/action_mailer/events.rb +34 -0
  280. data/lib/datadog/tracing/contrib/action_mailer/ext.rb +33 -0
  281. data/lib/datadog/tracing/contrib/action_mailer/integration.rb +50 -0
  282. data/lib/datadog/tracing/contrib/action_mailer/patcher.rb +29 -0
  283. data/lib/datadog/tracing/contrib/action_pack/action_controller/instrumentation.rb +160 -0
  284. data/lib/datadog/tracing/contrib/action_pack/action_controller/patcher.rb +29 -0
  285. data/lib/datadog/tracing/contrib/action_pack/configuration/settings.rb +36 -0
  286. data/lib/datadog/tracing/contrib/action_pack/ext.rb +22 -0
  287. data/lib/datadog/tracing/contrib/action_pack/integration.rb +50 -0
  288. data/lib/datadog/tracing/contrib/action_pack/patcher.rb +27 -0
  289. data/lib/datadog/tracing/contrib/action_pack/utils.rb +40 -0
  290. data/lib/datadog/tracing/contrib/action_view/configuration/settings.rb +36 -0
  291. data/lib/datadog/tracing/contrib/action_view/event.rb +35 -0
  292. data/lib/datadog/tracing/contrib/action_view/events/render_partial.rb +54 -0
  293. data/lib/datadog/tracing/contrib/action_view/events/render_template.rb +57 -0
  294. data/lib/datadog/tracing/contrib/action_view/events.rb +34 -0
  295. data/lib/datadog/tracing/contrib/action_view/ext.rb +24 -0
  296. data/lib/datadog/tracing/contrib/action_view/instrumentation/partial_renderer.rb +78 -0
  297. data/lib/datadog/tracing/contrib/action_view/instrumentation/template_renderer.rb +91 -0
  298. data/lib/datadog/tracing/contrib/action_view/integration.rb +57 -0
  299. data/lib/datadog/tracing/contrib/action_view/patcher.rb +47 -0
  300. data/lib/datadog/tracing/contrib/action_view/utils.rb +36 -0
  301. data/lib/datadog/tracing/contrib/active_job/configuration/settings.rb +37 -0
  302. data/lib/datadog/tracing/contrib/active_job/event.rb +58 -0
  303. data/lib/datadog/tracing/contrib/active_job/events/discard.rb +50 -0
  304. data/lib/datadog/tracing/contrib/active_job/events/enqueue.rb +49 -0
  305. data/lib/datadog/tracing/contrib/active_job/events/enqueue_at.rb +49 -0
  306. data/lib/datadog/tracing/contrib/active_job/events/enqueue_retry.rb +51 -0
  307. data/lib/datadog/tracing/contrib/active_job/events/perform.rb +49 -0
  308. data/lib/datadog/tracing/contrib/active_job/events/retry_stopped.rb +50 -0
  309. data/lib/datadog/tracing/contrib/active_job/events.rb +42 -0
  310. data/lib/datadog/tracing/contrib/active_job/ext.rb +39 -0
  311. data/lib/datadog/tracing/contrib/active_job/integration.rb +50 -0
  312. data/lib/datadog/tracing/contrib/active_job/log_injection.rb +24 -0
  313. data/lib/datadog/tracing/contrib/active_job/patcher.rb +36 -0
  314. data/lib/datadog/tracing/contrib/active_model_serializers/configuration/settings.rb +33 -0
  315. data/lib/datadog/tracing/contrib/active_model_serializers/event.rb +68 -0
  316. data/lib/datadog/tracing/contrib/active_model_serializers/events/render.rb +45 -0
  317. data/lib/datadog/tracing/contrib/active_model_serializers/events/serialize.rb +47 -0
  318. data/lib/datadog/tracing/contrib/active_model_serializers/events.rb +34 -0
  319. data/lib/datadog/tracing/contrib/active_model_serializers/ext.rb +24 -0
  320. data/lib/datadog/tracing/contrib/active_model_serializers/integration.rb +45 -0
  321. data/lib/datadog/tracing/contrib/active_model_serializers/patcher.rb +32 -0
  322. data/lib/datadog/tracing/contrib/active_record/configuration/makara_resolver.rb +36 -0
  323. data/lib/datadog/tracing/contrib/active_record/configuration/resolver.rb +138 -0
  324. data/lib/datadog/tracing/contrib/active_record/configuration/settings.rb +39 -0
  325. data/lib/datadog/tracing/contrib/active_record/event.rb +30 -0
  326. data/lib/datadog/tracing/contrib/active_record/events/instantiation.rb +58 -0
  327. data/lib/datadog/tracing/contrib/active_record/events/sql.rb +78 -0
  328. data/lib/datadog/tracing/contrib/active_record/events.rb +34 -0
  329. data/lib/datadog/tracing/contrib/active_record/ext.rb +29 -0
  330. data/lib/datadog/tracing/contrib/active_record/integration.rb +56 -0
  331. data/lib/datadog/tracing/contrib/active_record/patcher.rb +27 -0
  332. data/lib/datadog/tracing/contrib/active_record/utils.rb +128 -0
  333. data/lib/datadog/tracing/contrib/active_record/vendor/connection_specification.rb +307 -0
  334. data/lib/datadog/tracing/contrib/active_support/cache/instrumentation.rb +280 -0
  335. data/lib/datadog/tracing/contrib/active_support/cache/patcher.rb +73 -0
  336. data/lib/datadog/tracing/contrib/active_support/cache/redis.rb +47 -0
  337. data/lib/datadog/tracing/contrib/active_support/configuration/settings.rb +35 -0
  338. data/lib/datadog/tracing/contrib/active_support/ext.rb +31 -0
  339. data/lib/datadog/tracing/contrib/active_support/integration.rb +51 -0
  340. data/lib/datadog/tracing/contrib/active_support/notifications/event.rb +71 -0
  341. data/lib/datadog/tracing/contrib/active_support/notifications/subscriber.rb +71 -0
  342. data/lib/datadog/tracing/contrib/active_support/notifications/subscription.rb +164 -0
  343. data/lib/datadog/tracing/contrib/active_support/patcher.rb +27 -0
  344. data/lib/datadog/tracing/contrib/analytics.rb +29 -0
  345. data/lib/datadog/tracing/contrib/auto_instrument.rb +53 -0
  346. data/lib/datadog/tracing/contrib/aws/configuration/settings.rb +38 -0
  347. data/lib/datadog/tracing/contrib/aws/ext.rb +28 -0
  348. data/lib/datadog/tracing/contrib/aws/instrumentation.rb +96 -0
  349. data/lib/datadog/tracing/contrib/aws/integration.rb +47 -0
  350. data/lib/datadog/tracing/contrib/aws/parsed_context.rb +60 -0
  351. data/lib/datadog/tracing/contrib/aws/patcher.rb +57 -0
  352. data/lib/datadog/tracing/contrib/aws/services.rb +121 -0
  353. data/lib/datadog/tracing/contrib/concurrent_ruby/configuration/settings.rb +23 -0
  354. data/lib/datadog/tracing/contrib/concurrent_ruby/context_composite_executor_service.rb +53 -0
  355. data/lib/datadog/tracing/contrib/concurrent_ruby/ext.rb +16 -0
  356. data/lib/datadog/tracing/contrib/concurrent_ruby/future_patch.rb +27 -0
  357. data/lib/datadog/tracing/contrib/concurrent_ruby/integration.rb +43 -0
  358. data/lib/datadog/tracing/contrib/concurrent_ruby/patcher.rb +33 -0
  359. data/lib/datadog/tracing/contrib/configurable.rb +102 -0
  360. data/lib/datadog/tracing/contrib/configuration/resolver.rb +85 -0
  361. data/lib/datadog/tracing/contrib/configuration/resolvers/pattern_resolver.rb +43 -0
  362. data/lib/datadog/tracing/contrib/configuration/settings.rb +43 -0
  363. data/lib/datadog/tracing/contrib/dalli/configuration/settings.rb +38 -0
  364. data/lib/datadog/tracing/contrib/dalli/ext.rb +26 -0
  365. data/lib/datadog/tracing/contrib/dalli/instrumentation.rb +61 -0
  366. data/lib/datadog/tracing/contrib/dalli/integration.rb +52 -0
  367. data/lib/datadog/tracing/contrib/dalli/patcher.rb +28 -0
  368. data/lib/datadog/tracing/contrib/dalli/quantize.rb +26 -0
  369. data/lib/datadog/tracing/contrib/delayed_job/configuration/settings.rb +38 -0
  370. data/lib/datadog/tracing/contrib/delayed_job/ext.rb +28 -0
  371. data/lib/datadog/tracing/contrib/delayed_job/integration.rb +43 -0
  372. data/lib/datadog/tracing/contrib/delayed_job/patcher.rb +37 -0
  373. data/lib/datadog/tracing/contrib/delayed_job/plugin.rb +104 -0
  374. data/lib/datadog/tracing/contrib/delayed_job/server_internal_tracer/worker.rb +32 -0
  375. data/lib/datadog/tracing/contrib/elasticsearch/configuration/settings.rb +40 -0
  376. data/lib/datadog/tracing/contrib/elasticsearch/ext.rb +29 -0
  377. data/lib/datadog/tracing/contrib/elasticsearch/integration.rb +50 -0
  378. data/lib/datadog/tracing/contrib/elasticsearch/patcher.rb +153 -0
  379. data/lib/datadog/tracing/contrib/elasticsearch/quantize.rb +89 -0
  380. data/lib/datadog/tracing/contrib/ethon/configuration/settings.rb +42 -0
  381. data/lib/datadog/tracing/contrib/ethon/easy_patch.rb +176 -0
  382. data/lib/datadog/tracing/contrib/ethon/ext.rb +25 -0
  383. data/lib/datadog/tracing/contrib/ethon/integration.rb +48 -0
  384. data/lib/datadog/tracing/contrib/ethon/multi_patch.rb +97 -0
  385. data/lib/datadog/tracing/contrib/ethon/patcher.rb +31 -0
  386. data/lib/datadog/tracing/contrib/excon/configuration/settings.rb +42 -0
  387. data/lib/datadog/tracing/contrib/excon/ext.rb +22 -0
  388. data/lib/datadog/tracing/contrib/excon/integration.rb +48 -0
  389. data/lib/datadog/tracing/contrib/excon/middleware.rb +171 -0
  390. data/lib/datadog/tracing/contrib/excon/patcher.rb +31 -0
  391. data/lib/datadog/tracing/contrib/ext.rb +25 -0
  392. data/lib/datadog/tracing/contrib/extensions.rb +199 -0
  393. data/lib/datadog/tracing/contrib/faraday/configuration/settings.rb +46 -0
  394. data/lib/datadog/tracing/contrib/faraday/connection.rb +22 -0
  395. data/lib/datadog/tracing/contrib/faraday/ext.rb +22 -0
  396. data/lib/datadog/tracing/contrib/faraday/integration.rb +48 -0
  397. data/lib/datadog/tracing/contrib/faraday/middleware.rb +93 -0
  398. data/lib/datadog/tracing/contrib/faraday/patcher.rb +56 -0
  399. data/lib/datadog/tracing/contrib/faraday/rack_builder.rb +22 -0
  400. data/lib/datadog/tracing/contrib/grape/configuration/settings.rb +42 -0
  401. data/lib/datadog/tracing/contrib/grape/endpoint.rb +250 -0
  402. data/lib/datadog/tracing/contrib/grape/ext.rb +28 -0
  403. data/lib/datadog/tracing/contrib/grape/instrumentation.rb +37 -0
  404. data/lib/datadog/tracing/contrib/grape/integration.rb +44 -0
  405. data/lib/datadog/tracing/contrib/grape/patcher.rb +33 -0
  406. data/lib/datadog/tracing/contrib/graphql/configuration/settings.rb +36 -0
  407. data/lib/datadog/tracing/contrib/graphql/ext.rb +19 -0
  408. data/lib/datadog/tracing/contrib/graphql/integration.rb +44 -0
  409. data/lib/datadog/tracing/contrib/graphql/patcher.rb +90 -0
  410. data/lib/datadog/tracing/contrib/grpc/configuration/settings.rb +43 -0
  411. data/lib/datadog/tracing/contrib/grpc/datadog_interceptor/client.rb +99 -0
  412. data/lib/datadog/tracing/contrib/grpc/datadog_interceptor/server.rb +90 -0
  413. data/lib/datadog/tracing/contrib/grpc/datadog_interceptor.rb +107 -0
  414. data/lib/datadog/tracing/contrib/grpc/distributed/fetcher.rb +27 -0
  415. data/lib/datadog/tracing/contrib/grpc/distributed/propagation.rb +43 -0
  416. data/lib/datadog/tracing/contrib/grpc/ext.rb +27 -0
  417. data/lib/datadog/tracing/contrib/grpc/integration.rb +43 -0
  418. data/lib/datadog/tracing/contrib/grpc/intercept_with_datadog.rb +53 -0
  419. data/lib/datadog/tracing/contrib/grpc/patcher.rb +35 -0
  420. data/lib/datadog/tracing/contrib/hanami/action_tracer.rb +47 -0
  421. data/lib/datadog/tracing/contrib/hanami/configuration/settings.rb +22 -0
  422. data/lib/datadog/tracing/contrib/hanami/ext.rb +24 -0
  423. data/lib/datadog/tracing/contrib/hanami/integration.rb +44 -0
  424. data/lib/datadog/tracing/contrib/hanami/patcher.rb +33 -0
  425. data/lib/datadog/tracing/contrib/hanami/plugin.rb +23 -0
  426. data/lib/datadog/tracing/contrib/hanami/renderer_policy_tracing.rb +41 -0
  427. data/lib/datadog/tracing/contrib/hanami/router_tracing.rb +44 -0
  428. data/lib/datadog/tracing/contrib/http/circuit_breaker.rb +43 -0
  429. data/lib/datadog/tracing/contrib/http/configuration/settings.rb +42 -0
  430. data/lib/datadog/tracing/contrib/http/distributed/fetcher.rb +32 -0
  431. data/lib/datadog/tracing/contrib/http/distributed/propagation.rb +38 -0
  432. data/lib/datadog/tracing/contrib/http/ext.rb +22 -0
  433. data/lib/datadog/tracing/contrib/http/instrumentation.rb +140 -0
  434. data/lib/datadog/tracing/contrib/http/integration.rb +49 -0
  435. data/lib/datadog/tracing/contrib/http/patcher.rb +30 -0
  436. data/lib/datadog/tracing/contrib/http_annotation_helper.rb +17 -0
  437. data/lib/datadog/tracing/contrib/httpclient/configuration/settings.rb +42 -0
  438. data/lib/datadog/tracing/contrib/httpclient/ext.rb +22 -0
  439. data/lib/datadog/tracing/contrib/httpclient/instrumentation.rb +118 -0
  440. data/lib/datadog/tracing/contrib/httpclient/integration.rb +48 -0
  441. data/lib/datadog/tracing/contrib/httpclient/patcher.rb +42 -0
  442. data/lib/datadog/tracing/contrib/httprb/configuration/settings.rb +42 -0
  443. data/lib/datadog/tracing/contrib/httprb/ext.rb +22 -0
  444. data/lib/datadog/tracing/contrib/httprb/instrumentation.rb +129 -0
  445. data/lib/datadog/tracing/contrib/httprb/integration.rb +48 -0
  446. data/lib/datadog/tracing/contrib/httprb/patcher.rb +42 -0
  447. data/lib/datadog/tracing/contrib/integration.rb +78 -0
  448. data/lib/datadog/tracing/contrib/kafka/configuration/settings.rb +35 -0
  449. data/lib/datadog/tracing/contrib/kafka/consumer_event.rb +19 -0
  450. data/lib/datadog/tracing/contrib/kafka/consumer_group_event.rb +18 -0
  451. data/lib/datadog/tracing/contrib/kafka/event.rb +52 -0
  452. data/lib/datadog/tracing/contrib/kafka/events/connection/request.rb +42 -0
  453. data/lib/datadog/tracing/contrib/kafka/events/consumer/process_batch.rb +49 -0
  454. data/lib/datadog/tracing/contrib/kafka/events/consumer/process_message.rb +47 -0
  455. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/heartbeat.rb +47 -0
  456. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/join_group.rb +37 -0
  457. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/leave_group.rb +37 -0
  458. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/sync_group.rb +37 -0
  459. data/lib/datadog/tracing/contrib/kafka/events/produce_operation/send_messages.rb +41 -0
  460. data/lib/datadog/tracing/contrib/kafka/events/producer/deliver_messages.rb +44 -0
  461. data/lib/datadog/tracing/contrib/kafka/events.rb +48 -0
  462. data/lib/datadog/tracing/contrib/kafka/ext.rb +52 -0
  463. data/lib/datadog/tracing/contrib/kafka/integration.rb +44 -0
  464. data/lib/datadog/tracing/contrib/kafka/patcher.rb +29 -0
  465. data/lib/datadog/tracing/contrib/lograge/configuration/settings.rb +23 -0
  466. data/lib/datadog/tracing/contrib/lograge/ext.rb +15 -0
  467. data/lib/datadog/tracing/contrib/lograge/instrumentation.rb +46 -0
  468. data/lib/datadog/tracing/contrib/lograge/integration.rb +50 -0
  469. data/lib/datadog/tracing/contrib/lograge/patcher.rb +29 -0
  470. data/lib/datadog/tracing/contrib/mongodb/configuration/settings.rb +42 -0
  471. data/lib/datadog/tracing/contrib/mongodb/ext.rb +35 -0
  472. data/lib/datadog/tracing/contrib/mongodb/instrumentation.rb +47 -0
  473. data/lib/datadog/tracing/contrib/mongodb/integration.rb +48 -0
  474. data/lib/datadog/tracing/contrib/mongodb/parsers.rb +49 -0
  475. data/lib/datadog/tracing/contrib/mongodb/patcher.rb +34 -0
  476. data/lib/datadog/tracing/contrib/mongodb/subscribers.rb +127 -0
  477. data/lib/datadog/tracing/contrib/mysql2/configuration/settings.rb +50 -0
  478. data/lib/datadog/tracing/contrib/mysql2/ext.rb +24 -0
  479. data/lib/datadog/tracing/contrib/mysql2/instrumentation.rb +77 -0
  480. data/lib/datadog/tracing/contrib/mysql2/integration.rb +43 -0
  481. data/lib/datadog/tracing/contrib/mysql2/patcher.rb +31 -0
  482. data/lib/datadog/tracing/contrib/patchable.rb +109 -0
  483. data/lib/datadog/tracing/contrib/patcher.rb +86 -0
  484. data/lib/datadog/tracing/contrib/pg/configuration/settings.rb +50 -0
  485. data/lib/datadog/tracing/contrib/pg/ext.rb +33 -0
  486. data/lib/datadog/tracing/contrib/pg/instrumentation.rb +155 -0
  487. data/lib/datadog/tracing/contrib/pg/integration.rb +43 -0
  488. data/lib/datadog/tracing/contrib/pg/patcher.rb +31 -0
  489. data/lib/datadog/tracing/contrib/presto/configuration/settings.rb +38 -0
  490. data/lib/datadog/tracing/contrib/presto/ext.rb +33 -0
  491. data/lib/datadog/tracing/contrib/presto/instrumentation.rb +124 -0
  492. data/lib/datadog/tracing/contrib/presto/integration.rb +43 -0
  493. data/lib/datadog/tracing/contrib/presto/patcher.rb +37 -0
  494. data/lib/datadog/tracing/contrib/propagation/sql_comment/comment.rb +43 -0
  495. data/lib/datadog/tracing/contrib/propagation/sql_comment/ext.rb +33 -0
  496. data/lib/datadog/tracing/contrib/propagation/sql_comment/mode.rb +28 -0
  497. data/lib/datadog/tracing/contrib/propagation/sql_comment.rb +47 -0
  498. data/lib/datadog/tracing/contrib/qless/configuration/settings.rb +40 -0
  499. data/lib/datadog/tracing/contrib/qless/ext.rb +26 -0
  500. data/lib/datadog/tracing/contrib/qless/integration.rb +43 -0
  501. data/lib/datadog/tracing/contrib/qless/patcher.rb +37 -0
  502. data/lib/datadog/tracing/contrib/qless/qless_job.rb +74 -0
  503. data/lib/datadog/tracing/contrib/qless/tracer_cleaner.rb +30 -0
  504. data/lib/datadog/tracing/contrib/que/configuration/settings.rb +49 -0
  505. data/lib/datadog/tracing/contrib/que/ext.rb +34 -0
  506. data/lib/datadog/tracing/contrib/que/integration.rb +46 -0
  507. data/lib/datadog/tracing/contrib/que/patcher.rb +28 -0
  508. data/lib/datadog/tracing/contrib/que/tracer.rb +63 -0
  509. data/lib/datadog/tracing/contrib/racecar/configuration/settings.rb +35 -0
  510. data/lib/datadog/tracing/contrib/racecar/event.rb +78 -0
  511. data/lib/datadog/tracing/contrib/racecar/events/batch.rb +38 -0
  512. data/lib/datadog/tracing/contrib/racecar/events/consume.rb +35 -0
  513. data/lib/datadog/tracing/contrib/racecar/events/message.rb +38 -0
  514. data/lib/datadog/tracing/contrib/racecar/events.rb +36 -0
  515. data/lib/datadog/tracing/contrib/racecar/ext.rb +31 -0
  516. data/lib/datadog/tracing/contrib/racecar/integration.rb +44 -0
  517. data/lib/datadog/tracing/contrib/racecar/patcher.rb +29 -0
  518. data/lib/datadog/tracing/contrib/rack/configuration/settings.rb +51 -0
  519. data/lib/datadog/tracing/contrib/rack/ext.rb +25 -0
  520. data/lib/datadog/tracing/contrib/rack/header_collection.rb +35 -0
  521. data/lib/datadog/tracing/contrib/rack/integration.rb +50 -0
  522. data/lib/datadog/tracing/contrib/rack/middlewares.rb +323 -0
  523. data/lib/datadog/tracing/contrib/rack/patcher.rb +119 -0
  524. data/lib/datadog/tracing/contrib/rack/request_queue.rb +48 -0
  525. data/lib/datadog/tracing/contrib/rails/auto_instrument_railtie.rb +12 -0
  526. data/lib/datadog/tracing/contrib/rails/configuration/settings.rb +74 -0
  527. data/lib/datadog/tracing/contrib/rails/ext.rb +19 -0
  528. data/lib/datadog/tracing/contrib/rails/framework.rb +148 -0
  529. data/lib/datadog/tracing/contrib/rails/integration.rb +49 -0
  530. data/lib/datadog/tracing/contrib/rails/log_injection.rb +32 -0
  531. data/lib/datadog/tracing/contrib/rails/middlewares.rb +46 -0
  532. data/lib/datadog/tracing/contrib/rails/patcher.rb +120 -0
  533. data/lib/datadog/tracing/contrib/rails/railtie.rb +19 -0
  534. data/lib/datadog/tracing/contrib/rails/utils.rb +28 -0
  535. data/lib/datadog/tracing/contrib/rake/configuration/settings.rb +51 -0
  536. data/lib/datadog/tracing/contrib/rake/ext.rb +26 -0
  537. data/lib/datadog/tracing/contrib/rake/instrumentation.rb +103 -0
  538. data/lib/datadog/tracing/contrib/rake/integration.rb +43 -0
  539. data/lib/datadog/tracing/contrib/rake/patcher.rb +33 -0
  540. data/lib/datadog/tracing/contrib/redis/configuration/resolver.rb +49 -0
  541. data/lib/datadog/tracing/contrib/redis/configuration/settings.rb +43 -0
  542. data/lib/datadog/tracing/contrib/redis/ext.rb +29 -0
  543. data/lib/datadog/tracing/contrib/redis/instrumentation.rb +88 -0
  544. data/lib/datadog/tracing/contrib/redis/integration.rb +80 -0
  545. data/lib/datadog/tracing/contrib/redis/patcher.rb +79 -0
  546. data/lib/datadog/tracing/contrib/redis/quantize.rb +82 -0
  547. data/lib/datadog/tracing/contrib/redis/tags.rb +56 -0
  548. data/lib/datadog/tracing/contrib/redis/trace_middleware.rb +72 -0
  549. data/lib/datadog/tracing/contrib/redis/vendor/resolver.rb +162 -0
  550. data/lib/datadog/tracing/contrib/registerable.rb +50 -0
  551. data/lib/datadog/tracing/contrib/registry.rb +52 -0
  552. data/lib/datadog/tracing/contrib/resque/configuration/settings.rb +37 -0
  553. data/lib/datadog/tracing/contrib/resque/ext.rb +21 -0
  554. data/lib/datadog/tracing/contrib/resque/integration.rb +48 -0
  555. data/lib/datadog/tracing/contrib/resque/patcher.rb +29 -0
  556. data/lib/datadog/tracing/contrib/resque/resque_job.rb +104 -0
  557. data/lib/datadog/tracing/contrib/rest_client/configuration/settings.rb +42 -0
  558. data/lib/datadog/tracing/contrib/rest_client/ext.rb +22 -0
  559. data/lib/datadog/tracing/contrib/rest_client/integration.rb +43 -0
  560. data/lib/datadog/tracing/contrib/rest_client/patcher.rb +29 -0
  561. data/lib/datadog/tracing/contrib/rest_client/request_patch.rb +106 -0
  562. data/lib/datadog/tracing/contrib/semantic_logger/configuration/settings.rb +23 -0
  563. data/lib/datadog/tracing/contrib/semantic_logger/ext.rb +15 -0
  564. data/lib/datadog/tracing/contrib/semantic_logger/instrumentation.rb +50 -0
  565. data/lib/datadog/tracing/contrib/semantic_logger/integration.rb +52 -0
  566. data/lib/datadog/tracing/contrib/semantic_logger/patcher.rb +29 -0
  567. data/lib/datadog/tracing/contrib/sequel/configuration/settings.rb +33 -0
  568. data/lib/datadog/tracing/contrib/sequel/database.rb +59 -0
  569. data/lib/datadog/tracing/contrib/sequel/dataset.rb +64 -0
  570. data/lib/datadog/tracing/contrib/sequel/ext.rb +22 -0
  571. data/lib/datadog/tracing/contrib/sequel/integration.rb +43 -0
  572. data/lib/datadog/tracing/contrib/sequel/patcher.rb +37 -0
  573. data/lib/datadog/tracing/contrib/sequel/utils.rb +87 -0
  574. data/lib/datadog/tracing/contrib/shoryuken/configuration/settings.rb +38 -0
  575. data/lib/datadog/tracing/contrib/shoryuken/ext.rb +25 -0
  576. data/lib/datadog/tracing/contrib/shoryuken/integration.rb +44 -0
  577. data/lib/datadog/tracing/contrib/shoryuken/patcher.rb +28 -0
  578. data/lib/datadog/tracing/contrib/shoryuken/tracer.rb +63 -0
  579. data/lib/datadog/tracing/contrib/sidekiq/client_tracer.rb +57 -0
  580. data/lib/datadog/tracing/contrib/sidekiq/configuration/settings.rb +44 -0
  581. data/lib/datadog/tracing/contrib/sidekiq/ext.rb +44 -0
  582. data/lib/datadog/tracing/contrib/sidekiq/integration.rb +53 -0
  583. data/lib/datadog/tracing/contrib/sidekiq/patcher.rb +78 -0
  584. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/heartbeat.rb +52 -0
  585. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/job_fetch.rb +34 -0
  586. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/redis_info.rb +32 -0
  587. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/scheduled_poller.rb +53 -0
  588. data/lib/datadog/tracing/contrib/sidekiq/server_tracer.rb +102 -0
  589. data/lib/datadog/tracing/contrib/sidekiq/tracing.rb +44 -0
  590. data/lib/datadog/tracing/contrib/sinatra/configuration/settings.rb +43 -0
  591. data/lib/datadog/tracing/contrib/sinatra/env.rb +55 -0
  592. data/lib/datadog/tracing/contrib/sinatra/ext.rb +36 -0
  593. data/lib/datadog/tracing/contrib/sinatra/framework.rb +116 -0
  594. data/lib/datadog/tracing/contrib/sinatra/headers.rb +35 -0
  595. data/lib/datadog/tracing/contrib/sinatra/integration.rb +43 -0
  596. data/lib/datadog/tracing/contrib/sinatra/patcher.rb +76 -0
  597. data/lib/datadog/tracing/contrib/sinatra/tracer.rb +86 -0
  598. data/lib/datadog/tracing/contrib/sinatra/tracer_middleware.rb +127 -0
  599. data/lib/datadog/tracing/contrib/sneakers/configuration/settings.rb +38 -0
  600. data/lib/datadog/tracing/contrib/sneakers/ext.rb +26 -0
  601. data/lib/datadog/tracing/contrib/sneakers/integration.rb +46 -0
  602. data/lib/datadog/tracing/contrib/sneakers/patcher.rb +29 -0
  603. data/lib/datadog/tracing/contrib/sneakers/tracer.rb +59 -0
  604. data/lib/datadog/tracing/contrib/status_code_matcher.rb +75 -0
  605. data/lib/datadog/tracing/contrib/sucker_punch/configuration/settings.rb +35 -0
  606. data/lib/datadog/tracing/contrib/sucker_punch/exception_handler.rb +28 -0
  607. data/lib/datadog/tracing/contrib/sucker_punch/ext.rb +27 -0
  608. data/lib/datadog/tracing/contrib/sucker_punch/instrumentation.rb +104 -0
  609. data/lib/datadog/tracing/contrib/sucker_punch/integration.rb +43 -0
  610. data/lib/datadog/tracing/contrib/sucker_punch/patcher.rb +36 -0
  611. data/lib/datadog/tracing/contrib/utils/database.rb +31 -0
  612. data/lib/datadog/tracing/contrib/utils/quantization/hash.rb +111 -0
  613. data/lib/datadog/tracing/contrib/utils/quantization/http.rb +181 -0
  614. data/lib/datadog/tracing/contrib.rb +78 -0
  615. data/lib/datadog/tracing/correlation.rb +100 -0
  616. data/lib/datadog/tracing/diagnostics/ext.rb +36 -0
  617. data/lib/datadog/tracing/diagnostics/health.rb +40 -0
  618. data/lib/datadog/tracing/distributed/b3_multi.rb +66 -0
  619. data/lib/datadog/tracing/distributed/b3_single.rb +66 -0
  620. data/lib/datadog/tracing/distributed/datadog.rb +153 -0
  621. data/lib/datadog/tracing/distributed/datadog_tags_codec.rb +85 -0
  622. data/lib/datadog/tracing/distributed/fetcher.rb +30 -0
  623. data/lib/datadog/tracing/distributed/headers/ext.rb +35 -0
  624. data/lib/datadog/tracing/distributed/helpers.rb +80 -0
  625. data/lib/datadog/tracing/distributed/none.rb +19 -0
  626. data/lib/datadog/tracing/distributed/propagation.rb +127 -0
  627. data/lib/datadog/tracing/distributed/trace_context.rb +369 -0
  628. data/lib/datadog/tracing/event.rb +78 -0
  629. data/lib/datadog/tracing/flush.rb +96 -0
  630. data/lib/datadog/tracing/metadata/analytics.rb +26 -0
  631. data/lib/datadog/tracing/metadata/errors.rb +24 -0
  632. data/lib/datadog/tracing/metadata/ext.rb +178 -0
  633. data/lib/datadog/tracing/metadata/tagging.rb +125 -0
  634. data/lib/datadog/tracing/metadata.rb +20 -0
  635. data/lib/datadog/tracing/pipeline/span_filter.rb +46 -0
  636. data/lib/datadog/tracing/pipeline/span_processor.rb +39 -0
  637. data/lib/datadog/tracing/pipeline.rb +65 -0
  638. data/lib/datadog/tracing/propagation/http.rb +14 -0
  639. data/lib/datadog/tracing/runtime/metrics.rb +19 -0
  640. data/lib/datadog/tracing/sampling/all_sampler.rb +25 -0
  641. data/lib/datadog/tracing/sampling/ext.rb +58 -0
  642. data/lib/datadog/tracing/sampling/matcher.rb +68 -0
  643. data/lib/datadog/tracing/sampling/priority_sampler.rb +165 -0
  644. data/lib/datadog/tracing/sampling/rate_by_key_sampler.rb +96 -0
  645. data/lib/datadog/tracing/sampling/rate_by_service_sampler.rb +65 -0
  646. data/lib/datadog/tracing/sampling/rate_limiter.rb +188 -0
  647. data/lib/datadog/tracing/sampling/rate_sampler.rb +72 -0
  648. data/lib/datadog/tracing/sampling/rule.rb +76 -0
  649. data/lib/datadog/tracing/sampling/rule_sampler.rb +132 -0
  650. data/lib/datadog/tracing/sampling/sampler.rb +44 -0
  651. data/lib/datadog/tracing/sampling/span/ext.rb +25 -0
  652. data/lib/datadog/tracing/sampling/span/matcher.rb +89 -0
  653. data/lib/datadog/tracing/sampling/span/rule.rb +82 -0
  654. data/lib/datadog/tracing/sampling/span/rule_parser.rb +104 -0
  655. data/lib/datadog/tracing/sampling/span/sampler.rb +75 -0
  656. data/lib/datadog/tracing/span.rb +216 -0
  657. data/lib/datadog/tracing/span_operation.rb +520 -0
  658. data/lib/datadog/tracing/sync_writer.rb +69 -0
  659. data/lib/datadog/tracing/trace_digest.rb +136 -0
  660. data/lib/datadog/tracing/trace_operation.rb +468 -0
  661. data/lib/datadog/tracing/trace_segment.rb +212 -0
  662. data/lib/datadog/tracing/tracer.rb +533 -0
  663. data/lib/datadog/tracing/utils.rb +50 -0
  664. data/lib/datadog/tracing/workers/trace_writer.rb +195 -0
  665. data/lib/datadog/tracing/workers.rb +125 -0
  666. data/lib/datadog/tracing/writer.rb +187 -0
  667. data/lib/datadog/tracing.rb +142 -0
  668. data/lib/ddtrace/auto_instrument.rb +14 -3
  669. data/lib/ddtrace/auto_instrument_base.rb +1 -0
  670. data/lib/ddtrace/profiling/preload.rb +2 -2
  671. data/lib/ddtrace/transport/ext.rb +41 -0
  672. data/lib/ddtrace/transport/http/adapters/net.rb +18 -6
  673. data/lib/ddtrace/transport/http/adapters/registry.rb +1 -0
  674. data/lib/ddtrace/transport/http/adapters/test.rb +6 -3
  675. data/lib/ddtrace/transport/http/adapters/unix_socket.rb +25 -13
  676. data/lib/ddtrace/transport/http/api/endpoint.rb +1 -0
  677. data/lib/ddtrace/transport/http/api/fallbacks.rb +1 -0
  678. data/lib/ddtrace/transport/http/api/instance.rb +1 -0
  679. data/lib/ddtrace/transport/http/api/map.rb +2 -1
  680. data/lib/ddtrace/transport/http/api/spec.rb +1 -0
  681. data/lib/ddtrace/transport/http/api.rb +8 -14
  682. data/lib/ddtrace/transport/http/builder.rb +18 -10
  683. data/lib/ddtrace/transport/http/client.rb +5 -3
  684. data/lib/ddtrace/transport/http/env.rb +1 -0
  685. data/lib/ddtrace/transport/http/response.rb +36 -5
  686. data/lib/ddtrace/transport/http/statistics.rb +2 -1
  687. data/lib/ddtrace/transport/http/traces.rb +6 -3
  688. data/lib/ddtrace/transport/http.rb +40 -38
  689. data/lib/ddtrace/transport/io/client.rb +6 -3
  690. data/lib/ddtrace/transport/io/response.rb +2 -1
  691. data/lib/ddtrace/transport/io/traces.rb +5 -4
  692. data/lib/ddtrace/transport/io.rb +5 -4
  693. data/lib/ddtrace/transport/parcel.rb +2 -0
  694. data/lib/ddtrace/transport/request.rb +1 -0
  695. data/lib/ddtrace/transport/response.rb +1 -0
  696. data/lib/ddtrace/transport/serializable_trace.rb +118 -0
  697. data/lib/ddtrace/transport/statistics.rb +6 -4
  698. data/lib/ddtrace/transport/trace_formatter.rb +191 -0
  699. data/lib/ddtrace/transport/traces.rb +20 -8
  700. data/lib/ddtrace/version.rb +14 -12
  701. data/lib/ddtrace.rb +9 -48
  702. metadata +681 -475
  703. data/.editorconfig +0 -22
  704. data/.gitignore +0 -67
  705. data/.yardopts +0 -5
  706. data/CONTRIBUTING.md +0 -81
  707. data/ddtrace.gemspec +0 -53
  708. data/docs/DevelopmentGuide.md +0 -264
  709. data/docs/GettingStarted.md +0 -2535
  710. data/docs/ProfilingDevelopment.md +0 -107
  711. data/lib/datadog/ci/context_flush.rb +0 -29
  712. data/lib/datadog/contrib.rb +0 -69
  713. data/lib/ddtrace/analytics.rb +0 -39
  714. data/lib/ddtrace/buffer.rb +0 -328
  715. data/lib/ddtrace/chunker.rb +0 -35
  716. data/lib/ddtrace/configuration/agent_settings_resolver.rb +0 -231
  717. data/lib/ddtrace/configuration/base.rb +0 -82
  718. data/lib/ddtrace/configuration/components.rb +0 -292
  719. data/lib/ddtrace/configuration/dependency_resolver.rb +0 -25
  720. data/lib/ddtrace/configuration/option.rb +0 -65
  721. data/lib/ddtrace/configuration/option_definition.rb +0 -122
  722. data/lib/ddtrace/configuration/option_definition_set.rb +0 -19
  723. data/lib/ddtrace/configuration/option_set.rb +0 -7
  724. data/lib/ddtrace/configuration/options.rb +0 -112
  725. data/lib/ddtrace/configuration/pin_setup.rb +0 -32
  726. data/lib/ddtrace/configuration/settings.rb +0 -403
  727. data/lib/ddtrace/configuration.rb +0 -195
  728. data/lib/ddtrace/context.rb +0 -326
  729. data/lib/ddtrace/context_flush.rb +0 -82
  730. data/lib/ddtrace/context_provider.rb +0 -62
  731. data/lib/ddtrace/contrib/action_cable/configuration/settings.rb +0 -31
  732. data/lib/ddtrace/contrib/action_cable/event.rb +0 -67
  733. data/lib/ddtrace/contrib/action_cable/events/broadcast.rb +0 -50
  734. data/lib/ddtrace/contrib/action_cable/events/perform_action.rb +0 -56
  735. data/lib/ddtrace/contrib/action_cable/events/transmit.rb +0 -51
  736. data/lib/ddtrace/contrib/action_cable/events.rb +0 -34
  737. data/lib/ddtrace/contrib/action_cable/ext.rb +0 -27
  738. data/lib/ddtrace/contrib/action_cable/instrumentation.rb +0 -32
  739. data/lib/ddtrace/contrib/action_cable/integration.rb +0 -46
  740. data/lib/ddtrace/contrib/action_cable/patcher.rb +0 -28
  741. data/lib/ddtrace/contrib/action_pack/action_controller/instrumentation.rb +0 -157
  742. data/lib/ddtrace/contrib/action_pack/action_controller/patcher.rb +0 -26
  743. data/lib/ddtrace/contrib/action_pack/configuration/settings.rb +0 -33
  744. data/lib/ddtrace/contrib/action_pack/ext.rb +0 -20
  745. data/lib/ddtrace/contrib/action_pack/integration.rb +0 -46
  746. data/lib/ddtrace/contrib/action_pack/patcher.rb +0 -24
  747. data/lib/ddtrace/contrib/action_pack/utils.rb +0 -37
  748. data/lib/ddtrace/contrib/action_view/configuration/settings.rb +0 -32
  749. data/lib/ddtrace/contrib/action_view/event.rb +0 -36
  750. data/lib/ddtrace/contrib/action_view/events/render_partial.rb +0 -47
  751. data/lib/ddtrace/contrib/action_view/events/render_template.rb +0 -50
  752. data/lib/ddtrace/contrib/action_view/events.rb +0 -31
  753. data/lib/ddtrace/contrib/action_view/ext.rb +0 -21
  754. data/lib/ddtrace/contrib/action_view/instrumentation/partial_renderer.rb +0 -75
  755. data/lib/ddtrace/contrib/action_view/instrumentation/template_renderer.rb +0 -168
  756. data/lib/ddtrace/contrib/action_view/integration.rb +0 -53
  757. data/lib/ddtrace/contrib/action_view/patcher.rb +0 -48
  758. data/lib/ddtrace/contrib/action_view/utils.rb +0 -33
  759. data/lib/ddtrace/contrib/active_model_serializers/configuration/settings.rb +0 -31
  760. data/lib/ddtrace/contrib/active_model_serializers/event.rb +0 -69
  761. data/lib/ddtrace/contrib/active_model_serializers/events/render.rb +0 -33
  762. data/lib/ddtrace/contrib/active_model_serializers/events/serialize.rb +0 -36
  763. data/lib/ddtrace/contrib/active_model_serializers/events.rb +0 -31
  764. data/lib/ddtrace/contrib/active_model_serializers/ext.rb +0 -21
  765. data/lib/ddtrace/contrib/active_model_serializers/integration.rb +0 -41
  766. data/lib/ddtrace/contrib/active_model_serializers/patcher.rb +0 -30
  767. data/lib/ddtrace/contrib/active_record/configuration/makara_resolver.rb +0 -31
  768. data/lib/ddtrace/contrib/active_record/configuration/resolver.rb +0 -135
  769. data/lib/ddtrace/contrib/active_record/configuration/settings.rb +0 -36
  770. data/lib/ddtrace/contrib/active_record/event.rb +0 -31
  771. data/lib/ddtrace/contrib/active_record/events/instantiation.rb +0 -61
  772. data/lib/ddtrace/contrib/active_record/events/sql.rb +0 -69
  773. data/lib/ddtrace/contrib/active_record/events.rb +0 -31
  774. data/lib/ddtrace/contrib/active_record/ext.rb +0 -25
  775. data/lib/ddtrace/contrib/active_record/integration.rb +0 -54
  776. data/lib/ddtrace/contrib/active_record/patcher.rb +0 -24
  777. data/lib/ddtrace/contrib/active_record/utils.rb +0 -124
  778. data/lib/ddtrace/contrib/active_support/cache/instrumentation.rb +0 -259
  779. data/lib/ddtrace/contrib/active_support/cache/patcher.rb +0 -70
  780. data/lib/ddtrace/contrib/active_support/cache/redis.rb +0 -44
  781. data/lib/ddtrace/contrib/active_support/configuration/settings.rb +0 -31
  782. data/lib/ddtrace/contrib/active_support/ext.rb +0 -28
  783. data/lib/ddtrace/contrib/active_support/integration.rb +0 -47
  784. data/lib/ddtrace/contrib/active_support/notifications/event.rb +0 -76
  785. data/lib/ddtrace/contrib/active_support/notifications/subscriber.rb +0 -68
  786. data/lib/ddtrace/contrib/active_support/notifications/subscription.rb +0 -164
  787. data/lib/ddtrace/contrib/active_support/patcher.rb +0 -24
  788. data/lib/ddtrace/contrib/analytics.rb +0 -25
  789. data/lib/ddtrace/contrib/auto_instrument.rb +0 -49
  790. data/lib/ddtrace/contrib/aws/configuration/settings.rb +0 -31
  791. data/lib/ddtrace/contrib/aws/ext.rb +0 -24
  792. data/lib/ddtrace/contrib/aws/instrumentation.rb +0 -91
  793. data/lib/ddtrace/contrib/aws/integration.rb +0 -43
  794. data/lib/ddtrace/contrib/aws/parsed_context.rb +0 -57
  795. data/lib/ddtrace/contrib/aws/patcher.rb +0 -54
  796. data/lib/ddtrace/contrib/aws/services.rb +0 -119
  797. data/lib/ddtrace/contrib/concurrent_ruby/configuration/settings.rb +0 -21
  798. data/lib/ddtrace/contrib/concurrent_ruby/context_composite_executor_service.rb +0 -42
  799. data/lib/ddtrace/contrib/concurrent_ruby/ext.rb +0 -13
  800. data/lib/ddtrace/contrib/concurrent_ruby/future_patch.rb +0 -24
  801. data/lib/ddtrace/contrib/concurrent_ruby/integration.rb +0 -39
  802. data/lib/ddtrace/contrib/concurrent_ruby/patcher.rb +0 -30
  803. data/lib/ddtrace/contrib/configurable.rb +0 -103
  804. data/lib/ddtrace/contrib/configuration/resolver.rb +0 -82
  805. data/lib/ddtrace/contrib/configuration/resolvers/pattern_resolver.rb +0 -40
  806. data/lib/ddtrace/contrib/configuration/settings.rb +0 -56
  807. data/lib/ddtrace/contrib/dalli/configuration/settings.rb +0 -31
  808. data/lib/ddtrace/contrib/dalli/ext.rb +0 -21
  809. data/lib/ddtrace/contrib/dalli/instrumentation.rb +0 -55
  810. data/lib/ddtrace/contrib/dalli/integration.rb +0 -39
  811. data/lib/ddtrace/contrib/dalli/patcher.rb +0 -26
  812. data/lib/ddtrace/contrib/dalli/quantize.rb +0 -23
  813. data/lib/ddtrace/contrib/delayed_job/configuration/settings.rb +0 -33
  814. data/lib/ddtrace/contrib/delayed_job/ext.rb +0 -24
  815. data/lib/ddtrace/contrib/delayed_job/integration.rb +0 -39
  816. data/lib/ddtrace/contrib/delayed_job/patcher.rb +0 -29
  817. data/lib/ddtrace/contrib/delayed_job/plugin.rb +0 -85
  818. data/lib/ddtrace/contrib/elasticsearch/configuration/settings.rb +0 -32
  819. data/lib/ddtrace/contrib/elasticsearch/ext.rb +0 -23
  820. data/lib/ddtrace/contrib/elasticsearch/integration.rb +0 -40
  821. data/lib/ddtrace/contrib/elasticsearch/patcher.rb +0 -123
  822. data/lib/ddtrace/contrib/elasticsearch/quantize.rb +0 -84
  823. data/lib/ddtrace/contrib/ethon/configuration/settings.rb +0 -33
  824. data/lib/ddtrace/contrib/ethon/easy_patch.rb +0 -152
  825. data/lib/ddtrace/contrib/ethon/ext.rb +0 -20
  826. data/lib/ddtrace/contrib/ethon/integration.rb +0 -44
  827. data/lib/ddtrace/contrib/ethon/multi_patch.rb +0 -85
  828. data/lib/ddtrace/contrib/ethon/patcher.rb +0 -27
  829. data/lib/ddtrace/contrib/excon/configuration/settings.rb +0 -34
  830. data/lib/ddtrace/contrib/excon/ext.rb +0 -18
  831. data/lib/ddtrace/contrib/excon/integration.rb +0 -44
  832. data/lib/ddtrace/contrib/excon/middleware.rb +0 -164
  833. data/lib/ddtrace/contrib/excon/patcher.rb +0 -28
  834. data/lib/ddtrace/contrib/extensions.rb +0 -169
  835. data/lib/ddtrace/contrib/faraday/configuration/settings.rb +0 -39
  836. data/lib/ddtrace/contrib/faraday/connection.rb +0 -19
  837. data/lib/ddtrace/contrib/faraday/ext.rb +0 -18
  838. data/lib/ddtrace/contrib/faraday/integration.rb +0 -44
  839. data/lib/ddtrace/contrib/faraday/middleware.rb +0 -86
  840. data/lib/ddtrace/contrib/faraday/patcher.rb +0 -54
  841. data/lib/ddtrace/contrib/faraday/rack_builder.rb +0 -19
  842. data/lib/ddtrace/contrib/grape/configuration/settings.rb +0 -39
  843. data/lib/ddtrace/contrib/grape/endpoint.rb +0 -246
  844. data/lib/ddtrace/contrib/grape/ext.rb +0 -24
  845. data/lib/ddtrace/contrib/grape/instrumentation.rb +0 -34
  846. data/lib/ddtrace/contrib/grape/integration.rb +0 -40
  847. data/lib/ddtrace/contrib/grape/patcher.rb +0 -32
  848. data/lib/ddtrace/contrib/graphql/configuration/settings.rb +0 -33
  849. data/lib/ddtrace/contrib/graphql/ext.rb +0 -17
  850. data/lib/ddtrace/contrib/graphql/integration.rb +0 -40
  851. data/lib/ddtrace/contrib/graphql/patcher.rb +0 -61
  852. data/lib/ddtrace/contrib/grpc/configuration/settings.rb +0 -32
  853. data/lib/ddtrace/contrib/grpc/datadog_interceptor/client.rb +0 -59
  854. data/lib/ddtrace/contrib/grpc/datadog_interceptor/server.rb +0 -80
  855. data/lib/ddtrace/contrib/grpc/datadog_interceptor.rb +0 -79
  856. data/lib/ddtrace/contrib/grpc/ext.rb +0 -19
  857. data/lib/ddtrace/contrib/grpc/integration.rb +0 -39
  858. data/lib/ddtrace/contrib/grpc/intercept_with_datadog.rb +0 -50
  859. data/lib/ddtrace/contrib/grpc/patcher.rb +0 -34
  860. data/lib/ddtrace/contrib/http/circuit_breaker.rb +0 -38
  861. data/lib/ddtrace/contrib/http/configuration/settings.rb +0 -33
  862. data/lib/ddtrace/contrib/http/ext.rb +0 -18
  863. data/lib/ddtrace/contrib/http/instrumentation.rb +0 -180
  864. data/lib/ddtrace/contrib/http/integration.rb +0 -46
  865. data/lib/ddtrace/contrib/http/patcher.rb +0 -27
  866. data/lib/ddtrace/contrib/http_annotation_helper.rb +0 -11
  867. data/lib/ddtrace/contrib/httpclient/configuration/settings.rb +0 -33
  868. data/lib/ddtrace/contrib/httpclient/ext.rb +0 -18
  869. data/lib/ddtrace/contrib/httpclient/instrumentation.rb +0 -148
  870. data/lib/ddtrace/contrib/httpclient/integration.rb +0 -44
  871. data/lib/ddtrace/contrib/httpclient/patcher.rb +0 -39
  872. data/lib/ddtrace/contrib/httprb/configuration/settings.rb +0 -33
  873. data/lib/ddtrace/contrib/httprb/ext.rb +0 -18
  874. data/lib/ddtrace/contrib/httprb/instrumentation.rb +0 -158
  875. data/lib/ddtrace/contrib/httprb/integration.rb +0 -44
  876. data/lib/ddtrace/contrib/httprb/patcher.rb +0 -39
  877. data/lib/ddtrace/contrib/integration.rb +0 -17
  878. data/lib/ddtrace/contrib/kafka/configuration/settings.rb +0 -31
  879. data/lib/ddtrace/contrib/kafka/consumer_event.rb +0 -15
  880. data/lib/ddtrace/contrib/kafka/consumer_group_event.rb +0 -15
  881. data/lib/ddtrace/contrib/kafka/event.rb +0 -52
  882. data/lib/ddtrace/contrib/kafka/events/connection/request.rb +0 -35
  883. data/lib/ddtrace/contrib/kafka/events/consumer/process_batch.rb +0 -42
  884. data/lib/ddtrace/contrib/kafka/events/consumer/process_message.rb +0 -40
  885. data/lib/ddtrace/contrib/kafka/events/consumer_group/heartbeat.rb +0 -40
  886. data/lib/ddtrace/contrib/kafka/events/consumer_group/join_group.rb +0 -30
  887. data/lib/ddtrace/contrib/kafka/events/consumer_group/leave_group.rb +0 -30
  888. data/lib/ddtrace/contrib/kafka/events/consumer_group/sync_group.rb +0 -30
  889. data/lib/ddtrace/contrib/kafka/events/produce_operation/send_messages.rb +0 -33
  890. data/lib/ddtrace/contrib/kafka/events/producer/deliver_messages.rb +0 -36
  891. data/lib/ddtrace/contrib/kafka/events.rb +0 -45
  892. data/lib/ddtrace/contrib/kafka/ext.rb +0 -42
  893. data/lib/ddtrace/contrib/kafka/integration.rb +0 -40
  894. data/lib/ddtrace/contrib/kafka/patcher.rb +0 -27
  895. data/lib/ddtrace/contrib/lograge/configuration/settings.rb +0 -19
  896. data/lib/ddtrace/contrib/lograge/ext.rb +0 -11
  897. data/lib/ddtrace/contrib/lograge/instrumentation.rb +0 -39
  898. data/lib/ddtrace/contrib/lograge/integration.rb +0 -46
  899. data/lib/ddtrace/contrib/lograge/patcher.rb +0 -26
  900. data/lib/ddtrace/contrib/mongodb/configuration/settings.rb +0 -34
  901. data/lib/ddtrace/contrib/mongodb/ext.rb +0 -24
  902. data/lib/ddtrace/contrib/mongodb/instrumentation.rb +0 -70
  903. data/lib/ddtrace/contrib/mongodb/integration.rb +0 -39
  904. data/lib/ddtrace/contrib/mongodb/parsers.rb +0 -69
  905. data/lib/ddtrace/contrib/mongodb/patcher.rb +0 -32
  906. data/lib/ddtrace/contrib/mongodb/subscribers.rb +0 -112
  907. data/lib/ddtrace/contrib/mysql2/configuration/settings.rb +0 -31
  908. data/lib/ddtrace/contrib/mysql2/ext.rb +0 -19
  909. data/lib/ddtrace/contrib/mysql2/instrumentation.rb +0 -65
  910. data/lib/ddtrace/contrib/mysql2/integration.rb +0 -39
  911. data/lib/ddtrace/contrib/mysql2/patcher.rb +0 -28
  912. data/lib/ddtrace/contrib/patchable.rb +0 -71
  913. data/lib/ddtrace/contrib/patcher.rb +0 -66
  914. data/lib/ddtrace/contrib/presto/configuration/settings.rb +0 -31
  915. data/lib/ddtrace/contrib/presto/ext.rb +0 -29
  916. data/lib/ddtrace/contrib/presto/instrumentation.rb +0 -111
  917. data/lib/ddtrace/contrib/presto/integration.rb +0 -39
  918. data/lib/ddtrace/contrib/presto/patcher.rb +0 -34
  919. data/lib/ddtrace/contrib/qless/configuration/settings.rb +0 -36
  920. data/lib/ddtrace/contrib/qless/ext.rb +0 -21
  921. data/lib/ddtrace/contrib/qless/integration.rb +0 -39
  922. data/lib/ddtrace/contrib/qless/patcher.rb +0 -35
  923. data/lib/ddtrace/contrib/qless/qless_job.rb +0 -74
  924. data/lib/ddtrace/contrib/qless/tracer_cleaner.rb +0 -34
  925. data/lib/ddtrace/contrib/que/configuration/settings.rb +0 -44
  926. data/lib/ddtrace/contrib/que/ext.rb +0 -31
  927. data/lib/ddtrace/contrib/que/integration.rb +0 -43
  928. data/lib/ddtrace/contrib/que/patcher.rb +0 -25
  929. data/lib/ddtrace/contrib/que/tracer.rb +0 -58
  930. data/lib/ddtrace/contrib/racecar/configuration/settings.rb +0 -31
  931. data/lib/ddtrace/contrib/racecar/event.rb +0 -77
  932. data/lib/ddtrace/contrib/racecar/events/batch.rb +0 -28
  933. data/lib/ddtrace/contrib/racecar/events/consume.rb +0 -28
  934. data/lib/ddtrace/contrib/racecar/events/message.rb +0 -28
  935. data/lib/ddtrace/contrib/racecar/events.rb +0 -33
  936. data/lib/ddtrace/contrib/racecar/ext.rb +0 -26
  937. data/lib/ddtrace/contrib/racecar/integration.rb +0 -40
  938. data/lib/ddtrace/contrib/racecar/patcher.rb +0 -27
  939. data/lib/ddtrace/contrib/rack/configuration/settings.rb +0 -47
  940. data/lib/ddtrace/contrib/rack/ext.rb +0 -22
  941. data/lib/ddtrace/contrib/rack/integration.rb +0 -46
  942. data/lib/ddtrace/contrib/rack/middlewares.rb +0 -288
  943. data/lib/ddtrace/contrib/rack/patcher.rb +0 -106
  944. data/lib/ddtrace/contrib/rack/request_queue.rb +0 -45
  945. data/lib/ddtrace/contrib/rails/auto_instrument_railtie.rb +0 -11
  946. data/lib/ddtrace/contrib/rails/configuration/settings.rb +0 -94
  947. data/lib/ddtrace/contrib/rails/ext.rb +0 -18
  948. data/lib/ddtrace/contrib/rails/framework.rb +0 -149
  949. data/lib/ddtrace/contrib/rails/integration.rb +0 -45
  950. data/lib/ddtrace/contrib/rails/log_injection.rb +0 -42
  951. data/lib/ddtrace/contrib/rails/middlewares.rb +0 -44
  952. data/lib/ddtrace/contrib/rails/patcher.rb +0 -110
  953. data/lib/ddtrace/contrib/rails/railtie.rb +0 -18
  954. data/lib/ddtrace/contrib/rails/utils.rb +0 -25
  955. data/lib/ddtrace/contrib/rake/configuration/settings.rb +0 -32
  956. data/lib/ddtrace/contrib/rake/ext.rb +0 -22
  957. data/lib/ddtrace/contrib/rake/instrumentation.rb +0 -91
  958. data/lib/ddtrace/contrib/rake/integration.rb +0 -39
  959. data/lib/ddtrace/contrib/rake/patcher.rb +0 -31
  960. data/lib/ddtrace/contrib/redis/configuration/resolver.rb +0 -46
  961. data/lib/ddtrace/contrib/redis/configuration/settings.rb +0 -36
  962. data/lib/ddtrace/contrib/redis/ext.rb +0 -23
  963. data/lib/ddtrace/contrib/redis/integration.rb +0 -43
  964. data/lib/ddtrace/contrib/redis/patcher.rb +0 -115
  965. data/lib/ddtrace/contrib/redis/quantize.rb +0 -76
  966. data/lib/ddtrace/contrib/redis/tags.rb +0 -47
  967. data/lib/ddtrace/contrib/redis/vendor/resolver.rb +0 -159
  968. data/lib/ddtrace/contrib/registerable.rb +0 -34
  969. data/lib/ddtrace/contrib/registry.rb +0 -43
  970. data/lib/ddtrace/contrib/resque/configuration/settings.rb +0 -49
  971. data/lib/ddtrace/contrib/resque/ext.rb +0 -18
  972. data/lib/ddtrace/contrib/resque/integration.rb +0 -48
  973. data/lib/ddtrace/contrib/resque/patcher.rb +0 -30
  974. data/lib/ddtrace/contrib/resque/resque_job.rb +0 -104
  975. data/lib/ddtrace/contrib/rest_client/configuration/settings.rb +0 -32
  976. data/lib/ddtrace/contrib/rest_client/ext.rb +0 -18
  977. data/lib/ddtrace/contrib/rest_client/integration.rb +0 -39
  978. data/lib/ddtrace/contrib/rest_client/patcher.rb +0 -25
  979. data/lib/ddtrace/contrib/rest_client/request_patch.rb +0 -92
  980. data/lib/ddtrace/contrib/semantic_logger/configuration/settings.rb +0 -19
  981. data/lib/ddtrace/contrib/semantic_logger/ext.rb +0 -11
  982. data/lib/ddtrace/contrib/semantic_logger/instrumentation.rb +0 -43
  983. data/lib/ddtrace/contrib/semantic_logger/integration.rb +0 -48
  984. data/lib/ddtrace/contrib/semantic_logger/patcher.rb +0 -26
  985. data/lib/ddtrace/contrib/sequel/configuration/settings.rb +0 -29
  986. data/lib/ddtrace/contrib/sequel/database.rb +0 -64
  987. data/lib/ddtrace/contrib/sequel/dataset.rb +0 -64
  988. data/lib/ddtrace/contrib/sequel/ext.rb +0 -20
  989. data/lib/ddtrace/contrib/sequel/integration.rb +0 -39
  990. data/lib/ddtrace/contrib/sequel/patcher.rb +0 -34
  991. data/lib/ddtrace/contrib/sequel/utils.rb +0 -75
  992. data/lib/ddtrace/contrib/shoryuken/configuration/settings.rb +0 -32
  993. data/lib/ddtrace/contrib/shoryuken/ext.rb +0 -22
  994. data/lib/ddtrace/contrib/shoryuken/integration.rb +0 -40
  995. data/lib/ddtrace/contrib/shoryuken/patcher.rb +0 -25
  996. data/lib/ddtrace/contrib/shoryuken/tracer.rb +0 -56
  997. data/lib/ddtrace/contrib/sidekiq/client_tracer.rb +0 -44
  998. data/lib/ddtrace/contrib/sidekiq/configuration/settings.rb +0 -38
  999. data/lib/ddtrace/contrib/sidekiq/ext.rb +0 -28
  1000. data/lib/ddtrace/contrib/sidekiq/integration.rb +0 -39
  1001. data/lib/ddtrace/contrib/sidekiq/patcher.rb +0 -42
  1002. data/lib/ddtrace/contrib/sidekiq/server_tracer.rb +0 -66
  1003. data/lib/ddtrace/contrib/sidekiq/tracing.rb +0 -45
  1004. data/lib/ddtrace/contrib/sinatra/configuration/settings.rb +0 -40
  1005. data/lib/ddtrace/contrib/sinatra/env.rb +0 -58
  1006. data/lib/ddtrace/contrib/sinatra/ext.rb +0 -28
  1007. data/lib/ddtrace/contrib/sinatra/headers.rb +0 -30
  1008. data/lib/ddtrace/contrib/sinatra/integration.rb +0 -39
  1009. data/lib/ddtrace/contrib/sinatra/patcher.rb +0 -30
  1010. data/lib/ddtrace/contrib/sinatra/tracer.rb +0 -137
  1011. data/lib/ddtrace/contrib/sinatra/tracer_middleware.rb +0 -112
  1012. data/lib/ddtrace/contrib/sneakers/configuration/settings.rb +0 -34
  1013. data/lib/ddtrace/contrib/sneakers/ext.rb +0 -23
  1014. data/lib/ddtrace/contrib/sneakers/integration.rb +0 -42
  1015. data/lib/ddtrace/contrib/sneakers/patcher.rb +0 -25
  1016. data/lib/ddtrace/contrib/sneakers/tracer.rb +0 -54
  1017. data/lib/ddtrace/contrib/status_code_matcher.rb +0 -70
  1018. data/lib/ddtrace/contrib/sucker_punch/configuration/settings.rb +0 -31
  1019. data/lib/ddtrace/contrib/sucker_punch/exception_handler.rb +0 -25
  1020. data/lib/ddtrace/contrib/sucker_punch/ext.rb +0 -22
  1021. data/lib/ddtrace/contrib/sucker_punch/instrumentation.rb +0 -89
  1022. data/lib/ddtrace/contrib/sucker_punch/integration.rb +0 -39
  1023. data/lib/ddtrace/contrib/sucker_punch/patcher.rb +0 -44
  1024. data/lib/ddtrace/correlation.rb +0 -40
  1025. data/lib/ddtrace/diagnostics/environment_logger.rb +0 -280
  1026. data/lib/ddtrace/diagnostics/health.rb +0 -34
  1027. data/lib/ddtrace/distributed_tracing/headers/b3.rb +0 -45
  1028. data/lib/ddtrace/distributed_tracing/headers/b3_single.rb +0 -57
  1029. data/lib/ddtrace/distributed_tracing/headers/datadog.rb +0 -43
  1030. data/lib/ddtrace/distributed_tracing/headers/headers.rb +0 -72
  1031. data/lib/ddtrace/distributed_tracing/headers/helpers.rb +0 -44
  1032. data/lib/ddtrace/encoding.rb +0 -72
  1033. data/lib/ddtrace/error.rb +0 -97
  1034. data/lib/ddtrace/event.rb +0 -53
  1035. data/lib/ddtrace/ext/analytics.rb +0 -13
  1036. data/lib/ddtrace/ext/app_types.rb +0 -12
  1037. data/lib/ddtrace/ext/correlation.rb +0 -12
  1038. data/lib/ddtrace/ext/diagnostics.rb +0 -37
  1039. data/lib/ddtrace/ext/distributed.rb +0 -40
  1040. data/lib/ddtrace/ext/environment.rb +0 -24
  1041. data/lib/ddtrace/ext/errors.rb +0 -11
  1042. data/lib/ddtrace/ext/forced_tracing.rb +0 -26
  1043. data/lib/ddtrace/ext/git.rb +0 -20
  1044. data/lib/ddtrace/ext/http.rb +0 -47
  1045. data/lib/ddtrace/ext/integration.rb +0 -9
  1046. data/lib/ddtrace/ext/manual_tracing.rb +0 -10
  1047. data/lib/ddtrace/ext/metrics.rb +0 -16
  1048. data/lib/ddtrace/ext/net.rb +0 -11
  1049. data/lib/ddtrace/ext/priority.rb +0 -17
  1050. data/lib/ddtrace/ext/profiling.rb +0 -56
  1051. data/lib/ddtrace/ext/runtime.rb +0 -22
  1052. data/lib/ddtrace/ext/sampling.rb +0 -17
  1053. data/lib/ddtrace/ext/sql.rb +0 -9
  1054. data/lib/ddtrace/ext/test.rb +0 -9
  1055. data/lib/ddtrace/ext/transport.rb +0 -21
  1056. data/lib/ddtrace/forced_tracing.rb +0 -39
  1057. data/lib/ddtrace/logger.rb +0 -41
  1058. data/lib/ddtrace/metrics.rb +0 -282
  1059. data/lib/ddtrace/opentelemetry/extensions.rb +0 -14
  1060. data/lib/ddtrace/opentelemetry/span.rb +0 -34
  1061. data/lib/ddtrace/opentracer/binary_propagator.rb +0 -25
  1062. data/lib/ddtrace/opentracer/carrier.rb +0 -7
  1063. data/lib/ddtrace/opentracer/distributed_headers.rb +0 -56
  1064. data/lib/ddtrace/opentracer/global_tracer.rb +0 -16
  1065. data/lib/ddtrace/opentracer/propagator.rb +0 -23
  1066. data/lib/ddtrace/opentracer/rack_propagator.rb +0 -61
  1067. data/lib/ddtrace/opentracer/scope.rb +0 -16
  1068. data/lib/ddtrace/opentracer/scope_manager.rb +0 -7
  1069. data/lib/ddtrace/opentracer/span.rb +0 -95
  1070. data/lib/ddtrace/opentracer/span_context.rb +0 -15
  1071. data/lib/ddtrace/opentracer/span_context_factory.rb +0 -24
  1072. data/lib/ddtrace/opentracer/text_map_propagator.rb +0 -76
  1073. data/lib/ddtrace/opentracer/thread_local_scope.rb +0 -32
  1074. data/lib/ddtrace/opentracer/thread_local_scope_manager.rb +0 -41
  1075. data/lib/ddtrace/opentracer/tracer.rb +0 -209
  1076. data/lib/ddtrace/opentracer.rb +0 -22
  1077. data/lib/ddtrace/patcher.rb +0 -69
  1078. data/lib/ddtrace/pin.rb +0 -86
  1079. data/lib/ddtrace/pipeline/span_filter.rb +0 -39
  1080. data/lib/ddtrace/pipeline/span_processor.rb +0 -21
  1081. data/lib/ddtrace/pipeline.rb +0 -47
  1082. data/lib/ddtrace/profiling/backtrace_location.rb +0 -33
  1083. data/lib/ddtrace/profiling/buffer.rb +0 -42
  1084. data/lib/ddtrace/profiling/collectors/stack.rb +0 -257
  1085. data/lib/ddtrace/profiling/encoding/profile.rb +0 -38
  1086. data/lib/ddtrace/profiling/event.rb +0 -14
  1087. data/lib/ddtrace/profiling/events/stack.rb +0 -81
  1088. data/lib/ddtrace/profiling/exporter.rb +0 -24
  1089. data/lib/ddtrace/profiling/ext/cpu.rb +0 -67
  1090. data/lib/ddtrace/profiling/ext/cthread.rb +0 -156
  1091. data/lib/ddtrace/profiling/ext/forking.rb +0 -98
  1092. data/lib/ddtrace/profiling/flush.rb +0 -44
  1093. data/lib/ddtrace/profiling/native_extension.rb +0 -18
  1094. data/lib/ddtrace/profiling/pprof/builder.rb +0 -120
  1095. data/lib/ddtrace/profiling/pprof/converter.rb +0 -90
  1096. data/lib/ddtrace/profiling/pprof/message_set.rb +0 -15
  1097. data/lib/ddtrace/profiling/pprof/payload.rb +0 -19
  1098. data/lib/ddtrace/profiling/pprof/pprof_pb.rb +0 -82
  1099. data/lib/ddtrace/profiling/pprof/stack_sample.rb +0 -117
  1100. data/lib/ddtrace/profiling/pprof/string_table.rb +0 -11
  1101. data/lib/ddtrace/profiling/pprof/template.rb +0 -119
  1102. data/lib/ddtrace/profiling/profiler.rb +0 -31
  1103. data/lib/ddtrace/profiling/recorder.rb +0 -96
  1104. data/lib/ddtrace/profiling/scheduler.rb +0 -134
  1105. data/lib/ddtrace/profiling/tasks/setup.rb +0 -82
  1106. data/lib/ddtrace/profiling/trace_identifiers/ddtrace.rb +0 -41
  1107. data/lib/ddtrace/profiling/trace_identifiers/helper.rb +0 -46
  1108. data/lib/ddtrace/profiling/transport/client.rb +0 -15
  1109. data/lib/ddtrace/profiling/transport/http/api/endpoint.rb +0 -101
  1110. data/lib/ddtrace/profiling/transport/http/api/instance.rb +0 -37
  1111. data/lib/ddtrace/profiling/transport/http/api/spec.rb +0 -41
  1112. data/lib/ddtrace/profiling/transport/http/api.rb +0 -44
  1113. data/lib/ddtrace/profiling/transport/http/builder.rb +0 -29
  1114. data/lib/ddtrace/profiling/transport/http/client.rb +0 -34
  1115. data/lib/ddtrace/profiling/transport/http/response.rb +0 -22
  1116. data/lib/ddtrace/profiling/transport/http.rb +0 -120
  1117. data/lib/ddtrace/profiling/transport/io/client.rb +0 -28
  1118. data/lib/ddtrace/profiling/transport/io/response.rb +0 -17
  1119. data/lib/ddtrace/profiling/transport/io.rb +0 -31
  1120. data/lib/ddtrace/profiling/transport/parcel.rb +0 -18
  1121. data/lib/ddtrace/profiling/transport/request.rb +0 -16
  1122. data/lib/ddtrace/profiling/transport/response.rb +0 -9
  1123. data/lib/ddtrace/profiling.rb +0 -151
  1124. data/lib/ddtrace/propagation/grpc_propagator.rb +0 -75
  1125. data/lib/ddtrace/propagation/http_propagator.rb +0 -91
  1126. data/lib/ddtrace/quantization/hash.rb +0 -104
  1127. data/lib/ddtrace/quantization/http.rb +0 -90
  1128. data/lib/ddtrace/runtime/metrics.rb +0 -121
  1129. data/lib/ddtrace/sampler.rb +0 -293
  1130. data/lib/ddtrace/sampling/matcher.rb +0 -58
  1131. data/lib/ddtrace/sampling/rate_limiter.rb +0 -177
  1132. data/lib/ddtrace/sampling/rule.rb +0 -62
  1133. data/lib/ddtrace/sampling/rule_sampler.rb +0 -121
  1134. data/lib/ddtrace/sampling.rb +0 -3
  1135. data/lib/ddtrace/span.rb +0 -457
  1136. data/lib/ddtrace/sync_writer.rb +0 -69
  1137. data/lib/ddtrace/tasks/exec.rb +0 -47
  1138. data/lib/ddtrace/tasks/help.rb +0 -15
  1139. data/lib/ddtrace/tracer.rb +0 -449
  1140. data/lib/ddtrace/utils/compression.rb +0 -28
  1141. data/lib/ddtrace/utils/database.rb +0 -26
  1142. data/lib/ddtrace/utils/forking.rb +0 -53
  1143. data/lib/ddtrace/utils/object_set.rb +0 -40
  1144. data/lib/ddtrace/utils/only_once.rb +0 -41
  1145. data/lib/ddtrace/utils/sequence.rb +0 -18
  1146. data/lib/ddtrace/utils/string_table.rb +0 -46
  1147. data/lib/ddtrace/utils/time.rb +0 -46
  1148. data/lib/ddtrace/utils.rb +0 -80
  1149. data/lib/ddtrace/vendor/active_record/connection_specification.rb +0 -302
  1150. data/lib/ddtrace/vendor/multipart-post/multipart/post/composite_read_io.rb +0 -117
  1151. data/lib/ddtrace/vendor/multipart-post/multipart/post/multipartable.rb +0 -58
  1152. data/lib/ddtrace/vendor/multipart-post/multipart/post/parts.rb +0 -136
  1153. data/lib/ddtrace/vendor/multipart-post/multipart/post/version.rb +0 -10
  1154. data/lib/ddtrace/vendor/multipart-post/multipart/post.rb +0 -9
  1155. data/lib/ddtrace/vendor/multipart-post/multipart.rb +0 -13
  1156. data/lib/ddtrace/vendor/multipart-post/net/http/post/multipart.rb +0 -33
  1157. data/lib/ddtrace/worker.rb +0 -21
  1158. data/lib/ddtrace/workers/async.rb +0 -175
  1159. data/lib/ddtrace/workers/loop.rb +0 -132
  1160. data/lib/ddtrace/workers/polling.rb +0 -56
  1161. data/lib/ddtrace/workers/queue.rb +0 -41
  1162. data/lib/ddtrace/workers/runtime_metrics.rb +0 -65
  1163. data/lib/ddtrace/workers/trace_writer.rb +0 -200
  1164. data/lib/ddtrace/workers.rb +0 -123
  1165. data/lib/ddtrace/writer.rb +0 -200
  1166. /data/lib/{ddtrace → datadog/core}/vendor/multipart-post/LICENSE +0 -0
  1167. /data/lib/{ddtrace → datadog}/profiling/pprof/pprof.proto +0 -0
  1168. /data/lib/{ddtrace/vendor/active_record → datadog/tracing/contrib/active_record/vendor}/MIT-LICENSE +0 -0
  1169. /data/lib/{ddtrace → datadog/tracing}/contrib/redis/vendor/LICENSE +0 -0
data/lib/ddtrace/span.rb DELETED
@@ -1,457 +0,0 @@
1
- # typed: true
2
- # frozen_string_literal: true
3
-
4
- require 'time'
5
- require 'ddtrace/utils'
6
- require 'ddtrace/ext/distributed'
7
- require 'ddtrace/ext/environment'
8
- require 'ddtrace/ext/errors'
9
- require 'ddtrace/ext/http'
10
- require 'ddtrace/ext/net'
11
- require 'ddtrace/ext/priority'
12
- require 'ddtrace/analytics'
13
- require 'ddtrace/forced_tracing'
14
- require 'ddtrace/diagnostics/health'
15
- require 'ddtrace/utils/time'
16
-
17
- module Datadog
18
- # Represents a logical unit of work in the system. Each trace consists of one or more spans.
19
- # Each span consists of a start time and a duration. For example, a span can describe the time
20
- # spent on a distributed call on a separate machine, or the time spent in a small component
21
- # within a larger operation. Spans can be nested within each other, and in those instances
22
- # will have a parent-child relationship.
23
- #
24
- # rubocop:disable Metrics/ClassLength
25
- class Span
26
- prepend Analytics::Span
27
- prepend ForcedTracing::Span
28
-
29
- # The max value for a \Span identifier.
30
- # Span and trace identifiers should be strictly positive and strictly inferior to this limit.
31
- #
32
- # Limited to +2<<62-1+ positive integers, as Ruby is able to represent such numbers "inline",
33
- # inside a +VALUE+ scalar, thus not requiring memory allocation.
34
- #
35
- # The range of IDs also has to consider portability across different languages and platforms.
36
- RUBY_MAX_ID = (1 << 62) - 1
37
-
38
- # While we only generate 63-bit integers due to limitations in other languages, we support
39
- # parsing 64-bit integers for distributed tracing since an upstream system may generate one
40
- EXTERNAL_MAX_ID = 1 << 64
41
-
42
- # This limit is for numeric tags because uint64 could end up rounded.
43
- NUMERIC_TAG_SIZE_RANGE = (-1 << 53..1 << 53).freeze
44
-
45
- # Some associated values should always be sent as Tags, never as Metrics, regardless
46
- # if their value is numeric or not.
47
- # The Datadog agent will look for these values only as Tags, not Metrics.
48
- # @see https://github.com/DataDog/datadog-agent/blob/2ae2cdd315bcda53166dd8fa0dedcfc448087b9d/pkg/trace/stats/aggregation.go#L13-L17
49
- ENSURE_AGENT_TAGS = {
50
- Ext::DistributedTracing::ORIGIN_KEY => true,
51
- Ext::Environment::TAG_VERSION => true,
52
- Ext::HTTP::STATUS_CODE => true,
53
- Ext::NET::TAG_HOSTNAME => true
54
- }.freeze
55
-
56
- # Simple indirection used to contain the latest resource name for a span.
57
- # The profiler keeps a reference to these objects while sampling so it can extract the latest resource after the
58
- # fact, as some integrations only set the correct name at the end of the span.
59
- ResourceContainer = Struct.new(:latest)
60
-
61
- attr_accessor :name, :service, :span_type,
62
- :span_id, :trace_id, :parent_id,
63
- :status, :sampled,
64
- :tracer, :context
65
-
66
- attr_reader :parent, :start_time, :end_time, :resource_container
67
-
68
- attr_writer :duration
69
-
70
- # Create a new span linked to the given tracer. Call the \Tracer method <tt>start_span()</tt>
71
- # and then <tt>finish()</tt> once the tracer operation is over.
72
- #
73
- # * +service+: the service name for this span
74
- # * +resource+: the resource this span refers, or +name+ if it's missing
75
- # * +span_type+: the type of the span (such as +http+, +db+ and so on)
76
- # * +parent_id+: the identifier of the parent span
77
- # * +trace_id+: the identifier of the root span for this trace
78
- # * +context+: the context of the span
79
- def initialize(tracer, name, options = {})
80
- @tracer = tracer
81
-
82
- @name = name
83
- @service = options.fetch(:service, nil)
84
- @resource_container = ResourceContainer.new(options.fetch(:resource, name))
85
- @span_type = options.fetch(:span_type, nil)
86
-
87
- @span_id = Datadog::Utils.next_id
88
- @parent_id = options.fetch(:parent_id, 0)
89
- @trace_id = options.fetch(:trace_id, Datadog::Utils.next_id)
90
-
91
- @context = options.fetch(:context, nil)
92
-
93
- @meta = {}
94
- @metrics = {}
95
- @status = 0
96
-
97
- @parent = nil
98
- @sampled = true
99
-
100
- @allocation_count_start = now_allocations
101
- @allocation_count_finish = @allocation_count_start
102
-
103
- # start_time and end_time track wall clock. In Ruby, wall clock
104
- # has less accuracy than monotonic clock, so if possible we look to only use wall clock
105
- # to measure duration when a time is supplied by the user, or if monotonic clock
106
- # is unsupported.
107
- @start_time = nil
108
- @end_time = nil
109
-
110
- # duration_start and duration_end track monotonic clock, and may remain nil in cases where it
111
- # is known that we have to use wall clock to measure duration.
112
- @duration_start = nil
113
- @duration_end = nil
114
- end
115
-
116
- # Set the given key / value tag pair on the span. Keys and values
117
- # must be strings. A valid example is:
118
- #
119
- # span.set_tag('http.method', request.method)
120
- def set_tag(key, value = nil)
121
- # Keys must be unique between tags and metrics
122
- @metrics.delete(key)
123
-
124
- # DEV: This is necessary because the agent looks at `meta[key]`, not `metrics[key]`.
125
- value = value.to_s if ENSURE_AGENT_TAGS[key]
126
-
127
- # NOTE: Adding numeric tags as metrics is stop-gap support
128
- # for numeric typed tags. Eventually they will become
129
- # tags again.
130
- # Any numeric that is not an integer greater than max size is logged as a metric.
131
- # Everything else gets logged as a tag.
132
- if value.is_a?(Numeric) && !(value.is_a?(Integer) && !NUMERIC_TAG_SIZE_RANGE.cover?(value))
133
- set_metric(key, value)
134
- else
135
- @meta[key] = value.to_s
136
- end
137
- rescue StandardError => e
138
- Datadog.logger.debug("Unable to set the tag #{key}, ignoring it. Caused by: #{e}")
139
- end
140
-
141
- # Sets tags from given hash, for each key in hash it sets the tag with that key
142
- # and associated value from the hash. It is shortcut for `set_tag`. Keys and values
143
- # of the hash must be strings. Note that nested hashes are not supported.
144
- # A valid example is:
145
- #
146
- # span.set_tags({ "http.method" => "GET", "user.id" => "234" })
147
- def set_tags(tags)
148
- tags.each { |k, v| set_tag(k, v) }
149
- end
150
-
151
- # This method removes a tag for the given key.
152
- def clear_tag(key)
153
- @meta.delete(key)
154
- end
155
-
156
- # Return the tag with the given key, nil if it doesn't exist.
157
- def get_tag(key)
158
- @meta[key] || @metrics[key]
159
- end
160
-
161
- # This method sets a tag with a floating point value for the given key. It acts
162
- # like `set_tag()` and it simply add a tag without further processing.
163
- def set_metric(key, value)
164
- # Keys must be unique between tags and metrics
165
- @meta.delete(key)
166
-
167
- # enforce that the value is a floating point number
168
- value = Float(value)
169
- @metrics[key] = value
170
- rescue StandardError => e
171
- Datadog.logger.debug("Unable to set the metric #{key}, ignoring it. Caused by: #{e}")
172
- end
173
-
174
- # This method removes a metric for the given key. It acts like {#remove_tag}.
175
- def clear_metric(key)
176
- @metrics.delete(key)
177
- end
178
-
179
- # Return the metric with the given key, nil if it doesn't exist.
180
- def get_metric(key)
181
- @metrics[key] || @meta[key]
182
- end
183
-
184
- # Mark the span with the given error.
185
- def set_error(e)
186
- e = Error.build_from(e)
187
-
188
- @status = Ext::Errors::STATUS
189
- set_tag(Ext::Errors::TYPE, e.type) unless e.type.empty?
190
- set_tag(Ext::Errors::MSG, e.message) unless e.message.empty?
191
- set_tag(Ext::Errors::STACK, e.backtrace) unless e.backtrace.empty?
192
- end
193
-
194
- # Mark the span started at the current time.
195
- def start(start_time = nil)
196
- # A span should not be started twice. However, this is existing
197
- # behavior and so we maintain it for backward compatibility for those
198
- # who are using async manual instrumentation that may rely on this
199
-
200
- @start_time = start_time || Utils::Time.now.utc
201
- @duration_start = start_time.nil? ? duration_marker : nil
202
-
203
- self
204
- end
205
-
206
- # for backwards compatibility
207
- def start_time=(time)
208
- time.tap { start(time) }
209
- end
210
-
211
- # for backwards compatibility
212
- def end_time=(time)
213
- time.tap { finish(time) }
214
- end
215
-
216
- # Mark the span finished at the current time and submit it.
217
- def finish(finish_time = nil)
218
- # A span should not be finished twice. Note that this is not thread-safe,
219
- # finish is called from multiple threads, a given span might be finished
220
- # several times. Again, one should not do this, so this test is more a
221
- # fallback to avoid very bad things and protect you in most common cases.
222
- return if finished?
223
-
224
- @allocation_count_finish = now_allocations
225
-
226
- now = Utils::Time.now.utc
227
-
228
- # Provide a default start_time if unset.
229
- # Using `now` here causes duration to be 0; this is expected
230
- # behavior when start_time is unknown.
231
- start(finish_time || now) unless started?
232
-
233
- @end_time = finish_time || now
234
- @duration_end = finish_time.nil? ? duration_marker : nil
235
-
236
- # Finish does not really do anything if the span is not bound to a tracer and a context.
237
- return self if @tracer.nil? || @context.nil?
238
-
239
- # spans without a service would be dropped, so here we provide a default.
240
- # This should really never happen with integrations in contrib, as a default
241
- # service is always set. It's only for custom instrumentation.
242
- @service ||= (@tracer && @tracer.default_service)
243
-
244
- begin
245
- @context.close_span(self)
246
- @tracer.record(self)
247
- rescue StandardError => e
248
- Datadog.logger.debug("error recording finished trace: #{e}")
249
- Datadog.health_metrics.error_span_finish(1, tags: ["error:#{e.class.name}"])
250
- end
251
- self
252
- end
253
-
254
- # Return a string representation of the span.
255
- def to_s
256
- "Span(name:#{@name},sid:#{@span_id},tid:#{@trace_id},pid:#{@parent_id})"
257
- end
258
-
259
- # DEPRECATED: remove this function in the next release, replaced by ``parent=``
260
- def set_parent(parent)
261
- self.parent = parent
262
- end
263
-
264
- # Set this span's parent, inheriting any properties not explicitly set.
265
- # If the parent is nil, set the span zero values.
266
- def parent=(parent)
267
- @parent = parent
268
-
269
- if parent.nil?
270
- @trace_id = @span_id
271
- @parent_id = 0
272
- else
273
- @trace_id = parent.trace_id
274
- @parent_id = parent.span_id
275
- @service ||= parent.service
276
- @sampled = parent.sampled
277
- end
278
- end
279
-
280
- def allocations
281
- @allocation_count_finish - @allocation_count_start
282
- end
283
-
284
- # Return the hash representation of the current span.
285
- def to_hash
286
- h = {
287
- span_id: @span_id,
288
- parent_id: @parent_id,
289
- trace_id: @trace_id,
290
- name: @name,
291
- service: @service,
292
- resource: resource,
293
- type: @span_type,
294
- meta: @meta,
295
- metrics: @metrics,
296
- allocations: allocations,
297
- error: @status
298
- }
299
-
300
- if finished?
301
- h[:start] = start_time_nano
302
- h[:duration] = duration_nano
303
- end
304
-
305
- h
306
- end
307
-
308
- # MessagePack serializer interface. Making this object
309
- # respond to `#to_msgpack` allows it to be automatically
310
- # serialized by MessagePack.
311
- #
312
- # This is more efficient than doing +MessagePack.pack(span.to_hash)+
313
- # as we don't have to create an intermediate Hash.
314
- #
315
- # @param packer [MessagePack::Packer] serialization buffer, can be +nil+ with JRuby
316
- def to_msgpack(packer = nil)
317
- # As of 1.3.3, JRuby implementation doesn't pass an existing packer
318
- packer ||= MessagePack::Packer.new
319
-
320
- if finished?
321
- packer.write_map_header(13) # Set header with how many elements in the map
322
-
323
- packer.write('start')
324
- packer.write(start_time_nano)
325
-
326
- packer.write('duration')
327
- packer.write(duration_nano)
328
- else
329
- packer.write_map_header(11) # Set header with how many elements in the map
330
- end
331
-
332
- # DEV: We use strings as keys here, instead of symbols, as
333
- # DEV: MessagePack will ultimately convert them to strings.
334
- # DEV: By providing strings directly, we skip this indirection operation.
335
- packer.write('span_id')
336
- packer.write(@span_id)
337
- packer.write('parent_id')
338
- packer.write(@parent_id)
339
- packer.write('trace_id')
340
- packer.write(@trace_id)
341
- packer.write('name')
342
- packer.write(@name)
343
- packer.write('service')
344
- packer.write(@service)
345
- packer.write('resource')
346
- packer.write(resource)
347
- packer.write('type')
348
- packer.write(@span_type)
349
- packer.write('meta')
350
- packer.write(@meta)
351
- packer.write('metrics')
352
- packer.write(@metrics)
353
- packer.write('allocations')
354
- packer.write(allocations)
355
- packer.write('error')
356
- packer.write(@status)
357
- packer
358
- end
359
-
360
- # JSON serializer interface.
361
- # Used by older version of the transport.
362
- def to_json(*args)
363
- to_hash.to_json(*args)
364
- end
365
-
366
- # Return a human readable version of the span
367
- def pretty_print(q)
368
- start_time = (self.start_time.to_f * 1e9).to_i
369
- end_time = (self.end_time.to_f * 1e9).to_i
370
- q.group 0 do
371
- q.breakable
372
- q.text "Name: #{@name}\n"
373
- q.text "Span ID: #{@span_id}\n"
374
- q.text "Parent ID: #{@parent_id}\n"
375
- q.text "Trace ID: #{@trace_id}\n"
376
- q.text "Type: #{@span_type}\n"
377
- q.text "Service: #{@service}\n"
378
- q.text "Resource: #{resource}\n"
379
- q.text "Error: #{@status}\n"
380
- q.text "Start: #{start_time}\n"
381
- q.text "End: #{end_time}\n"
382
- q.text "Duration: #{duration.to_f if finished?}\n"
383
- q.text "Allocations: #{allocations}\n"
384
- q.group(2, 'Tags: [', "]\n") do
385
- q.breakable
386
- q.seplist @meta.each do |key, value|
387
- q.text "#{key} => #{value}"
388
- end
389
- end
390
- q.group(2, 'Metrics: [', ']') do
391
- q.breakable
392
- q.seplist @metrics.each do |key, value|
393
- q.text "#{key} => #{value}"
394
- end
395
- end
396
- end
397
- end
398
-
399
- # Return whether the duration is started or not
400
- def started?
401
- !@start_time.nil?
402
- end
403
-
404
- # Return whether the duration is finished or not.
405
- def finished?
406
- !@end_time.nil?
407
- end
408
-
409
- def duration
410
- if @duration_end.nil? || @duration_start.nil?
411
- @end_time - @start_time
412
- else
413
- @duration_end - @duration_start
414
- end
415
- end
416
-
417
- def resource
418
- @resource_container.latest
419
- end
420
-
421
- def resource=(resource)
422
- @resource_container.latest = resource
423
- end
424
-
425
- private
426
-
427
- def duration_marker
428
- Utils::Time.get_time
429
- end
430
-
431
- if defined?(JRUBY_VERSION) || Gem::Version.new(RUBY_VERSION) < Gem::Version.new(VERSION::MINIMUM_RUBY_VERSION)
432
- def now_allocations
433
- 0
434
- end
435
- elsif Gem::Version.new(RUBY_VERSION) < Gem::Version.new('2.2.0')
436
- def now_allocations
437
- GC.stat.fetch(:total_allocated_object)
438
- end
439
- else
440
- def now_allocations
441
- GC.stat(:total_allocated_objects)
442
- end
443
- end
444
-
445
- # Used for serialization
446
- # @return [Integer] in nanoseconds since Epoch
447
- def start_time_nano
448
- @start_time.to_i * 1000000000 + @start_time.nsec
449
- end
450
-
451
- # Used for serialization
452
- # @return [Integer] in nanoseconds since Epoch
453
- def duration_nano
454
- (duration * 1e9).to_i
455
- end
456
- end
457
- end
@@ -1,69 +0,0 @@
1
- # typed: true
2
- require 'ddtrace/ext/net'
3
- require 'datadog/core/environment/socket'
4
- require 'ddtrace/runtime/metrics'
5
- require 'ddtrace/utils/only_once'
6
-
7
- module Datadog
8
- # SyncWriter flushes both services and traces synchronously
9
- # DEV: To be replaced by Datadog::Workers::TraceWriter.
10
- #
11
- # Note: If you're wondering if this class is used at all, since there are no other references to it on the codebase,
12
- # the separate `datadog-lambda` uses it as of February 2021:
13
- # <https://github.com/DataDog/datadog-lambda-rb/blob/c15f0f0916c90123416dc44e7d6800ef4a7cfdbf/lib/datadog/lambda.rb#L38>
14
- class SyncWriter
15
- DEPRECATION_WARN_ONLY_ONCE = Datadog::Utils::OnlyOnce.new
16
-
17
- attr_reader \
18
- :priority_sampler,
19
- :transport
20
-
21
- def initialize(options = {})
22
- @transport = options.fetch(:transport) do
23
- transport_options = options.fetch(:transport_options, {})
24
- transport_options[:agent_settings] = options[:agent_settings] if options.key?(:agent_settings)
25
- Transport::HTTP.default(**transport_options)
26
- end
27
-
28
- @priority_sampler = options.fetch(:priority_sampler, nil)
29
- end
30
-
31
- def write(trace, services = nil)
32
- unless services.nil?
33
- DEPRECATION_WARN_ONLY_ONCE.run do
34
- Datadog.logger.warn(%(
35
- write: Writing services has been deprecated and no longer need to be provided.
36
- write(traces, services) can be updated to write(traces)
37
- ))
38
- end
39
- end
40
-
41
- flush_trace(trace)
42
- rescue => e
43
- Datadog.logger.debug(e)
44
- end
45
-
46
- # Added for interface completeness
47
- def stop
48
- # No cleanup to do for the SyncWriter
49
- true
50
- end
51
-
52
- private
53
-
54
- def flush_trace(trace)
55
- processed_traces = Pipeline.process!([trace])
56
- return if processed_traces.empty?
57
-
58
- inject_hostname!(processed_traces.first) if Datadog.configuration.report_hostname
59
- transport.send_traces(processed_traces)
60
- end
61
-
62
- def inject_hostname!(trace)
63
- unless trace.first.nil?
64
- hostname = Datadog::Core::Environment::Socket.hostname
65
- trace.first.set_tag(Ext::NET::TAG_HOSTNAME, hostname) unless hostname.nil? || hostname.empty?
66
- end
67
- end
68
- end
69
- end
@@ -1,47 +0,0 @@
1
- # typed: true
2
- module Datadog
3
- module Tasks
4
- # Wraps command with Datadog tracing
5
- class Exec
6
- attr_reader :args
7
-
8
- def initialize(args)
9
- @args = args
10
- end
11
-
12
- def run
13
- set_rubyopt!
14
- exec_with_error_handling(args)
15
- end
16
-
17
- def rubyopts
18
- [
19
- '-rddtrace/profiling/preload'
20
- ]
21
- end
22
-
23
- private
24
-
25
- def set_rubyopt!
26
- existing_rubyopt = ENV['RUBYOPT']
27
-
28
- ENV['RUBYOPT'] = existing_rubyopt ? "#{existing_rubyopt} #{rubyopts.join(' ')}" : rubyopts.join(' ')
29
- end
30
-
31
- # If there's an error here, rather than throwing a cryptic stack trace, let's instead have clearer messages, and
32
- # follow the same status codes as the shell uses
33
- # See also:
34
- # * https://www.gnu.org/software/bash/manual/html_node/Exit-Status.html
35
- # * https://github.com/rubygems/rubygems/blob/dd93966cac224532035deda533cba2685dfa30cc/bundler/lib/bundler/cli/exec.rb#L45
36
- def exec_with_error_handling(args)
37
- Kernel.exec(*args)
38
- rescue Errno::ENOENT => e
39
- Kernel.warn "ddtracerb exec failed: #{e.message} (command was '#{args.join(' ')}')"
40
- Kernel.exit 127
41
- rescue Errno::EACCES, Errno::ENOEXEC => e
42
- Kernel.warn "ddtracerb exec failed: #{e.message} (command was '#{args.join(' ')}')"
43
- Kernel.exit 126
44
- end
45
- end
46
- end
47
- end
@@ -1,15 +0,0 @@
1
- # typed: true
2
- module Datadog
3
- module Tasks
4
- # Prints help message for usage of `ddtrace`
5
- class Help
6
- def run
7
- puts %(
8
- Usage: ddtrace [command] [arguments]
9
- exec [command]: Executes command with tracing & profiling preloaded.
10
- help: Prints this help message.
11
- )
12
- end
13
- end
14
- end
15
- end