ddtrace 0.54.2 → 1.0.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 (1099) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +3 -0
  3. data/CHANGELOG.md +126 -1
  4. data/LICENSE-3rdparty.csv +2 -1
  5. data/README.md +4 -0
  6. data/bin/ddtracerb +5 -5
  7. data/ddtrace.gemspec +8 -5
  8. data/docs/0.x-trace.png +0 -0
  9. data/docs/1.0-trace.png +0 -0
  10. data/docs/AutoInstrumentation.md +36 -0
  11. data/docs/Deprecation.md +8 -0
  12. data/docs/DevelopmentGuide.md +1 -1
  13. data/docs/GettingStarted.md +551 -506
  14. data/docs/ProfilingDevelopment.md +12 -9
  15. data/docs/PublicApi.md +14 -0
  16. data/docs/UpgradeGuide.md +736 -0
  17. data/ext/ddtrace_profiling_native_extension/extconf.rb +9 -0
  18. data/ext/ddtrace_profiling_native_extension/profiling.c +3 -1
  19. data/lib/datadog/appsec/assets/blocked.html +4 -0
  20. data/lib/datadog/appsec/assets/waf_rules/README.md +7 -0
  21. data/lib/datadog/appsec/assets/waf_rules/recommended.json +5638 -0
  22. data/lib/datadog/appsec/assets/waf_rules/risky.json +1499 -0
  23. data/lib/datadog/appsec/assets/waf_rules/strict.json +1298 -0
  24. data/lib/datadog/appsec/assets.rb +38 -0
  25. data/lib/datadog/appsec/autoload.rb +16 -0
  26. data/lib/datadog/appsec/configuration/settings.rb +175 -0
  27. data/lib/datadog/appsec/configuration.rb +72 -0
  28. data/lib/datadog/appsec/contrib/auto_instrument.rb +29 -0
  29. data/lib/datadog/appsec/contrib/configuration/settings.rb +20 -0
  30. data/lib/datadog/appsec/contrib/integration.rb +37 -0
  31. data/lib/datadog/appsec/contrib/patcher.rb +12 -0
  32. data/lib/datadog/appsec/contrib/rack/configuration/settings.rb +22 -0
  33. data/lib/datadog/appsec/contrib/rack/ext.rb +15 -0
  34. data/lib/datadog/appsec/contrib/rack/gateway/watcher.rb +126 -0
  35. data/lib/datadog/appsec/contrib/rack/integration.rb +48 -0
  36. data/lib/datadog/appsec/contrib/rack/patcher.rb +33 -0
  37. data/lib/datadog/appsec/contrib/rack/reactive/request.rb +87 -0
  38. data/lib/datadog/appsec/contrib/rack/reactive/response.rb +64 -0
  39. data/lib/datadog/appsec/contrib/rack/request.rb +52 -0
  40. data/lib/datadog/appsec/contrib/rack/request_middleware.rb +57 -0
  41. data/lib/datadog/appsec/contrib/rack/response.rb +24 -0
  42. data/lib/datadog/appsec/contrib/rails/configuration/settings.rb +22 -0
  43. data/lib/datadog/appsec/contrib/rails/ext.rb +15 -0
  44. data/lib/datadog/appsec/contrib/rails/framework.rb +30 -0
  45. data/lib/datadog/appsec/contrib/rails/integration.rb +48 -0
  46. data/lib/datadog/appsec/contrib/rails/patcher.rb +125 -0
  47. data/lib/datadog/appsec/contrib/rails/request_middleware.rb +20 -0
  48. data/lib/datadog/appsec/contrib/sinatra/configuration/settings.rb +22 -0
  49. data/lib/datadog/appsec/contrib/sinatra/ext.rb +15 -0
  50. data/lib/datadog/appsec/contrib/sinatra/framework.rb +34 -0
  51. data/lib/datadog/appsec/contrib/sinatra/integration.rb +48 -0
  52. data/lib/datadog/appsec/contrib/sinatra/patcher.rb +77 -0
  53. data/lib/datadog/appsec/contrib/sinatra/request_middleware.rb +20 -0
  54. data/lib/datadog/appsec/event.rb +106 -0
  55. data/lib/datadog/appsec/extensions.rb +121 -0
  56. data/lib/datadog/appsec/instrumentation/gateway.rb +44 -0
  57. data/lib/datadog/appsec/processor.rb +121 -0
  58. data/lib/datadog/appsec/rate_limiter.rb +55 -0
  59. data/lib/datadog/appsec/reactive/address_hash.rb +18 -0
  60. data/lib/datadog/appsec/reactive/engine.rb +44 -0
  61. data/lib/datadog/appsec/reactive/operation.rb +52 -0
  62. data/lib/datadog/appsec/reactive/subscriber.rb +18 -0
  63. data/lib/datadog/appsec.rb +23 -0
  64. data/lib/datadog/ci/configuration/components.rb +9 -8
  65. data/lib/datadog/ci/configuration/settings.rb +19 -3
  66. data/lib/datadog/ci/contrib/cucumber/configuration/settings.rb +4 -2
  67. data/lib/datadog/ci/contrib/cucumber/ext.rb +2 -0
  68. data/lib/datadog/ci/contrib/cucumber/formatter.rb +4 -9
  69. data/lib/datadog/ci/contrib/cucumber/instrumentation.rb +2 -1
  70. data/lib/datadog/ci/contrib/cucumber/integration.rb +3 -2
  71. data/lib/datadog/ci/contrib/cucumber/patcher.rb +3 -2
  72. data/lib/datadog/ci/contrib/rspec/configuration/settings.rb +4 -2
  73. data/lib/datadog/ci/contrib/rspec/example.rb +4 -9
  74. data/lib/datadog/ci/contrib/rspec/ext.rb +2 -0
  75. data/lib/datadog/ci/contrib/rspec/integration.rb +3 -2
  76. data/lib/datadog/ci/contrib/rspec/patcher.rb +3 -2
  77. data/lib/datadog/ci/ext/app_types.rb +2 -1
  78. data/lib/datadog/ci/ext/environment.rb +107 -103
  79. data/lib/datadog/ci/ext/settings.rb +2 -1
  80. data/lib/datadog/ci/ext/test.rb +1 -0
  81. data/lib/datadog/ci/extensions.rb +5 -4
  82. data/lib/datadog/ci/flush.rb +38 -0
  83. data/lib/datadog/ci/test.rb +15 -13
  84. data/lib/datadog/ci.rb +4 -1
  85. data/lib/datadog/core/buffer/cruby.rb +55 -0
  86. data/lib/datadog/core/buffer/random.rb +134 -0
  87. data/lib/datadog/core/buffer/thread_safe.rb +58 -0
  88. data/lib/datadog/core/chunker.rb +35 -0
  89. data/lib/datadog/core/configuration/agent_settings_resolver.rb +365 -0
  90. data/lib/datadog/core/configuration/base.rb +89 -0
  91. data/lib/datadog/core/configuration/components.rb +393 -0
  92. data/lib/datadog/core/configuration/dependency_resolver.rb +28 -0
  93. data/lib/datadog/core/configuration/option.rb +69 -0
  94. data/lib/datadog/core/configuration/option_definition.rb +126 -0
  95. data/lib/datadog/core/configuration/option_definition_set.rb +22 -0
  96. data/lib/datadog/core/configuration/option_set.rb +10 -0
  97. data/lib/datadog/core/configuration/options.rb +118 -0
  98. data/lib/datadog/core/configuration/settings.rb +618 -0
  99. data/lib/datadog/core/configuration.rb +284 -0
  100. data/lib/datadog/core/diagnostics/environment_logger.rb +283 -0
  101. data/lib/datadog/core/diagnostics/ext.rb +41 -0
  102. data/lib/datadog/core/diagnostics/health.rb +37 -0
  103. data/lib/datadog/core/encoding.rb +76 -0
  104. data/lib/datadog/core/environment/cgroup.rb +1 -0
  105. data/lib/datadog/core/environment/class_count.rb +1 -0
  106. data/lib/datadog/core/environment/container.rb +1 -0
  107. data/lib/datadog/core/environment/ext.rb +28 -9
  108. data/lib/datadog/core/environment/gc.rb +1 -0
  109. data/lib/datadog/core/environment/identity.rb +11 -4
  110. data/lib/datadog/core/environment/socket.rb +9 -2
  111. data/lib/datadog/core/environment/thread_count.rb +1 -0
  112. data/lib/datadog/core/environment/variable_helpers.rb +2 -0
  113. data/lib/datadog/core/environment/vm_cache.rb +1 -0
  114. data/lib/datadog/core/error.rb +101 -0
  115. data/lib/datadog/core/extensions.rb +16 -0
  116. data/lib/datadog/core/git/ext.rb +35 -0
  117. data/lib/datadog/core/logger.rb +46 -0
  118. data/lib/datadog/core/metrics/client.rb +188 -0
  119. data/lib/datadog/core/metrics/ext.rb +20 -0
  120. data/lib/datadog/core/metrics/helpers.rb +25 -0
  121. data/lib/datadog/core/metrics/logging.rb +44 -0
  122. data/lib/datadog/core/metrics/metric.rb +14 -0
  123. data/lib/datadog/core/metrics/options.rb +50 -0
  124. data/lib/datadog/core/pin.rb +75 -0
  125. data/lib/datadog/core/runtime/ext.rb +28 -0
  126. data/lib/datadog/core/runtime/metrics.rb +126 -0
  127. data/lib/datadog/core/utils/compression.rb +32 -0
  128. data/lib/datadog/core/utils/forking.rb +63 -0
  129. data/lib/datadog/core/utils/object_set.rb +43 -0
  130. data/lib/datadog/core/utils/only_once.rb +44 -0
  131. data/lib/datadog/core/utils/safe_dup.rb +27 -0
  132. data/lib/datadog/core/utils/sequence.rb +21 -0
  133. data/lib/datadog/core/utils/string_table.rb +49 -0
  134. data/lib/datadog/core/utils/time.rb +54 -0
  135. data/lib/datadog/core/utils.rb +115 -0
  136. data/lib/{ddtrace → datadog/core}/vendor/multipart-post/LICENSE +0 -0
  137. data/lib/datadog/core/vendor/multipart-post/multipart/post/composite_read_io.rb +120 -0
  138. data/lib/datadog/core/vendor/multipart-post/multipart/post/multipartable.rb +61 -0
  139. data/lib/datadog/core/vendor/multipart-post/multipart/post/parts.rb +139 -0
  140. data/lib/datadog/core/vendor/multipart-post/multipart/post/version.rb +13 -0
  141. data/lib/datadog/core/vendor/multipart-post/multipart/post.rb +12 -0
  142. data/lib/datadog/core/vendor/multipart-post/multipart.rb +16 -0
  143. data/lib/datadog/core/vendor/multipart-post/net/http/post/multipart.rb +36 -0
  144. data/lib/datadog/core/worker.rb +24 -0
  145. data/lib/datadog/core/workers/async.rb +180 -0
  146. data/lib/datadog/core/workers/interval_loop.rb +119 -0
  147. data/lib/datadog/core/workers/polling.rb +59 -0
  148. data/lib/datadog/core/workers/queue.rb +44 -0
  149. data/lib/datadog/core/workers/runtime_metrics.rb +65 -0
  150. data/lib/datadog/core.rb +74 -0
  151. data/lib/datadog/opentracer/binary_propagator.rb +26 -0
  152. data/lib/datadog/opentracer/carrier.rb +9 -0
  153. data/lib/datadog/opentracer/distributed_headers.rb +58 -0
  154. data/lib/datadog/opentracer/global_tracer.rb +17 -0
  155. data/lib/datadog/opentracer/propagator.rb +26 -0
  156. data/lib/datadog/opentracer/rack_propagator.rb +72 -0
  157. data/lib/datadog/opentracer/scope.rb +18 -0
  158. data/lib/datadog/opentracer/scope_manager.rb +9 -0
  159. data/lib/datadog/opentracer/span.rb +101 -0
  160. data/lib/datadog/opentracer/span_context.rb +19 -0
  161. data/lib/datadog/opentracer/span_context_factory.rb +27 -0
  162. data/lib/datadog/opentracer/text_map_propagator.rb +87 -0
  163. data/lib/datadog/opentracer/thread_local_scope.rb +34 -0
  164. data/lib/datadog/opentracer/thread_local_scope_manager.rb +43 -0
  165. data/lib/datadog/opentracer/tracer.rb +214 -0
  166. data/lib/datadog/opentracer.rb +24 -0
  167. data/lib/datadog/profiling/backtrace_location.rb +34 -0
  168. data/lib/datadog/profiling/buffer.rb +43 -0
  169. data/lib/datadog/profiling/collectors/code_provenance.rb +114 -0
  170. data/lib/datadog/profiling/collectors/stack.rb +297 -0
  171. data/lib/datadog/profiling/encoding/profile.rb +48 -0
  172. data/lib/datadog/profiling/event.rb +15 -0
  173. data/lib/datadog/profiling/events/stack.rb +82 -0
  174. data/lib/datadog/profiling/exporter.rb +25 -0
  175. data/lib/datadog/profiling/ext/forking.rb +99 -0
  176. data/lib/datadog/profiling/ext.rb +57 -0
  177. data/lib/datadog/profiling/flush.rb +69 -0
  178. data/lib/datadog/profiling/native_extension.rb +41 -0
  179. data/lib/datadog/profiling/pprof/builder.rb +127 -0
  180. data/lib/datadog/profiling/pprof/converter.rb +104 -0
  181. data/lib/datadog/profiling/pprof/message_set.rb +16 -0
  182. data/lib/datadog/profiling/pprof/payload.rb +20 -0
  183. data/lib/{ddtrace → datadog}/profiling/pprof/pprof.proto +0 -0
  184. data/lib/datadog/profiling/pprof/pprof_pb.rb +83 -0
  185. data/lib/datadog/profiling/pprof/stack_sample.rb +141 -0
  186. data/lib/datadog/profiling/pprof/string_table.rb +12 -0
  187. data/lib/datadog/profiling/pprof/template.rb +120 -0
  188. data/lib/datadog/profiling/preload.rb +5 -0
  189. data/lib/datadog/profiling/profiler.rb +34 -0
  190. data/lib/datadog/profiling/recorder.rb +117 -0
  191. data/lib/datadog/profiling/scheduler.rb +151 -0
  192. data/lib/datadog/profiling/tasks/exec.rb +50 -0
  193. data/lib/datadog/profiling/tasks/help.rb +18 -0
  194. data/lib/datadog/profiling/tasks/setup.rb +91 -0
  195. data/lib/datadog/profiling/trace_identifiers/ddtrace.rb +45 -0
  196. data/lib/datadog/profiling/trace_identifiers/helper.rb +47 -0
  197. data/lib/datadog/profiling/transport/client.rb +16 -0
  198. data/lib/datadog/profiling/transport/http/api/endpoint.rb +107 -0
  199. data/lib/datadog/profiling/transport/http/api/instance.rb +38 -0
  200. data/lib/datadog/profiling/transport/http/api/spec.rb +42 -0
  201. data/lib/datadog/profiling/transport/http/api.rb +45 -0
  202. data/lib/datadog/profiling/transport/http/builder.rb +30 -0
  203. data/lib/datadog/profiling/transport/http/client.rb +35 -0
  204. data/lib/datadog/profiling/transport/http/response.rb +23 -0
  205. data/lib/datadog/profiling/transport/http.rb +112 -0
  206. data/lib/datadog/profiling/transport/io/client.rb +29 -0
  207. data/lib/datadog/profiling/transport/io/response.rb +18 -0
  208. data/lib/datadog/profiling/transport/io.rb +32 -0
  209. data/lib/datadog/profiling/transport/parcel.rb +19 -0
  210. data/lib/datadog/profiling/transport/request.rb +17 -0
  211. data/lib/datadog/profiling/transport/response.rb +10 -0
  212. data/lib/datadog/profiling.rb +168 -0
  213. data/lib/datadog/tracing/analytics.rb +25 -0
  214. data/lib/datadog/tracing/buffer.rb +126 -0
  215. data/lib/datadog/tracing/configuration/ext.rb +51 -0
  216. data/lib/datadog/tracing/context.rb +68 -0
  217. data/lib/datadog/tracing/context_provider.rb +66 -0
  218. data/lib/datadog/tracing/contrib/action_cable/configuration/settings.rb +35 -0
  219. data/lib/datadog/tracing/contrib/action_cable/event.rb +72 -0
  220. data/lib/datadog/tracing/contrib/action_cable/events/broadcast.rb +58 -0
  221. data/lib/datadog/tracing/contrib/action_cable/events/perform_action.rb +63 -0
  222. data/lib/datadog/tracing/contrib/action_cable/events/transmit.rb +59 -0
  223. data/lib/datadog/tracing/contrib/action_cable/events.rb +37 -0
  224. data/lib/datadog/tracing/contrib/action_cable/ext.rb +32 -0
  225. data/lib/datadog/tracing/contrib/action_cable/instrumentation.rb +91 -0
  226. data/lib/datadog/tracing/contrib/action_cable/integration.rb +50 -0
  227. data/lib/datadog/tracing/contrib/action_cable/patcher.rb +31 -0
  228. data/lib/datadog/tracing/contrib/action_mailer/configuration/settings.rb +36 -0
  229. data/lib/datadog/tracing/contrib/action_mailer/event.rb +52 -0
  230. data/lib/datadog/tracing/contrib/action_mailer/events/deliver.rb +60 -0
  231. data/lib/datadog/tracing/contrib/action_mailer/events/process.rb +47 -0
  232. data/lib/datadog/tracing/contrib/action_mailer/events.rb +34 -0
  233. data/lib/datadog/tracing/contrib/action_mailer/ext.rb +33 -0
  234. data/lib/datadog/tracing/contrib/action_mailer/integration.rb +50 -0
  235. data/lib/datadog/tracing/contrib/action_mailer/patcher.rb +29 -0
  236. data/lib/datadog/tracing/contrib/action_pack/action_controller/instrumentation.rb +156 -0
  237. data/lib/datadog/tracing/contrib/action_pack/action_controller/patcher.rb +29 -0
  238. data/lib/datadog/tracing/contrib/action_pack/configuration/settings.rb +36 -0
  239. data/lib/datadog/tracing/contrib/action_pack/ext.rb +22 -0
  240. data/lib/datadog/tracing/contrib/action_pack/integration.rb +50 -0
  241. data/lib/datadog/tracing/contrib/action_pack/patcher.rb +27 -0
  242. data/lib/datadog/tracing/contrib/action_pack/utils.rb +40 -0
  243. data/lib/datadog/tracing/contrib/action_view/configuration/settings.rb +36 -0
  244. data/lib/datadog/tracing/contrib/action_view/event.rb +35 -0
  245. data/lib/datadog/tracing/contrib/action_view/events/render_partial.rb +54 -0
  246. data/lib/datadog/tracing/contrib/action_view/events/render_template.rb +57 -0
  247. data/lib/datadog/tracing/contrib/action_view/events.rb +34 -0
  248. data/lib/datadog/tracing/contrib/action_view/ext.rb +24 -0
  249. data/lib/datadog/tracing/contrib/action_view/instrumentation/partial_renderer.rb +78 -0
  250. data/lib/datadog/tracing/contrib/action_view/instrumentation/template_renderer.rb +91 -0
  251. data/lib/datadog/tracing/contrib/action_view/integration.rb +57 -0
  252. data/lib/datadog/tracing/contrib/action_view/patcher.rb +48 -0
  253. data/lib/datadog/tracing/contrib/action_view/utils.rb +36 -0
  254. data/lib/datadog/tracing/contrib/active_job/configuration/settings.rb +37 -0
  255. data/lib/datadog/tracing/contrib/active_job/event.rb +58 -0
  256. data/lib/datadog/tracing/contrib/active_job/events/discard.rb +50 -0
  257. data/lib/datadog/tracing/contrib/active_job/events/enqueue.rb +49 -0
  258. data/lib/datadog/tracing/contrib/active_job/events/enqueue_at.rb +49 -0
  259. data/lib/datadog/tracing/contrib/active_job/events/enqueue_retry.rb +51 -0
  260. data/lib/datadog/tracing/contrib/active_job/events/perform.rb +49 -0
  261. data/lib/datadog/tracing/contrib/active_job/events/retry_stopped.rb +50 -0
  262. data/lib/datadog/tracing/contrib/active_job/events.rb +42 -0
  263. data/lib/datadog/tracing/contrib/active_job/ext.rb +39 -0
  264. data/lib/datadog/tracing/contrib/active_job/integration.rb +50 -0
  265. data/lib/datadog/tracing/contrib/active_job/log_injection.rb +26 -0
  266. data/lib/datadog/tracing/contrib/active_job/patcher.rb +36 -0
  267. data/lib/datadog/tracing/contrib/active_model_serializers/configuration/settings.rb +33 -0
  268. data/lib/datadog/tracing/contrib/active_model_serializers/event.rb +69 -0
  269. data/lib/datadog/tracing/contrib/active_model_serializers/events/render.rb +45 -0
  270. data/lib/datadog/tracing/contrib/active_model_serializers/events/serialize.rb +47 -0
  271. data/lib/datadog/tracing/contrib/active_model_serializers/events.rb +34 -0
  272. data/lib/datadog/tracing/contrib/active_model_serializers/ext.rb +24 -0
  273. data/lib/datadog/tracing/contrib/active_model_serializers/integration.rb +45 -0
  274. data/lib/datadog/tracing/contrib/active_model_serializers/patcher.rb +33 -0
  275. data/lib/datadog/tracing/contrib/active_record/configuration/makara_resolver.rb +36 -0
  276. data/lib/datadog/tracing/contrib/active_record/configuration/resolver.rb +138 -0
  277. data/lib/datadog/tracing/contrib/active_record/configuration/settings.rb +39 -0
  278. data/lib/datadog/tracing/contrib/active_record/event.rb +30 -0
  279. data/lib/datadog/tracing/contrib/active_record/events/instantiation.rb +58 -0
  280. data/lib/datadog/tracing/contrib/active_record/events/sql.rb +78 -0
  281. data/lib/datadog/tracing/contrib/active_record/events.rb +34 -0
  282. data/lib/datadog/tracing/contrib/active_record/ext.rb +29 -0
  283. data/lib/datadog/tracing/contrib/active_record/integration.rb +56 -0
  284. data/lib/datadog/tracing/contrib/active_record/patcher.rb +27 -0
  285. data/lib/datadog/tracing/contrib/active_record/utils.rb +128 -0
  286. data/lib/{ddtrace/vendor/active_record → datadog/tracing/contrib/active_record/vendor}/MIT-LICENSE +0 -0
  287. data/lib/datadog/tracing/contrib/active_record/vendor/connection_specification.rb +307 -0
  288. data/lib/datadog/tracing/contrib/active_support/cache/instrumentation.rb +270 -0
  289. data/lib/datadog/tracing/contrib/active_support/cache/patcher.rb +73 -0
  290. data/lib/datadog/tracing/contrib/active_support/cache/redis.rb +47 -0
  291. data/lib/datadog/tracing/contrib/active_support/configuration/settings.rb +35 -0
  292. data/lib/datadog/tracing/contrib/active_support/ext.rb +31 -0
  293. data/lib/datadog/tracing/contrib/active_support/integration.rb +51 -0
  294. data/lib/datadog/tracing/contrib/active_support/notifications/event.rb +71 -0
  295. data/lib/datadog/tracing/contrib/active_support/notifications/subscriber.rb +71 -0
  296. data/lib/datadog/tracing/contrib/active_support/notifications/subscription.rb +162 -0
  297. data/lib/datadog/tracing/contrib/active_support/patcher.rb +27 -0
  298. data/lib/datadog/tracing/contrib/analytics.rb +29 -0
  299. data/lib/datadog/tracing/contrib/auto_instrument.rb +53 -0
  300. data/lib/datadog/tracing/contrib/aws/configuration/settings.rb +35 -0
  301. data/lib/datadog/tracing/contrib/aws/ext.rb +27 -0
  302. data/lib/datadog/tracing/contrib/aws/instrumentation.rb +95 -0
  303. data/lib/datadog/tracing/contrib/aws/integration.rb +47 -0
  304. data/lib/datadog/tracing/contrib/aws/parsed_context.rb +60 -0
  305. data/lib/datadog/tracing/contrib/aws/patcher.rb +57 -0
  306. data/lib/datadog/tracing/contrib/aws/services.rb +123 -0
  307. data/lib/datadog/tracing/contrib/concurrent_ruby/configuration/settings.rb +23 -0
  308. data/lib/datadog/tracing/contrib/concurrent_ruby/context_composite_executor_service.rb +46 -0
  309. data/lib/datadog/tracing/contrib/concurrent_ruby/ext.rb +16 -0
  310. data/lib/datadog/tracing/contrib/concurrent_ruby/future_patch.rb +27 -0
  311. data/lib/datadog/tracing/contrib/concurrent_ruby/integration.rb +43 -0
  312. data/lib/datadog/tracing/contrib/concurrent_ruby/patcher.rb +33 -0
  313. data/lib/datadog/tracing/contrib/configurable.rb +102 -0
  314. data/lib/datadog/tracing/contrib/configuration/resolver.rb +85 -0
  315. data/lib/datadog/tracing/contrib/configuration/resolvers/pattern_resolver.rb +43 -0
  316. data/lib/datadog/tracing/contrib/configuration/settings.rb +43 -0
  317. data/lib/datadog/tracing/contrib/dalli/configuration/settings.rb +35 -0
  318. data/lib/datadog/tracing/contrib/dalli/ext.rb +24 -0
  319. data/lib/datadog/tracing/contrib/dalli/instrumentation.rb +58 -0
  320. data/lib/datadog/tracing/contrib/dalli/integration.rb +52 -0
  321. data/lib/datadog/tracing/contrib/dalli/patcher.rb +29 -0
  322. data/lib/datadog/tracing/contrib/dalli/quantize.rb +26 -0
  323. data/lib/datadog/tracing/contrib/delayed_job/configuration/settings.rb +38 -0
  324. data/lib/datadog/tracing/contrib/delayed_job/ext.rb +26 -0
  325. data/lib/datadog/tracing/contrib/delayed_job/integration.rb +43 -0
  326. data/lib/datadog/tracing/contrib/delayed_job/patcher.rb +32 -0
  327. data/lib/datadog/tracing/contrib/delayed_job/plugin.rb +101 -0
  328. data/lib/datadog/tracing/contrib/elasticsearch/configuration/settings.rb +36 -0
  329. data/lib/datadog/tracing/contrib/elasticsearch/ext.rb +26 -0
  330. data/lib/datadog/tracing/contrib/elasticsearch/integration.rb +44 -0
  331. data/lib/datadog/tracing/contrib/elasticsearch/patcher.rb +115 -0
  332. data/lib/datadog/tracing/contrib/elasticsearch/quantize.rb +89 -0
  333. data/lib/datadog/tracing/contrib/ethon/configuration/settings.rb +37 -0
  334. data/lib/datadog/tracing/contrib/ethon/easy_patch.rb +177 -0
  335. data/lib/datadog/tracing/contrib/ethon/ext.rb +24 -0
  336. data/lib/datadog/tracing/contrib/ethon/integration.rb +48 -0
  337. data/lib/datadog/tracing/contrib/ethon/multi_patch.rb +96 -0
  338. data/lib/datadog/tracing/contrib/ethon/patcher.rb +32 -0
  339. data/lib/datadog/tracing/contrib/excon/configuration/settings.rb +38 -0
  340. data/lib/datadog/tracing/contrib/excon/ext.rb +21 -0
  341. data/lib/datadog/tracing/contrib/excon/integration.rb +48 -0
  342. data/lib/datadog/tracing/contrib/excon/middleware.rb +170 -0
  343. data/lib/datadog/tracing/contrib/excon/patcher.rb +31 -0
  344. data/lib/datadog/tracing/contrib/extensions.rb +199 -0
  345. data/lib/datadog/tracing/contrib/faraday/configuration/settings.rb +42 -0
  346. data/lib/datadog/tracing/contrib/faraday/connection.rb +22 -0
  347. data/lib/datadog/tracing/contrib/faraday/ext.rb +21 -0
  348. data/lib/datadog/tracing/contrib/faraday/integration.rb +48 -0
  349. data/lib/datadog/tracing/contrib/faraday/middleware.rb +93 -0
  350. data/lib/datadog/tracing/contrib/faraday/patcher.rb +57 -0
  351. data/lib/datadog/tracing/contrib/faraday/rack_builder.rb +22 -0
  352. data/lib/datadog/tracing/contrib/grape/configuration/settings.rb +42 -0
  353. data/lib/datadog/tracing/contrib/grape/endpoint.rb +253 -0
  354. data/lib/datadog/tracing/contrib/grape/ext.rb +28 -0
  355. data/lib/datadog/tracing/contrib/grape/instrumentation.rb +37 -0
  356. data/lib/datadog/tracing/contrib/grape/integration.rb +44 -0
  357. data/lib/datadog/tracing/contrib/grape/patcher.rb +34 -0
  358. data/lib/datadog/tracing/contrib/graphql/configuration/settings.rb +36 -0
  359. data/lib/datadog/tracing/contrib/graphql/ext.rb +19 -0
  360. data/lib/datadog/tracing/contrib/graphql/integration.rb +44 -0
  361. data/lib/datadog/tracing/contrib/graphql/patcher.rb +92 -0
  362. data/lib/datadog/tracing/contrib/grpc/configuration/settings.rb +37 -0
  363. data/lib/datadog/tracing/contrib/grpc/datadog_interceptor/client.rb +84 -0
  364. data/lib/datadog/tracing/contrib/grpc/datadog_interceptor/server.rb +90 -0
  365. data/lib/datadog/tracing/contrib/grpc/datadog_interceptor.rb +104 -0
  366. data/lib/datadog/tracing/contrib/grpc/ext.rb +23 -0
  367. data/lib/datadog/tracing/contrib/grpc/integration.rb +43 -0
  368. data/lib/datadog/tracing/contrib/grpc/intercept_with_datadog.rb +53 -0
  369. data/lib/datadog/tracing/contrib/grpc/patcher.rb +38 -0
  370. data/lib/datadog/tracing/contrib/http/circuit_breaker.rb +44 -0
  371. data/lib/datadog/tracing/contrib/http/configuration/settings.rb +37 -0
  372. data/lib/datadog/tracing/contrib/http/ext.rb +21 -0
  373. data/lib/datadog/tracing/contrib/http/instrumentation.rb +139 -0
  374. data/lib/datadog/tracing/contrib/http/integration.rb +49 -0
  375. data/lib/datadog/tracing/contrib/http/patcher.rb +30 -0
  376. data/lib/datadog/tracing/contrib/http_annotation_helper.rb +17 -0
  377. data/lib/datadog/tracing/contrib/httpclient/configuration/settings.rb +37 -0
  378. data/lib/datadog/tracing/contrib/httpclient/ext.rb +21 -0
  379. data/lib/datadog/tracing/contrib/httpclient/instrumentation.rb +117 -0
  380. data/lib/datadog/tracing/contrib/httpclient/integration.rb +48 -0
  381. data/lib/datadog/tracing/contrib/httpclient/patcher.rb +42 -0
  382. data/lib/datadog/tracing/contrib/httprb/configuration/settings.rb +37 -0
  383. data/lib/datadog/tracing/contrib/httprb/ext.rb +21 -0
  384. data/lib/datadog/tracing/contrib/httprb/instrumentation.rb +128 -0
  385. data/lib/datadog/tracing/contrib/httprb/integration.rb +48 -0
  386. data/lib/datadog/tracing/contrib/httprb/patcher.rb +42 -0
  387. data/lib/datadog/tracing/contrib/integration.rb +78 -0
  388. data/lib/datadog/tracing/contrib/kafka/configuration/settings.rb +35 -0
  389. data/lib/datadog/tracing/contrib/kafka/consumer_event.rb +18 -0
  390. data/lib/datadog/tracing/contrib/kafka/consumer_group_event.rb +18 -0
  391. data/lib/datadog/tracing/contrib/kafka/event.rb +52 -0
  392. data/lib/datadog/tracing/contrib/kafka/events/connection/request.rb +42 -0
  393. data/lib/datadog/tracing/contrib/kafka/events/consumer/process_batch.rb +49 -0
  394. data/lib/datadog/tracing/contrib/kafka/events/consumer/process_message.rb +47 -0
  395. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/heartbeat.rb +47 -0
  396. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/join_group.rb +37 -0
  397. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/leave_group.rb +37 -0
  398. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/sync_group.rb +37 -0
  399. data/lib/datadog/tracing/contrib/kafka/events/produce_operation/send_messages.rb +40 -0
  400. data/lib/datadog/tracing/contrib/kafka/events/producer/deliver_messages.rb +43 -0
  401. data/lib/datadog/tracing/contrib/kafka/events.rb +48 -0
  402. data/lib/datadog/tracing/contrib/kafka/ext.rb +52 -0
  403. data/lib/datadog/tracing/contrib/kafka/integration.rb +44 -0
  404. data/lib/datadog/tracing/contrib/kafka/patcher.rb +30 -0
  405. data/lib/datadog/tracing/contrib/lograge/configuration/settings.rb +23 -0
  406. data/lib/datadog/tracing/contrib/lograge/ext.rb +15 -0
  407. data/lib/datadog/tracing/contrib/lograge/instrumentation.rb +46 -0
  408. data/lib/datadog/tracing/contrib/lograge/integration.rb +50 -0
  409. data/lib/datadog/tracing/contrib/lograge/patcher.rb +29 -0
  410. data/lib/datadog/tracing/contrib/mongodb/configuration/settings.rb +38 -0
  411. data/lib/datadog/tracing/contrib/mongodb/ext.rb +27 -0
  412. data/lib/datadog/tracing/contrib/mongodb/instrumentation.rb +47 -0
  413. data/lib/datadog/tracing/contrib/mongodb/integration.rb +48 -0
  414. data/lib/datadog/tracing/contrib/mongodb/parsers.rb +49 -0
  415. data/lib/datadog/tracing/contrib/mongodb/patcher.rb +34 -0
  416. data/lib/datadog/tracing/contrib/mongodb/subscribers.rb +121 -0
  417. data/lib/datadog/tracing/contrib/mysql2/configuration/settings.rb +35 -0
  418. data/lib/datadog/tracing/contrib/mysql2/ext.rb +22 -0
  419. data/lib/datadog/tracing/contrib/mysql2/instrumentation.rb +62 -0
  420. data/lib/datadog/tracing/contrib/mysql2/integration.rb +43 -0
  421. data/lib/datadog/tracing/contrib/mysql2/patcher.rb +31 -0
  422. data/lib/datadog/tracing/contrib/patchable.rb +109 -0
  423. data/lib/datadog/tracing/contrib/patcher.rb +74 -0
  424. data/lib/datadog/tracing/contrib/presto/configuration/settings.rb +35 -0
  425. data/lib/datadog/tracing/contrib/presto/ext.rb +32 -0
  426. data/lib/datadog/tracing/contrib/presto/instrumentation.rb +125 -0
  427. data/lib/datadog/tracing/contrib/presto/integration.rb +43 -0
  428. data/lib/datadog/tracing/contrib/presto/patcher.rb +37 -0
  429. data/lib/datadog/tracing/contrib/qless/configuration/settings.rb +40 -0
  430. data/lib/datadog/tracing/contrib/qless/ext.rb +26 -0
  431. data/lib/datadog/tracing/contrib/qless/integration.rb +43 -0
  432. data/lib/datadog/tracing/contrib/qless/patcher.rb +39 -0
  433. data/lib/datadog/tracing/contrib/qless/qless_job.rb +75 -0
  434. data/lib/datadog/tracing/contrib/qless/tracer_cleaner.rb +32 -0
  435. data/lib/datadog/tracing/contrib/que/configuration/settings.rb +49 -0
  436. data/lib/datadog/tracing/contrib/que/ext.rb +34 -0
  437. data/lib/datadog/tracing/contrib/que/integration.rb +46 -0
  438. data/lib/datadog/tracing/contrib/que/patcher.rb +29 -0
  439. data/lib/datadog/tracing/contrib/que/tracer.rb +61 -0
  440. data/lib/datadog/tracing/contrib/racecar/configuration/settings.rb +35 -0
  441. data/lib/datadog/tracing/contrib/racecar/event.rb +79 -0
  442. data/lib/datadog/tracing/contrib/racecar/events/batch.rb +35 -0
  443. data/lib/datadog/tracing/contrib/racecar/events/consume.rb +35 -0
  444. data/lib/datadog/tracing/contrib/racecar/events/message.rb +35 -0
  445. data/lib/datadog/tracing/contrib/racecar/events.rb +36 -0
  446. data/lib/datadog/tracing/contrib/racecar/ext.rb +31 -0
  447. data/lib/datadog/tracing/contrib/racecar/integration.rb +44 -0
  448. data/lib/datadog/tracing/contrib/racecar/patcher.rb +30 -0
  449. data/lib/datadog/tracing/contrib/rack/configuration/settings.rb +51 -0
  450. data/lib/datadog/tracing/contrib/rack/ext.rb +25 -0
  451. data/lib/datadog/tracing/contrib/rack/integration.rb +50 -0
  452. data/lib/datadog/tracing/contrib/rack/middlewares.rb +255 -0
  453. data/lib/datadog/tracing/contrib/rack/patcher.rb +109 -0
  454. data/lib/datadog/tracing/contrib/rack/request_queue.rb +48 -0
  455. data/lib/datadog/tracing/contrib/rails/auto_instrument_railtie.rb +12 -0
  456. data/lib/datadog/tracing/contrib/rails/configuration/settings.rb +71 -0
  457. data/lib/datadog/tracing/contrib/rails/ext.rb +19 -0
  458. data/lib/datadog/tracing/contrib/rails/framework.rb +152 -0
  459. data/lib/datadog/tracing/contrib/rails/integration.rb +49 -0
  460. data/lib/datadog/tracing/contrib/rails/log_injection.rb +47 -0
  461. data/lib/datadog/tracing/contrib/rails/middlewares.rb +47 -0
  462. data/lib/datadog/tracing/contrib/rails/patcher.rb +121 -0
  463. data/lib/datadog/tracing/contrib/rails/railtie.rb +19 -0
  464. data/lib/datadog/tracing/contrib/rails/utils.rb +28 -0
  465. data/lib/datadog/tracing/contrib/rake/configuration/settings.rb +36 -0
  466. data/lib/datadog/tracing/contrib/rake/ext.rb +26 -0
  467. data/lib/datadog/tracing/contrib/rake/instrumentation.rb +98 -0
  468. data/lib/datadog/tracing/contrib/rake/integration.rb +43 -0
  469. data/lib/datadog/tracing/contrib/rake/patcher.rb +35 -0
  470. data/lib/datadog/tracing/contrib/redis/configuration/resolver.rb +49 -0
  471. data/lib/datadog/tracing/contrib/redis/configuration/settings.rb +40 -0
  472. data/lib/datadog/tracing/contrib/redis/ext.rb +26 -0
  473. data/lib/datadog/tracing/contrib/redis/instrumentation.rb +78 -0
  474. data/lib/datadog/tracing/contrib/redis/integration.rb +47 -0
  475. data/lib/datadog/tracing/contrib/redis/patcher.rb +36 -0
  476. data/lib/datadog/tracing/contrib/redis/quantize.rb +79 -0
  477. data/lib/datadog/tracing/contrib/redis/tags.rb +54 -0
  478. data/lib/{ddtrace → datadog/tracing}/contrib/redis/vendor/LICENSE +0 -0
  479. data/lib/datadog/tracing/contrib/redis/vendor/resolver.rb +162 -0
  480. data/lib/datadog/tracing/contrib/registerable.rb +50 -0
  481. data/lib/datadog/tracing/contrib/registry.rb +52 -0
  482. data/lib/datadog/tracing/contrib/resque/configuration/settings.rb +37 -0
  483. data/lib/datadog/tracing/contrib/resque/ext.rb +21 -0
  484. data/lib/datadog/tracing/contrib/resque/integration.rb +48 -0
  485. data/lib/datadog/tracing/contrib/resque/patcher.rb +30 -0
  486. data/lib/datadog/tracing/contrib/resque/resque_job.rb +103 -0
  487. data/lib/datadog/tracing/contrib/rest_client/configuration/settings.rb +36 -0
  488. data/lib/datadog/tracing/contrib/rest_client/ext.rb +21 -0
  489. data/lib/datadog/tracing/contrib/rest_client/integration.rb +43 -0
  490. data/lib/datadog/tracing/contrib/rest_client/patcher.rb +30 -0
  491. data/lib/datadog/tracing/contrib/rest_client/request_patch.rb +105 -0
  492. data/lib/datadog/tracing/contrib/semantic_logger/configuration/settings.rb +23 -0
  493. data/lib/datadog/tracing/contrib/semantic_logger/ext.rb +15 -0
  494. data/lib/datadog/tracing/contrib/semantic_logger/instrumentation.rb +50 -0
  495. data/lib/datadog/tracing/contrib/semantic_logger/integration.rb +52 -0
  496. data/lib/datadog/tracing/contrib/semantic_logger/patcher.rb +29 -0
  497. data/lib/datadog/tracing/contrib/sequel/configuration/settings.rb +33 -0
  498. data/lib/datadog/tracing/contrib/sequel/database.rb +60 -0
  499. data/lib/datadog/tracing/contrib/sequel/dataset.rb +65 -0
  500. data/lib/datadog/tracing/contrib/sequel/ext.rb +22 -0
  501. data/lib/datadog/tracing/contrib/sequel/integration.rb +43 -0
  502. data/lib/datadog/tracing/contrib/sequel/patcher.rb +37 -0
  503. data/lib/datadog/tracing/contrib/sequel/utils.rb +87 -0
  504. data/lib/datadog/tracing/contrib/shoryuken/configuration/settings.rb +38 -0
  505. data/lib/datadog/tracing/contrib/shoryuken/ext.rb +25 -0
  506. data/lib/datadog/tracing/contrib/shoryuken/integration.rb +44 -0
  507. data/lib/datadog/tracing/contrib/shoryuken/patcher.rb +28 -0
  508. data/lib/datadog/tracing/contrib/shoryuken/tracer.rb +61 -0
  509. data/lib/datadog/tracing/contrib/sidekiq/client_tracer.rb +53 -0
  510. data/lib/datadog/tracing/contrib/sidekiq/configuration/settings.rb +43 -0
  511. data/lib/datadog/tracing/contrib/sidekiq/ext.rb +38 -0
  512. data/lib/datadog/tracing/contrib/sidekiq/integration.rb +53 -0
  513. data/lib/datadog/tracing/contrib/sidekiq/patcher.rb +71 -0
  514. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/heartbeat.rb +34 -0
  515. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/job_fetch.rb +34 -0
  516. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/scheduled_push.rb +33 -0
  517. data/lib/datadog/tracing/contrib/sidekiq/server_tracer.rb +79 -0
  518. data/lib/datadog/tracing/contrib/sidekiq/tracing.rb +44 -0
  519. data/lib/datadog/tracing/contrib/sinatra/configuration/settings.rb +43 -0
  520. data/lib/datadog/tracing/contrib/sinatra/env.rb +66 -0
  521. data/lib/datadog/tracing/contrib/sinatra/ext.rb +32 -0
  522. data/lib/datadog/tracing/contrib/sinatra/framework.rb +107 -0
  523. data/lib/datadog/tracing/contrib/sinatra/headers.rb +35 -0
  524. data/lib/datadog/tracing/contrib/sinatra/integration.rb +43 -0
  525. data/lib/datadog/tracing/contrib/sinatra/patcher.rb +77 -0
  526. data/lib/datadog/tracing/contrib/sinatra/tracer.rb +159 -0
  527. data/lib/datadog/tracing/contrib/sinatra/tracer_middleware.rb +123 -0
  528. data/lib/datadog/tracing/contrib/sneakers/configuration/settings.rb +38 -0
  529. data/lib/datadog/tracing/contrib/sneakers/ext.rb +26 -0
  530. data/lib/datadog/tracing/contrib/sneakers/integration.rb +46 -0
  531. data/lib/datadog/tracing/contrib/sneakers/patcher.rb +30 -0
  532. data/lib/datadog/tracing/contrib/sneakers/tracer.rb +58 -0
  533. data/lib/datadog/tracing/contrib/status_code_matcher.rb +75 -0
  534. data/lib/datadog/tracing/contrib/sucker_punch/configuration/settings.rb +35 -0
  535. data/lib/datadog/tracing/contrib/sucker_punch/exception_handler.rb +28 -0
  536. data/lib/datadog/tracing/contrib/sucker_punch/ext.rb +27 -0
  537. data/lib/datadog/tracing/contrib/sucker_punch/instrumentation.rb +105 -0
  538. data/lib/datadog/tracing/contrib/sucker_punch/integration.rb +43 -0
  539. data/lib/datadog/tracing/contrib/sucker_punch/patcher.rb +38 -0
  540. data/lib/datadog/tracing/contrib/utils/database.rb +31 -0
  541. data/lib/datadog/tracing/contrib/utils/quantization/hash.rb +111 -0
  542. data/lib/datadog/tracing/contrib/utils/quantization/http.rb +99 -0
  543. data/lib/datadog/tracing/contrib.rb +76 -0
  544. data/lib/datadog/tracing/correlation.rb +100 -0
  545. data/lib/datadog/tracing/distributed/headers/b3.rb +55 -0
  546. data/lib/datadog/tracing/distributed/headers/b3_single.rb +67 -0
  547. data/lib/datadog/tracing/distributed/headers/datadog.rb +52 -0
  548. data/lib/datadog/tracing/distributed/headers/ext.rb +31 -0
  549. data/lib/datadog/tracing/distributed/helpers.rb +44 -0
  550. data/lib/datadog/tracing/distributed/parser.rb +70 -0
  551. data/lib/datadog/tracing/event.rb +77 -0
  552. data/lib/datadog/tracing/flush.rb +74 -0
  553. data/lib/datadog/tracing/metadata/analytics.rb +26 -0
  554. data/lib/datadog/tracing/metadata/errors.rb +24 -0
  555. data/lib/datadog/tracing/metadata/ext.rb +151 -0
  556. data/lib/datadog/tracing/metadata/tagging.rb +110 -0
  557. data/lib/datadog/tracing/metadata.rb +20 -0
  558. data/lib/datadog/tracing/pipeline/span_filter.rb +42 -0
  559. data/lib/datadog/tracing/pipeline/span_processor.rb +39 -0
  560. data/lib/datadog/tracing/pipeline.rb +65 -0
  561. data/lib/datadog/tracing/propagation/grpc.rb +88 -0
  562. data/lib/datadog/tracing/propagation/http.rb +109 -0
  563. data/lib/datadog/tracing/runtime/metrics.rb +19 -0
  564. data/lib/datadog/tracing/sampling/all_sampler.rb +25 -0
  565. data/lib/datadog/tracing/sampling/ext.rb +27 -0
  566. data/lib/datadog/tracing/sampling/matcher.rb +68 -0
  567. data/lib/datadog/tracing/sampling/priority_sampler.rb +113 -0
  568. data/lib/datadog/tracing/sampling/rate_by_key_sampler.rb +97 -0
  569. data/lib/datadog/tracing/sampling/rate_by_service_sampler.rb +41 -0
  570. data/lib/datadog/tracing/sampling/rate_limiter.rb +185 -0
  571. data/lib/datadog/tracing/sampling/rate_sampler.rb +55 -0
  572. data/lib/datadog/tracing/sampling/rule.rb +70 -0
  573. data/lib/datadog/tracing/sampling/rule_sampler.rb +133 -0
  574. data/lib/datadog/tracing/sampling/sampler.rb +44 -0
  575. data/lib/datadog/tracing/span.rb +212 -0
  576. data/lib/datadog/tracing/span_operation.rb +521 -0
  577. data/lib/datadog/tracing/sync_writer.rb +69 -0
  578. data/lib/datadog/tracing/trace_digest.rb +60 -0
  579. data/lib/datadog/tracing/trace_operation.rb +432 -0
  580. data/lib/datadog/tracing/trace_segment.rb +207 -0
  581. data/lib/datadog/tracing/tracer.rb +505 -0
  582. data/lib/datadog/tracing/workers/trace_writer.rb +195 -0
  583. data/lib/datadog/tracing/workers.rb +125 -0
  584. data/lib/datadog/tracing/writer.rb +180 -0
  585. data/lib/datadog/tracing.rb +142 -0
  586. data/lib/ddtrace/auto_instrument.rb +6 -2
  587. data/lib/ddtrace/auto_instrument_base.rb +1 -0
  588. data/lib/ddtrace/profiling/preload.rb +2 -2
  589. data/lib/ddtrace/transport/ext.rb +35 -0
  590. data/lib/ddtrace/transport/http/adapters/net.rb +3 -2
  591. data/lib/ddtrace/transport/http/adapters/registry.rb +1 -0
  592. data/lib/ddtrace/transport/http/adapters/test.rb +1 -0
  593. data/lib/ddtrace/transport/http/adapters/unix_socket.rb +3 -2
  594. data/lib/ddtrace/transport/http/api/endpoint.rb +1 -0
  595. data/lib/ddtrace/transport/http/api/fallbacks.rb +1 -0
  596. data/lib/ddtrace/transport/http/api/instance.rb +1 -0
  597. data/lib/ddtrace/transport/http/api/map.rb +1 -0
  598. data/lib/ddtrace/transport/http/api/spec.rb +1 -0
  599. data/lib/ddtrace/transport/http/api.rb +5 -11
  600. data/lib/ddtrace/transport/http/builder.rb +3 -2
  601. data/lib/ddtrace/transport/http/client.rb +1 -0
  602. data/lib/ddtrace/transport/http/env.rb +1 -0
  603. data/lib/ddtrace/transport/http/response.rb +1 -0
  604. data/lib/ddtrace/transport/http/statistics.rb +1 -0
  605. data/lib/ddtrace/transport/http/traces.rb +3 -0
  606. data/lib/ddtrace/transport/http.rb +33 -28
  607. data/lib/ddtrace/transport/io/client.rb +1 -0
  608. data/lib/ddtrace/transport/io/response.rb +1 -0
  609. data/lib/ddtrace/transport/io/traces.rb +2 -1
  610. data/lib/ddtrace/transport/io.rb +3 -2
  611. data/lib/ddtrace/transport/parcel.rb +2 -0
  612. data/lib/ddtrace/transport/request.rb +1 -0
  613. data/lib/ddtrace/transport/response.rb +1 -0
  614. data/lib/ddtrace/transport/serializable_trace.rb +118 -0
  615. data/lib/ddtrace/transport/statistics.rb +6 -4
  616. data/lib/ddtrace/transport/trace_formatter.rb +187 -0
  617. data/lib/ddtrace/transport/traces.rb +15 -5
  618. data/lib/ddtrace/version.rb +15 -13
  619. data/lib/ddtrace.rb +8 -48
  620. metadata +565 -488
  621. data/.yardopts +0 -5
  622. data/lib/datadog/ci/context_flush.rb +0 -29
  623. data/lib/datadog/contrib.rb +0 -71
  624. data/lib/ddtrace/analytics.rb +0 -39
  625. data/lib/ddtrace/buffer.rb +0 -340
  626. data/lib/ddtrace/chunker.rb +0 -35
  627. data/lib/ddtrace/configuration/agent_settings_resolver.rb +0 -309
  628. data/lib/ddtrace/configuration/base.rb +0 -82
  629. data/lib/ddtrace/configuration/components.rb +0 -292
  630. data/lib/ddtrace/configuration/dependency_resolver.rb +0 -25
  631. data/lib/ddtrace/configuration/option.rb +0 -65
  632. data/lib/ddtrace/configuration/option_definition.rb +0 -122
  633. data/lib/ddtrace/configuration/option_definition_set.rb +0 -19
  634. data/lib/ddtrace/configuration/option_set.rb +0 -7
  635. data/lib/ddtrace/configuration/options.rb +0 -112
  636. data/lib/ddtrace/configuration/pin_setup.rb +0 -32
  637. data/lib/ddtrace/configuration/settings.rb +0 -413
  638. data/lib/ddtrace/configuration.rb +0 -195
  639. data/lib/ddtrace/context.rb +0 -334
  640. data/lib/ddtrace/context_flush.rb +0 -82
  641. data/lib/ddtrace/context_provider.rb +0 -62
  642. data/lib/ddtrace/contrib/action_cable/configuration/settings.rb +0 -31
  643. data/lib/ddtrace/contrib/action_cable/event.rb +0 -67
  644. data/lib/ddtrace/contrib/action_cable/events/broadcast.rb +0 -50
  645. data/lib/ddtrace/contrib/action_cable/events/perform_action.rb +0 -56
  646. data/lib/ddtrace/contrib/action_cable/events/transmit.rb +0 -51
  647. data/lib/ddtrace/contrib/action_cable/events.rb +0 -34
  648. data/lib/ddtrace/contrib/action_cable/ext.rb +0 -27
  649. data/lib/ddtrace/contrib/action_cable/instrumentation.rb +0 -78
  650. data/lib/ddtrace/contrib/action_cable/integration.rb +0 -46
  651. data/lib/ddtrace/contrib/action_cable/patcher.rb +0 -29
  652. data/lib/ddtrace/contrib/action_mailer/configuration/settings.rb +0 -32
  653. data/lib/ddtrace/contrib/action_mailer/event.rb +0 -50
  654. data/lib/ddtrace/contrib/action_mailer/events/deliver.rb +0 -54
  655. data/lib/ddtrace/contrib/action_mailer/events/process.rb +0 -41
  656. data/lib/ddtrace/contrib/action_mailer/events.rb +0 -31
  657. data/lib/ddtrace/contrib/action_mailer/ext.rb +0 -32
  658. data/lib/ddtrace/contrib/action_mailer/integration.rb +0 -45
  659. data/lib/ddtrace/contrib/action_mailer/patcher.rb +0 -27
  660. data/lib/ddtrace/contrib/action_pack/action_controller/instrumentation.rb +0 -157
  661. data/lib/ddtrace/contrib/action_pack/action_controller/patcher.rb +0 -26
  662. data/lib/ddtrace/contrib/action_pack/configuration/settings.rb +0 -33
  663. data/lib/ddtrace/contrib/action_pack/ext.rb +0 -20
  664. data/lib/ddtrace/contrib/action_pack/integration.rb +0 -46
  665. data/lib/ddtrace/contrib/action_pack/patcher.rb +0 -24
  666. data/lib/ddtrace/contrib/action_pack/utils.rb +0 -37
  667. data/lib/ddtrace/contrib/action_view/configuration/settings.rb +0 -32
  668. data/lib/ddtrace/contrib/action_view/event.rb +0 -36
  669. data/lib/ddtrace/contrib/action_view/events/render_partial.rb +0 -47
  670. data/lib/ddtrace/contrib/action_view/events/render_template.rb +0 -50
  671. data/lib/ddtrace/contrib/action_view/events.rb +0 -31
  672. data/lib/ddtrace/contrib/action_view/ext.rb +0 -21
  673. data/lib/ddtrace/contrib/action_view/instrumentation/partial_renderer.rb +0 -75
  674. data/lib/ddtrace/contrib/action_view/instrumentation/template_renderer.rb +0 -168
  675. data/lib/ddtrace/contrib/action_view/integration.rb +0 -53
  676. data/lib/ddtrace/contrib/action_view/patcher.rb +0 -48
  677. data/lib/ddtrace/contrib/action_view/utils.rb +0 -33
  678. data/lib/ddtrace/contrib/active_job/configuration/settings.rb +0 -33
  679. data/lib/ddtrace/contrib/active_job/event.rb +0 -54
  680. data/lib/ddtrace/contrib/active_job/events/discard.rb +0 -46
  681. data/lib/ddtrace/contrib/active_job/events/enqueue.rb +0 -45
  682. data/lib/ddtrace/contrib/active_job/events/enqueue_at.rb +0 -45
  683. data/lib/ddtrace/contrib/active_job/events/enqueue_retry.rb +0 -47
  684. data/lib/ddtrace/contrib/active_job/events/perform.rb +0 -45
  685. data/lib/ddtrace/contrib/active_job/events/retry_stopped.rb +0 -46
  686. data/lib/ddtrace/contrib/active_job/events.rb +0 -39
  687. data/lib/ddtrace/contrib/active_job/ext.rb +0 -32
  688. data/lib/ddtrace/contrib/active_job/integration.rb +0 -46
  689. data/lib/ddtrace/contrib/active_job/log_injection.rb +0 -21
  690. data/lib/ddtrace/contrib/active_job/patcher.rb +0 -33
  691. data/lib/ddtrace/contrib/active_model_serializers/configuration/settings.rb +0 -31
  692. data/lib/ddtrace/contrib/active_model_serializers/event.rb +0 -69
  693. data/lib/ddtrace/contrib/active_model_serializers/events/render.rb +0 -33
  694. data/lib/ddtrace/contrib/active_model_serializers/events/serialize.rb +0 -36
  695. data/lib/ddtrace/contrib/active_model_serializers/events.rb +0 -31
  696. data/lib/ddtrace/contrib/active_model_serializers/ext.rb +0 -21
  697. data/lib/ddtrace/contrib/active_model_serializers/integration.rb +0 -41
  698. data/lib/ddtrace/contrib/active_model_serializers/patcher.rb +0 -30
  699. data/lib/ddtrace/contrib/active_record/configuration/makara_resolver.rb +0 -31
  700. data/lib/ddtrace/contrib/active_record/configuration/resolver.rb +0 -135
  701. data/lib/ddtrace/contrib/active_record/configuration/settings.rb +0 -36
  702. data/lib/ddtrace/contrib/active_record/event.rb +0 -31
  703. data/lib/ddtrace/contrib/active_record/events/instantiation.rb +0 -61
  704. data/lib/ddtrace/contrib/active_record/events/sql.rb +0 -69
  705. data/lib/ddtrace/contrib/active_record/events.rb +0 -31
  706. data/lib/ddtrace/contrib/active_record/ext.rb +0 -25
  707. data/lib/ddtrace/contrib/active_record/integration.rb +0 -54
  708. data/lib/ddtrace/contrib/active_record/patcher.rb +0 -24
  709. data/lib/ddtrace/contrib/active_record/utils.rb +0 -124
  710. data/lib/ddtrace/contrib/active_support/cache/instrumentation.rb +0 -259
  711. data/lib/ddtrace/contrib/active_support/cache/patcher.rb +0 -70
  712. data/lib/ddtrace/contrib/active_support/cache/redis.rb +0 -44
  713. data/lib/ddtrace/contrib/active_support/configuration/settings.rb +0 -31
  714. data/lib/ddtrace/contrib/active_support/ext.rb +0 -28
  715. data/lib/ddtrace/contrib/active_support/integration.rb +0 -47
  716. data/lib/ddtrace/contrib/active_support/notifications/event.rb +0 -76
  717. data/lib/ddtrace/contrib/active_support/notifications/subscriber.rb +0 -68
  718. data/lib/ddtrace/contrib/active_support/notifications/subscription.rb +0 -164
  719. data/lib/ddtrace/contrib/active_support/patcher.rb +0 -24
  720. data/lib/ddtrace/contrib/analytics.rb +0 -25
  721. data/lib/ddtrace/contrib/auto_instrument.rb +0 -48
  722. data/lib/ddtrace/contrib/aws/configuration/settings.rb +0 -31
  723. data/lib/ddtrace/contrib/aws/ext.rb +0 -24
  724. data/lib/ddtrace/contrib/aws/instrumentation.rb +0 -91
  725. data/lib/ddtrace/contrib/aws/integration.rb +0 -43
  726. data/lib/ddtrace/contrib/aws/parsed_context.rb +0 -57
  727. data/lib/ddtrace/contrib/aws/patcher.rb +0 -54
  728. data/lib/ddtrace/contrib/aws/services.rb +0 -119
  729. data/lib/ddtrace/contrib/concurrent_ruby/configuration/settings.rb +0 -21
  730. data/lib/ddtrace/contrib/concurrent_ruby/context_composite_executor_service.rb +0 -42
  731. data/lib/ddtrace/contrib/concurrent_ruby/ext.rb +0 -13
  732. data/lib/ddtrace/contrib/concurrent_ruby/future_patch.rb +0 -24
  733. data/lib/ddtrace/contrib/concurrent_ruby/integration.rb +0 -39
  734. data/lib/ddtrace/contrib/concurrent_ruby/patcher.rb +0 -30
  735. data/lib/ddtrace/contrib/configurable.rb +0 -103
  736. data/lib/ddtrace/contrib/configuration/resolver.rb +0 -82
  737. data/lib/ddtrace/contrib/configuration/resolvers/pattern_resolver.rb +0 -40
  738. data/lib/ddtrace/contrib/configuration/settings.rb +0 -56
  739. data/lib/ddtrace/contrib/dalli/configuration/settings.rb +0 -31
  740. data/lib/ddtrace/contrib/dalli/ext.rb +0 -21
  741. data/lib/ddtrace/contrib/dalli/instrumentation.rb +0 -55
  742. data/lib/ddtrace/contrib/dalli/integration.rb +0 -39
  743. data/lib/ddtrace/contrib/dalli/patcher.rb +0 -26
  744. data/lib/ddtrace/contrib/dalli/quantize.rb +0 -23
  745. data/lib/ddtrace/contrib/delayed_job/configuration/settings.rb +0 -33
  746. data/lib/ddtrace/contrib/delayed_job/ext.rb +0 -24
  747. data/lib/ddtrace/contrib/delayed_job/integration.rb +0 -39
  748. data/lib/ddtrace/contrib/delayed_job/patcher.rb +0 -29
  749. data/lib/ddtrace/contrib/delayed_job/plugin.rb +0 -85
  750. data/lib/ddtrace/contrib/elasticsearch/configuration/settings.rb +0 -32
  751. data/lib/ddtrace/contrib/elasticsearch/ext.rb +0 -23
  752. data/lib/ddtrace/contrib/elasticsearch/integration.rb +0 -40
  753. data/lib/ddtrace/contrib/elasticsearch/patcher.rb +0 -123
  754. data/lib/ddtrace/contrib/elasticsearch/quantize.rb +0 -84
  755. data/lib/ddtrace/contrib/ethon/configuration/settings.rb +0 -33
  756. data/lib/ddtrace/contrib/ethon/easy_patch.rb +0 -152
  757. data/lib/ddtrace/contrib/ethon/ext.rb +0 -20
  758. data/lib/ddtrace/contrib/ethon/integration.rb +0 -44
  759. data/lib/ddtrace/contrib/ethon/multi_patch.rb +0 -85
  760. data/lib/ddtrace/contrib/ethon/patcher.rb +0 -27
  761. data/lib/ddtrace/contrib/excon/configuration/settings.rb +0 -34
  762. data/lib/ddtrace/contrib/excon/ext.rb +0 -18
  763. data/lib/ddtrace/contrib/excon/integration.rb +0 -44
  764. data/lib/ddtrace/contrib/excon/middleware.rb +0 -164
  765. data/lib/ddtrace/contrib/excon/patcher.rb +0 -28
  766. data/lib/ddtrace/contrib/extensions.rb +0 -169
  767. data/lib/ddtrace/contrib/faraday/configuration/settings.rb +0 -39
  768. data/lib/ddtrace/contrib/faraday/connection.rb +0 -19
  769. data/lib/ddtrace/contrib/faraday/ext.rb +0 -18
  770. data/lib/ddtrace/contrib/faraday/integration.rb +0 -44
  771. data/lib/ddtrace/contrib/faraday/middleware.rb +0 -86
  772. data/lib/ddtrace/contrib/faraday/patcher.rb +0 -54
  773. data/lib/ddtrace/contrib/faraday/rack_builder.rb +0 -19
  774. data/lib/ddtrace/contrib/grape/configuration/settings.rb +0 -39
  775. data/lib/ddtrace/contrib/grape/endpoint.rb +0 -246
  776. data/lib/ddtrace/contrib/grape/ext.rb +0 -24
  777. data/lib/ddtrace/contrib/grape/instrumentation.rb +0 -34
  778. data/lib/ddtrace/contrib/grape/integration.rb +0 -40
  779. data/lib/ddtrace/contrib/grape/patcher.rb +0 -32
  780. data/lib/ddtrace/contrib/graphql/configuration/settings.rb +0 -33
  781. data/lib/ddtrace/contrib/graphql/ext.rb +0 -17
  782. data/lib/ddtrace/contrib/graphql/integration.rb +0 -40
  783. data/lib/ddtrace/contrib/graphql/patcher.rb +0 -61
  784. data/lib/ddtrace/contrib/grpc/configuration/settings.rb +0 -32
  785. data/lib/ddtrace/contrib/grpc/datadog_interceptor/client.rb +0 -59
  786. data/lib/ddtrace/contrib/grpc/datadog_interceptor/server.rb +0 -80
  787. data/lib/ddtrace/contrib/grpc/datadog_interceptor.rb +0 -79
  788. data/lib/ddtrace/contrib/grpc/ext.rb +0 -19
  789. data/lib/ddtrace/contrib/grpc/integration.rb +0 -39
  790. data/lib/ddtrace/contrib/grpc/intercept_with_datadog.rb +0 -50
  791. data/lib/ddtrace/contrib/grpc/patcher.rb +0 -34
  792. data/lib/ddtrace/contrib/http/circuit_breaker.rb +0 -38
  793. data/lib/ddtrace/contrib/http/configuration/settings.rb +0 -33
  794. data/lib/ddtrace/contrib/http/ext.rb +0 -18
  795. data/lib/ddtrace/contrib/http/instrumentation.rb +0 -180
  796. data/lib/ddtrace/contrib/http/integration.rb +0 -46
  797. data/lib/ddtrace/contrib/http/patcher.rb +0 -27
  798. data/lib/ddtrace/contrib/http_annotation_helper.rb +0 -11
  799. data/lib/ddtrace/contrib/httpclient/configuration/settings.rb +0 -33
  800. data/lib/ddtrace/contrib/httpclient/ext.rb +0 -18
  801. data/lib/ddtrace/contrib/httpclient/instrumentation.rb +0 -148
  802. data/lib/ddtrace/contrib/httpclient/integration.rb +0 -44
  803. data/lib/ddtrace/contrib/httpclient/patcher.rb +0 -39
  804. data/lib/ddtrace/contrib/httprb/configuration/settings.rb +0 -33
  805. data/lib/ddtrace/contrib/httprb/ext.rb +0 -18
  806. data/lib/ddtrace/contrib/httprb/instrumentation.rb +0 -158
  807. data/lib/ddtrace/contrib/httprb/integration.rb +0 -44
  808. data/lib/ddtrace/contrib/httprb/patcher.rb +0 -39
  809. data/lib/ddtrace/contrib/integration.rb +0 -17
  810. data/lib/ddtrace/contrib/kafka/configuration/settings.rb +0 -31
  811. data/lib/ddtrace/contrib/kafka/consumer_event.rb +0 -15
  812. data/lib/ddtrace/contrib/kafka/consumer_group_event.rb +0 -15
  813. data/lib/ddtrace/contrib/kafka/event.rb +0 -52
  814. data/lib/ddtrace/contrib/kafka/events/connection/request.rb +0 -35
  815. data/lib/ddtrace/contrib/kafka/events/consumer/process_batch.rb +0 -42
  816. data/lib/ddtrace/contrib/kafka/events/consumer/process_message.rb +0 -40
  817. data/lib/ddtrace/contrib/kafka/events/consumer_group/heartbeat.rb +0 -40
  818. data/lib/ddtrace/contrib/kafka/events/consumer_group/join_group.rb +0 -30
  819. data/lib/ddtrace/contrib/kafka/events/consumer_group/leave_group.rb +0 -30
  820. data/lib/ddtrace/contrib/kafka/events/consumer_group/sync_group.rb +0 -30
  821. data/lib/ddtrace/contrib/kafka/events/produce_operation/send_messages.rb +0 -33
  822. data/lib/ddtrace/contrib/kafka/events/producer/deliver_messages.rb +0 -36
  823. data/lib/ddtrace/contrib/kafka/events.rb +0 -45
  824. data/lib/ddtrace/contrib/kafka/ext.rb +0 -42
  825. data/lib/ddtrace/contrib/kafka/integration.rb +0 -40
  826. data/lib/ddtrace/contrib/kafka/patcher.rb +0 -27
  827. data/lib/ddtrace/contrib/lograge/configuration/settings.rb +0 -19
  828. data/lib/ddtrace/contrib/lograge/ext.rb +0 -11
  829. data/lib/ddtrace/contrib/lograge/instrumentation.rb +0 -39
  830. data/lib/ddtrace/contrib/lograge/integration.rb +0 -46
  831. data/lib/ddtrace/contrib/lograge/patcher.rb +0 -26
  832. data/lib/ddtrace/contrib/mongodb/configuration/settings.rb +0 -34
  833. data/lib/ddtrace/contrib/mongodb/ext.rb +0 -24
  834. data/lib/ddtrace/contrib/mongodb/instrumentation.rb +0 -70
  835. data/lib/ddtrace/contrib/mongodb/integration.rb +0 -44
  836. data/lib/ddtrace/contrib/mongodb/parsers.rb +0 -69
  837. data/lib/ddtrace/contrib/mongodb/patcher.rb +0 -32
  838. data/lib/ddtrace/contrib/mongodb/subscribers.rb +0 -112
  839. data/lib/ddtrace/contrib/mysql2/configuration/settings.rb +0 -31
  840. data/lib/ddtrace/contrib/mysql2/ext.rb +0 -19
  841. data/lib/ddtrace/contrib/mysql2/instrumentation.rb +0 -65
  842. data/lib/ddtrace/contrib/mysql2/integration.rb +0 -39
  843. data/lib/ddtrace/contrib/mysql2/patcher.rb +0 -28
  844. data/lib/ddtrace/contrib/patchable.rb +0 -71
  845. data/lib/ddtrace/contrib/patcher.rb +0 -66
  846. data/lib/ddtrace/contrib/presto/configuration/settings.rb +0 -31
  847. data/lib/ddtrace/contrib/presto/ext.rb +0 -29
  848. data/lib/ddtrace/contrib/presto/instrumentation.rb +0 -111
  849. data/lib/ddtrace/contrib/presto/integration.rb +0 -39
  850. data/lib/ddtrace/contrib/presto/patcher.rb +0 -34
  851. data/lib/ddtrace/contrib/qless/configuration/settings.rb +0 -36
  852. data/lib/ddtrace/contrib/qless/ext.rb +0 -21
  853. data/lib/ddtrace/contrib/qless/integration.rb +0 -39
  854. data/lib/ddtrace/contrib/qless/patcher.rb +0 -35
  855. data/lib/ddtrace/contrib/qless/qless_job.rb +0 -74
  856. data/lib/ddtrace/contrib/qless/tracer_cleaner.rb +0 -34
  857. data/lib/ddtrace/contrib/que/configuration/settings.rb +0 -44
  858. data/lib/ddtrace/contrib/que/ext.rb +0 -31
  859. data/lib/ddtrace/contrib/que/integration.rb +0 -43
  860. data/lib/ddtrace/contrib/que/patcher.rb +0 -25
  861. data/lib/ddtrace/contrib/que/tracer.rb +0 -58
  862. data/lib/ddtrace/contrib/racecar/configuration/settings.rb +0 -31
  863. data/lib/ddtrace/contrib/racecar/event.rb +0 -77
  864. data/lib/ddtrace/contrib/racecar/events/batch.rb +0 -28
  865. data/lib/ddtrace/contrib/racecar/events/consume.rb +0 -28
  866. data/lib/ddtrace/contrib/racecar/events/message.rb +0 -28
  867. data/lib/ddtrace/contrib/racecar/events.rb +0 -33
  868. data/lib/ddtrace/contrib/racecar/ext.rb +0 -26
  869. data/lib/ddtrace/contrib/racecar/integration.rb +0 -40
  870. data/lib/ddtrace/contrib/racecar/patcher.rb +0 -27
  871. data/lib/ddtrace/contrib/rack/configuration/settings.rb +0 -47
  872. data/lib/ddtrace/contrib/rack/ext.rb +0 -22
  873. data/lib/ddtrace/contrib/rack/integration.rb +0 -46
  874. data/lib/ddtrace/contrib/rack/middlewares.rb +0 -288
  875. data/lib/ddtrace/contrib/rack/patcher.rb +0 -106
  876. data/lib/ddtrace/contrib/rack/request_queue.rb +0 -45
  877. data/lib/ddtrace/contrib/rails/auto_instrument_railtie.rb +0 -10
  878. data/lib/ddtrace/contrib/rails/configuration/settings.rb +0 -101
  879. data/lib/ddtrace/contrib/rails/ext.rb +0 -18
  880. data/lib/ddtrace/contrib/rails/framework.rb +0 -172
  881. data/lib/ddtrace/contrib/rails/integration.rb +0 -45
  882. data/lib/ddtrace/contrib/rails/log_injection.rb +0 -42
  883. data/lib/ddtrace/contrib/rails/middlewares.rb +0 -44
  884. data/lib/ddtrace/contrib/rails/patcher.rb +0 -119
  885. data/lib/ddtrace/contrib/rails/railtie.rb +0 -18
  886. data/lib/ddtrace/contrib/rails/utils.rb +0 -25
  887. data/lib/ddtrace/contrib/rake/configuration/settings.rb +0 -32
  888. data/lib/ddtrace/contrib/rake/ext.rb +0 -22
  889. data/lib/ddtrace/contrib/rake/instrumentation.rb +0 -91
  890. data/lib/ddtrace/contrib/rake/integration.rb +0 -39
  891. data/lib/ddtrace/contrib/rake/patcher.rb +0 -31
  892. data/lib/ddtrace/contrib/redis/configuration/resolver.rb +0 -46
  893. data/lib/ddtrace/contrib/redis/configuration/settings.rb +0 -36
  894. data/lib/ddtrace/contrib/redis/ext.rb +0 -23
  895. data/lib/ddtrace/contrib/redis/instrumentation.rb +0 -90
  896. data/lib/ddtrace/contrib/redis/integration.rb +0 -43
  897. data/lib/ddtrace/contrib/redis/patcher.rb +0 -33
  898. data/lib/ddtrace/contrib/redis/quantize.rb +0 -76
  899. data/lib/ddtrace/contrib/redis/tags.rb +0 -47
  900. data/lib/ddtrace/contrib/redis/vendor/resolver.rb +0 -159
  901. data/lib/ddtrace/contrib/registerable.rb +0 -33
  902. data/lib/ddtrace/contrib/registry.rb +0 -43
  903. data/lib/ddtrace/contrib/resque/configuration/settings.rb +0 -49
  904. data/lib/ddtrace/contrib/resque/ext.rb +0 -18
  905. data/lib/ddtrace/contrib/resque/integration.rb +0 -44
  906. data/lib/ddtrace/contrib/resque/patcher.rb +0 -30
  907. data/lib/ddtrace/contrib/resque/resque_job.rb +0 -104
  908. data/lib/ddtrace/contrib/rest_client/configuration/settings.rb +0 -32
  909. data/lib/ddtrace/contrib/rest_client/ext.rb +0 -18
  910. data/lib/ddtrace/contrib/rest_client/integration.rb +0 -39
  911. data/lib/ddtrace/contrib/rest_client/patcher.rb +0 -25
  912. data/lib/ddtrace/contrib/rest_client/request_patch.rb +0 -92
  913. data/lib/ddtrace/contrib/semantic_logger/configuration/settings.rb +0 -19
  914. data/lib/ddtrace/contrib/semantic_logger/ext.rb +0 -11
  915. data/lib/ddtrace/contrib/semantic_logger/instrumentation.rb +0 -43
  916. data/lib/ddtrace/contrib/semantic_logger/integration.rb +0 -48
  917. data/lib/ddtrace/contrib/semantic_logger/patcher.rb +0 -26
  918. data/lib/ddtrace/contrib/sequel/configuration/settings.rb +0 -29
  919. data/lib/ddtrace/contrib/sequel/database.rb +0 -64
  920. data/lib/ddtrace/contrib/sequel/dataset.rb +0 -64
  921. data/lib/ddtrace/contrib/sequel/ext.rb +0 -20
  922. data/lib/ddtrace/contrib/sequel/integration.rb +0 -39
  923. data/lib/ddtrace/contrib/sequel/patcher.rb +0 -34
  924. data/lib/ddtrace/contrib/sequel/utils.rb +0 -75
  925. data/lib/ddtrace/contrib/shoryuken/configuration/settings.rb +0 -32
  926. data/lib/ddtrace/contrib/shoryuken/ext.rb +0 -22
  927. data/lib/ddtrace/contrib/shoryuken/integration.rb +0 -40
  928. data/lib/ddtrace/contrib/shoryuken/patcher.rb +0 -25
  929. data/lib/ddtrace/contrib/shoryuken/tracer.rb +0 -56
  930. data/lib/ddtrace/contrib/sidekiq/client_tracer.rb +0 -44
  931. data/lib/ddtrace/contrib/sidekiq/configuration/settings.rb +0 -38
  932. data/lib/ddtrace/contrib/sidekiq/ext.rb +0 -31
  933. data/lib/ddtrace/contrib/sidekiq/integration.rb +0 -49
  934. data/lib/ddtrace/contrib/sidekiq/patcher.rb +0 -68
  935. data/lib/ddtrace/contrib/sidekiq/server_internal_tracer/heartbeat.rb +0 -30
  936. data/lib/ddtrace/contrib/sidekiq/server_internal_tracer/job_fetch.rb +0 -30
  937. data/lib/ddtrace/contrib/sidekiq/server_internal_tracer/scheduled_push.rb +0 -29
  938. data/lib/ddtrace/contrib/sidekiq/server_tracer.rb +0 -66
  939. data/lib/ddtrace/contrib/sidekiq/tracing.rb +0 -45
  940. data/lib/ddtrace/contrib/sinatra/configuration/settings.rb +0 -40
  941. data/lib/ddtrace/contrib/sinatra/env.rb +0 -59
  942. data/lib/ddtrace/contrib/sinatra/ext.rb +0 -28
  943. data/lib/ddtrace/contrib/sinatra/headers.rb +0 -30
  944. data/lib/ddtrace/contrib/sinatra/integration.rb +0 -39
  945. data/lib/ddtrace/contrib/sinatra/patcher.rb +0 -30
  946. data/lib/ddtrace/contrib/sinatra/tracer.rb +0 -150
  947. data/lib/ddtrace/contrib/sinatra/tracer_middleware.rb +0 -112
  948. data/lib/ddtrace/contrib/sneakers/configuration/settings.rb +0 -34
  949. data/lib/ddtrace/contrib/sneakers/ext.rb +0 -23
  950. data/lib/ddtrace/contrib/sneakers/integration.rb +0 -42
  951. data/lib/ddtrace/contrib/sneakers/patcher.rb +0 -25
  952. data/lib/ddtrace/contrib/sneakers/tracer.rb +0 -54
  953. data/lib/ddtrace/contrib/status_code_matcher.rb +0 -70
  954. data/lib/ddtrace/contrib/sucker_punch/configuration/settings.rb +0 -31
  955. data/lib/ddtrace/contrib/sucker_punch/exception_handler.rb +0 -25
  956. data/lib/ddtrace/contrib/sucker_punch/ext.rb +0 -22
  957. data/lib/ddtrace/contrib/sucker_punch/instrumentation.rb +0 -89
  958. data/lib/ddtrace/contrib/sucker_punch/integration.rb +0 -39
  959. data/lib/ddtrace/contrib/sucker_punch/patcher.rb +0 -44
  960. data/lib/ddtrace/correlation.rb +0 -40
  961. data/lib/ddtrace/diagnostics/environment_logger.rb +0 -280
  962. data/lib/ddtrace/diagnostics/health.rb +0 -34
  963. data/lib/ddtrace/distributed_tracing/headers/b3.rb +0 -45
  964. data/lib/ddtrace/distributed_tracing/headers/b3_single.rb +0 -57
  965. data/lib/ddtrace/distributed_tracing/headers/datadog.rb +0 -43
  966. data/lib/ddtrace/distributed_tracing/headers/headers.rb +0 -72
  967. data/lib/ddtrace/distributed_tracing/headers/helpers.rb +0 -44
  968. data/lib/ddtrace/encoding.rb +0 -72
  969. data/lib/ddtrace/error.rb +0 -97
  970. data/lib/ddtrace/event.rb +0 -53
  971. data/lib/ddtrace/ext/analytics.rb +0 -13
  972. data/lib/ddtrace/ext/app_types.rb +0 -12
  973. data/lib/ddtrace/ext/correlation.rb +0 -12
  974. data/lib/ddtrace/ext/diagnostics.rb +0 -37
  975. data/lib/ddtrace/ext/distributed.rb +0 -40
  976. data/lib/ddtrace/ext/environment.rb +0 -24
  977. data/lib/ddtrace/ext/errors.rb +0 -11
  978. data/lib/ddtrace/ext/forced_tracing.rb +0 -26
  979. data/lib/ddtrace/ext/git.rb +0 -32
  980. data/lib/ddtrace/ext/http.rb +0 -47
  981. data/lib/ddtrace/ext/integration.rb +0 -9
  982. data/lib/ddtrace/ext/manual_tracing.rb +0 -10
  983. data/lib/ddtrace/ext/metrics.rb +0 -16
  984. data/lib/ddtrace/ext/net.rb +0 -11
  985. data/lib/ddtrace/ext/priority.rb +0 -19
  986. data/lib/ddtrace/ext/profiling.rb +0 -53
  987. data/lib/ddtrace/ext/runtime.rb +0 -25
  988. data/lib/ddtrace/ext/sampling.rb +0 -17
  989. data/lib/ddtrace/ext/sql.rb +0 -9
  990. data/lib/ddtrace/ext/test.rb +0 -9
  991. data/lib/ddtrace/ext/transport.rb +0 -32
  992. data/lib/ddtrace/forced_tracing.rb +0 -39
  993. data/lib/ddtrace/logger.rb +0 -41
  994. data/lib/ddtrace/metrics.rb +0 -282
  995. data/lib/ddtrace/opentelemetry/extensions.rb +0 -14
  996. data/lib/ddtrace/opentelemetry/span.rb +0 -34
  997. data/lib/ddtrace/opentracer/binary_propagator.rb +0 -25
  998. data/lib/ddtrace/opentracer/carrier.rb +0 -7
  999. data/lib/ddtrace/opentracer/distributed_headers.rb +0 -56
  1000. data/lib/ddtrace/opentracer/global_tracer.rb +0 -16
  1001. data/lib/ddtrace/opentracer/propagator.rb +0 -23
  1002. data/lib/ddtrace/opentracer/rack_propagator.rb +0 -61
  1003. data/lib/ddtrace/opentracer/scope.rb +0 -16
  1004. data/lib/ddtrace/opentracer/scope_manager.rb +0 -7
  1005. data/lib/ddtrace/opentracer/span.rb +0 -95
  1006. data/lib/ddtrace/opentracer/span_context.rb +0 -15
  1007. data/lib/ddtrace/opentracer/span_context_factory.rb +0 -24
  1008. data/lib/ddtrace/opentracer/text_map_propagator.rb +0 -76
  1009. data/lib/ddtrace/opentracer/thread_local_scope.rb +0 -32
  1010. data/lib/ddtrace/opentracer/thread_local_scope_manager.rb +0 -41
  1011. data/lib/ddtrace/opentracer/tracer.rb +0 -209
  1012. data/lib/ddtrace/opentracer.rb +0 -22
  1013. data/lib/ddtrace/patcher.rb +0 -69
  1014. data/lib/ddtrace/pin.rb +0 -86
  1015. data/lib/ddtrace/pipeline/span_filter.rb +0 -39
  1016. data/lib/ddtrace/pipeline/span_processor.rb +0 -21
  1017. data/lib/ddtrace/pipeline.rb +0 -47
  1018. data/lib/ddtrace/profiling/backtrace_location.rb +0 -33
  1019. data/lib/ddtrace/profiling/buffer.rb +0 -42
  1020. data/lib/ddtrace/profiling/collectors/stack.rb +0 -297
  1021. data/lib/ddtrace/profiling/encoding/profile.rb +0 -46
  1022. data/lib/ddtrace/profiling/event.rb +0 -14
  1023. data/lib/ddtrace/profiling/events/stack.rb +0 -81
  1024. data/lib/ddtrace/profiling/exporter.rb +0 -24
  1025. data/lib/ddtrace/profiling/ext/forking.rb +0 -98
  1026. data/lib/ddtrace/profiling/flush.rb +0 -44
  1027. data/lib/ddtrace/profiling/native_extension.rb +0 -40
  1028. data/lib/ddtrace/profiling/pprof/builder.rb +0 -126
  1029. data/lib/ddtrace/profiling/pprof/converter.rb +0 -103
  1030. data/lib/ddtrace/profiling/pprof/message_set.rb +0 -15
  1031. data/lib/ddtrace/profiling/pprof/payload.rb +0 -19
  1032. data/lib/ddtrace/profiling/pprof/pprof_pb.rb +0 -82
  1033. data/lib/ddtrace/profiling/pprof/stack_sample.rb +0 -140
  1034. data/lib/ddtrace/profiling/pprof/string_table.rb +0 -11
  1035. data/lib/ddtrace/profiling/pprof/template.rb +0 -119
  1036. data/lib/ddtrace/profiling/profiler.rb +0 -31
  1037. data/lib/ddtrace/profiling/recorder.rb +0 -96
  1038. data/lib/ddtrace/profiling/scheduler.rb +0 -150
  1039. data/lib/ddtrace/profiling/tasks/setup.rb +0 -90
  1040. data/lib/ddtrace/profiling/trace_identifiers/ddtrace.rb +0 -42
  1041. data/lib/ddtrace/profiling/trace_identifiers/helper.rb +0 -46
  1042. data/lib/ddtrace/profiling/transport/client.rb +0 -15
  1043. data/lib/ddtrace/profiling/transport/http/api/endpoint.rb +0 -94
  1044. data/lib/ddtrace/profiling/transport/http/api/instance.rb +0 -37
  1045. data/lib/ddtrace/profiling/transport/http/api/spec.rb +0 -41
  1046. data/lib/ddtrace/profiling/transport/http/api.rb +0 -44
  1047. data/lib/ddtrace/profiling/transport/http/builder.rb +0 -29
  1048. data/lib/ddtrace/profiling/transport/http/client.rb +0 -34
  1049. data/lib/ddtrace/profiling/transport/http/response.rb +0 -22
  1050. data/lib/ddtrace/profiling/transport/http.rb +0 -111
  1051. data/lib/ddtrace/profiling/transport/io/client.rb +0 -28
  1052. data/lib/ddtrace/profiling/transport/io/response.rb +0 -17
  1053. data/lib/ddtrace/profiling/transport/io.rb +0 -31
  1054. data/lib/ddtrace/profiling/transport/parcel.rb +0 -18
  1055. data/lib/ddtrace/profiling/transport/request.rb +0 -16
  1056. data/lib/ddtrace/profiling/transport/response.rb +0 -9
  1057. data/lib/ddtrace/profiling.rb +0 -149
  1058. data/lib/ddtrace/propagation/grpc_propagator.rb +0 -75
  1059. data/lib/ddtrace/propagation/http_propagator.rb +0 -91
  1060. data/lib/ddtrace/quantization/hash.rb +0 -104
  1061. data/lib/ddtrace/quantization/http.rb +0 -90
  1062. data/lib/ddtrace/runtime/metrics.rb +0 -135
  1063. data/lib/ddtrace/sampler.rb +0 -303
  1064. data/lib/ddtrace/sampling/matcher.rb +0 -58
  1065. data/lib/ddtrace/sampling/rate_limiter.rb +0 -177
  1066. data/lib/ddtrace/sampling/rule.rb +0 -62
  1067. data/lib/ddtrace/sampling/rule_sampler.rb +0 -133
  1068. data/lib/ddtrace/sampling.rb +0 -3
  1069. data/lib/ddtrace/span.rb +0 -445
  1070. data/lib/ddtrace/sync_writer.rb +0 -69
  1071. data/lib/ddtrace/tasks/exec.rb +0 -47
  1072. data/lib/ddtrace/tasks/help.rb +0 -15
  1073. data/lib/ddtrace/tracer.rb +0 -449
  1074. data/lib/ddtrace/utils/compression.rb +0 -28
  1075. data/lib/ddtrace/utils/database.rb +0 -26
  1076. data/lib/ddtrace/utils/forking.rb +0 -53
  1077. data/lib/ddtrace/utils/object_set.rb +0 -40
  1078. data/lib/ddtrace/utils/only_once.rb +0 -41
  1079. data/lib/ddtrace/utils/sequence.rb +0 -18
  1080. data/lib/ddtrace/utils/string_table.rb +0 -46
  1081. data/lib/ddtrace/utils/time.rb +0 -51
  1082. data/lib/ddtrace/utils.rb +0 -80
  1083. data/lib/ddtrace/vendor/active_record/connection_specification.rb +0 -302
  1084. data/lib/ddtrace/vendor/multipart-post/multipart/post/composite_read_io.rb +0 -117
  1085. data/lib/ddtrace/vendor/multipart-post/multipart/post/multipartable.rb +0 -58
  1086. data/lib/ddtrace/vendor/multipart-post/multipart/post/parts.rb +0 -136
  1087. data/lib/ddtrace/vendor/multipart-post/multipart/post/version.rb +0 -10
  1088. data/lib/ddtrace/vendor/multipart-post/multipart/post.rb +0 -9
  1089. data/lib/ddtrace/vendor/multipart-post/multipart.rb +0 -13
  1090. data/lib/ddtrace/vendor/multipart-post/net/http/post/multipart.rb +0 -33
  1091. data/lib/ddtrace/worker.rb +0 -21
  1092. data/lib/ddtrace/workers/async.rb +0 -175
  1093. data/lib/ddtrace/workers/interval_loop.rb +0 -116
  1094. data/lib/ddtrace/workers/polling.rb +0 -56
  1095. data/lib/ddtrace/workers/queue.rb +0 -41
  1096. data/lib/ddtrace/workers/runtime_metrics.rb +0 -65
  1097. data/lib/ddtrace/workers/trace_writer.rb +0 -200
  1098. data/lib/ddtrace/workers.rb +0 -123
  1099. data/lib/ddtrace/writer.rb +0 -200
@@ -0,0 +1,110 @@
1
+ # typed: false
2
+
3
+ require 'datadog/core/environment/ext'
4
+
5
+ require 'datadog/tracing/metadata/ext'
6
+
7
+ module Datadog
8
+ module Tracing
9
+ module Metadata
10
+ # Adds metadata & metric tag behavior
11
+ # @public_api
12
+ module Tagging
13
+ # This limit is for numeric tags because uint64 could end up rounded.
14
+ NUMERIC_TAG_SIZE_RANGE = (-1 << 53..1 << 53).freeze
15
+
16
+ # Some associated values should always be sent as Tags, never as Metrics, regardless
17
+ # if their value is numeric or not.
18
+ # The Datadog agent will look for these values only as Tags, not Metrics.
19
+ # @see https://github.com/DataDog/datadog-agent/blob/2ae2cdd315bcda53166dd8fa0dedcfc448087b9d/pkg/trace/stats/aggregation.go#L13-L17
20
+ ENSURE_AGENT_TAGS = {
21
+ Ext::Distributed::TAG_ORIGIN => true,
22
+ Core::Environment::Ext::TAG_VERSION => true,
23
+ Ext::HTTP::TAG_STATUS_CODE => true,
24
+ Ext::NET::TAG_HOSTNAME => true
25
+ }.freeze
26
+
27
+ # Return the tag with the given key, nil if it doesn't exist.
28
+ def get_tag(key)
29
+ meta[key] || metrics[key]
30
+ end
31
+
32
+ # Set the given key / value tag pair on the span. Keys and values
33
+ # must be strings. A valid example is:
34
+ #
35
+ # span.set_tag('http.method', request.method)
36
+ def set_tag(key, value = nil)
37
+ # Keys must be unique between tags and metrics
38
+ metrics.delete(key)
39
+
40
+ # DEV: This is necessary because the agent looks at `meta[key]`, not `metrics[key]`.
41
+ value = value.to_s if ENSURE_AGENT_TAGS[key]
42
+
43
+ # NOTE: Adding numeric tags as metrics is stop-gap support
44
+ # for numeric typed tags. Eventually they will become
45
+ # tags again.
46
+ # Any numeric that is not an integer greater than max size is logged as a metric.
47
+ # Everything else gets logged as a tag.
48
+ if value.is_a?(Numeric) && !(value.is_a?(Integer) && !NUMERIC_TAG_SIZE_RANGE.cover?(value))
49
+ set_metric(key, value)
50
+ else
51
+ # Encode strings in UTF-8 to facilitate downstream serialization
52
+ meta[Core::Utils.utf8_encode(key)] = Core::Utils.utf8_encode(value)
53
+ end
54
+ rescue StandardError => e
55
+ Datadog.logger.debug("Unable to set the tag #{key}, ignoring it. Caused by: #{e}")
56
+ end
57
+
58
+ # Sets tags from given hash, for each key in hash it sets the tag with that key
59
+ # and associated value from the hash. It is shortcut for `set_tag`. Keys and values
60
+ # of the hash must be strings. Note that nested hashes are not supported.
61
+ # A valid example is:
62
+ #
63
+ # span.set_tags({ "http.method" => "GET", "user.id" => "234" })
64
+ def set_tags(tags)
65
+ tags.each { |k, v| set_tag(k, v) }
66
+ end
67
+
68
+ # This method removes a tag for the given key.
69
+ def clear_tag(key)
70
+ meta.delete(key)
71
+ end
72
+
73
+ # Return the metric with the given key, nil if it doesn't exist.
74
+ def get_metric(key)
75
+ metrics[key] || meta[key]
76
+ end
77
+
78
+ # This method sets a tag with a floating point value for the given key. It acts
79
+ # like `set_tag()` and it simply add a tag without further processing.
80
+ def set_metric(key, value)
81
+ # Keys must be unique between tags and metrics
82
+ meta.delete(key)
83
+
84
+ # enforce that the value is a floating point number
85
+ value = Float(value)
86
+
87
+ # Encode strings in UTF-8 to facilitate downstream serialization
88
+ metrics[Core::Utils.utf8_encode(key)] = value
89
+ rescue StandardError => e
90
+ Datadog.logger.debug("Unable to set the metric #{key}, ignoring it. Caused by: #{e}")
91
+ end
92
+
93
+ # This method removes a metric for the given key. It acts like {#clear_tag}.
94
+ def clear_metric(key)
95
+ metrics.delete(key)
96
+ end
97
+
98
+ protected
99
+
100
+ def meta
101
+ @meta ||= {}
102
+ end
103
+
104
+ def metrics
105
+ @metrics ||= {}
106
+ end
107
+ end
108
+ end
109
+ end
110
+ end
@@ -0,0 +1,20 @@
1
+ # typed: true
2
+
3
+ require 'datadog/tracing/metadata/analytics'
4
+ require 'datadog/tracing/metadata/tagging'
5
+ require 'datadog/tracing/metadata/errors'
6
+
7
+ module Datadog
8
+ module Tracing
9
+ # Adds common tagging behavior
10
+ module Metadata
11
+ def self.included(base)
12
+ base.include(Metadata::Tagging)
13
+ base.include(Metadata::Errors)
14
+
15
+ # Additional extensions
16
+ base.prepend(Metadata::Analytics)
17
+ end
18
+ end
19
+ end
20
+ end
@@ -0,0 +1,42 @@
1
+ # typed: true
2
+
3
+ require 'set'
4
+ require 'datadog/tracing/pipeline/span_processor'
5
+
6
+ module Datadog
7
+ module Tracing
8
+ module Pipeline
9
+ # SpanFilter implements a processor that filters entire span subtrees
10
+ # This processor executes the configured `operation` for each {Datadog::Tracing::Span}
11
+ # in a {Datadog::Tracing::TraceSegment}.
12
+ #
13
+ # If `operation` returns a truthy value for a span, that span is kept,
14
+ # otherwise the span is removed from the trace.
15
+ #
16
+ # @public_api
17
+ class SpanFilter < SpanProcessor
18
+ # NOTE: this SpanFilter implementation only handles traces in which child spans appear
19
+ # after parent spans in the trace array. If in the future child spans can be before
20
+ # parent spans, then the code below will need to be updated.
21
+ # @!visibility private
22
+ def call(trace)
23
+ deleted = Set.new
24
+
25
+ trace.spans.delete_if do |span|
26
+ should_delete = deleted.include?(span.parent_id) || drop_it?(span)
27
+ deleted << span.id if should_delete
28
+ should_delete
29
+ end
30
+
31
+ trace
32
+ end
33
+
34
+ private
35
+
36
+ def drop_it?(span)
37
+ @operation.call(span) rescue false
38
+ end
39
+ end
40
+ end
41
+ end
42
+ end
@@ -0,0 +1,39 @@
1
+ # typed: true
2
+
3
+ module Datadog
4
+ module Tracing
5
+ module Pipeline
6
+ # This processor executes the configured `operation` for each {Datadog::Tracing::Span}
7
+ # in a {Datadog::Tracing::TraceSegment}.
8
+ #
9
+ # @public_api
10
+ class SpanProcessor
11
+ # You can either provide an `operation` object or a block to this method.
12
+ #
13
+ # Both have the same semantics as `operation`.
14
+ # `operation` is used if both `operation` and a block are present.
15
+ #
16
+ # @param [#call(Datadog::Tracing::Span)] operation a callable that can modify the span.
17
+ def initialize(operation = nil, &block)
18
+ callable = operation || block
19
+
20
+ raise(ArgumentError) unless callable.respond_to?(:call)
21
+
22
+ @operation = operation || block
23
+ end
24
+
25
+ # Invokes `operation#call` for each spans in the `trace` argument.
26
+ # @param [Datadog::Tracing::TraceSegment] trace a trace segment.
27
+ # @return [Datadog::Tracing::TraceSegment] the `trace` provided as an argument.
28
+ # @!visibility private
29
+ def call(trace)
30
+ trace.spans.each do |span|
31
+ @operation.call(span) rescue next
32
+ end
33
+
34
+ trace
35
+ end
36
+ end
37
+ end
38
+ end
39
+ end
@@ -0,0 +1,65 @@
1
+ # typed: true
2
+
3
+ require 'datadog/core'
4
+
5
+ require 'datadog/tracing/pipeline/span_filter'
6
+ require 'datadog/tracing/pipeline/span_processor'
7
+
8
+ module Datadog
9
+ module Tracing
10
+ # Modifies traces through a set of filters and processors
11
+ module Pipeline
12
+ @mutex = Mutex.new
13
+ @processors = []
14
+
15
+ # @see file:docs/GettingStarted.md#configuring-the-transport-layer Configuring the transport layer
16
+ #
17
+ # @overload before_flush(*processors)
18
+ # @param [Array<Datadog::Tracing::Pipeline::SpanProcessor>] processors a list of processors that can modify
19
+ # or filter the trace.
20
+ # @param [Array<#call(Datadog::Tracing::TraceSegment)>] processors a list of callable objects that receive a
21
+ # {Datadog::Tracing::TraceSegment} and can modify or filter the trace.
22
+ # @overload before_flush(&processor_block)
23
+ # @yield Receive a {Datadog::Tracing::TraceSegment} and can modify or filter the trace.
24
+ # @yieldparam [Datadog::Tracing::TraceSegment] trace trace object that can be modified or filtered.
25
+ # @yieldreturn [Datadog::Tracing::TraceSegment] the trace object that will be passed to the next processor. Normally
26
+ # the same `trace` parameter object should be returned.
27
+ def self.before_flush(*processors, &processor_block)
28
+ processors << processor_block if processor_block
29
+
30
+ @mutex.synchronize do
31
+ @processors.concat(processors)
32
+ end
33
+ end
34
+
35
+ def self.process!(traces)
36
+ @mutex.synchronize do
37
+ traces
38
+ .map { |trace| apply_processors!(trace) }
39
+ .compact
40
+ end
41
+ end
42
+
43
+ def self.processors=(value)
44
+ @processors = value
45
+ end
46
+
47
+ def self.apply_processors!(trace)
48
+ @processors.inject(trace) do |current_trace, processor|
49
+ next nil if current_trace.nil? || current_trace.empty?
50
+
51
+ process_result = processor.call(current_trace)
52
+ process_result && process_result.empty? ? nil : process_result
53
+ end
54
+ rescue => e
55
+ Datadog.logger.debug(
56
+ "trace dropped entirely due to `Pipeline.before_flush` error: #{e}"
57
+ )
58
+
59
+ nil
60
+ end
61
+
62
+ private_class_method :apply_processors!
63
+ end
64
+ end
65
+ end
@@ -0,0 +1,88 @@
1
+ # typed: true
2
+
3
+ require 'datadog/tracing/distributed/headers/ext'
4
+ require 'datadog/tracing/span'
5
+ require 'datadog/tracing/trace_digest'
6
+ require 'datadog/tracing/trace_operation'
7
+
8
+ module Datadog
9
+ module Tracing
10
+ module Propagation
11
+ # opentracing.io compliant methods for distributing trace headers
12
+ # between two or more distributed services. Note this is very close
13
+ # to the Propagation::HTTP; the key difference is the way gRPC handles
14
+ # header information (called "metadata") as it operates over HTTP2
15
+ module GRPC
16
+ include Distributed::Headers::Ext
17
+
18
+ def self.inject!(digest, metadata)
19
+ return if digest.nil?
20
+
21
+ digest = digest.to_digest if digest.is_a?(TraceOperation)
22
+
23
+ metadata[GRPC_METADATA_TRACE_ID] = digest.trace_id.to_s
24
+ metadata[GRPC_METADATA_PARENT_ID] = digest.span_id.to_s
25
+ metadata[GRPC_METADATA_SAMPLING_PRIORITY] = digest.trace_sampling_priority.to_s if digest.trace_sampling_priority
26
+ metadata[GRPC_METADATA_ORIGIN] = digest.trace_origin.to_s if digest.trace_origin
27
+ end
28
+
29
+ def self.extract(metadata)
30
+ metadata = Carrier.new(metadata)
31
+ return nil unless metadata.valid?
32
+
33
+ TraceDigest.new(
34
+ span_id: metadata.parent_id,
35
+ trace_id: metadata.trace_id,
36
+ trace_origin: metadata.origin,
37
+ trace_sampling_priority: metadata.sampling_priority
38
+ )
39
+ end
40
+
41
+ # opentracing.io compliant carrier object
42
+ class Carrier
43
+ include Distributed::Headers::Ext
44
+
45
+ def initialize(metadata = {})
46
+ @metadata = metadata || {}
47
+ end
48
+
49
+ def valid?
50
+ trace_id && parent_id
51
+ end
52
+
53
+ def trace_id
54
+ value = metadata_for_key(GRPC_METADATA_TRACE_ID).to_i
55
+ value if (1..Span::EXTERNAL_MAX_ID).cover? value
56
+ end
57
+
58
+ def parent_id
59
+ value = metadata_for_key(GRPC_METADATA_PARENT_ID).to_i
60
+ value if (1..Span::EXTERNAL_MAX_ID).cover? value
61
+ end
62
+
63
+ def sampling_priority
64
+ value = metadata_for_key(GRPC_METADATA_SAMPLING_PRIORITY)
65
+ value && value.to_i
66
+ end
67
+
68
+ def origin
69
+ value = metadata_for_key(GRPC_METADATA_ORIGIN)
70
+ value if value != ''
71
+ end
72
+
73
+ private
74
+
75
+ def metadata_for_key(key)
76
+ # metadata values can be arrays (multiple headers with the same key)
77
+ value = @metadata[key]
78
+ if value.is_a?(Array)
79
+ value.first
80
+ else
81
+ value
82
+ end
83
+ end
84
+ end
85
+ end
86
+ end
87
+ end
88
+ end
@@ -0,0 +1,109 @@
1
+ # typed: false
2
+
3
+ require 'datadog/core'
4
+
5
+ require 'datadog/tracing/configuration/ext'
6
+ require 'datadog/tracing/sampling/ext'
7
+ require 'datadog/tracing/distributed/headers/b3'
8
+ require 'datadog/tracing/distributed/headers/b3_single'
9
+ require 'datadog/tracing/distributed/headers/datadog'
10
+
11
+ require 'datadog/tracing/trace_digest'
12
+ require 'datadog/tracing/trace_operation'
13
+
14
+ module Datadog
15
+ module Tracing
16
+ module Propagation
17
+ # Propagation::HTTP helps extracting and injecting HTTP headers.
18
+ # @public_api
19
+ module HTTP
20
+ PROPAGATION_STYLES = {
21
+ Configuration::Ext::Distributed::PROPAGATION_STYLE_B3 => Distributed::Headers::B3,
22
+ Configuration::Ext::Distributed::PROPAGATION_STYLE_B3_SINGLE_HEADER => Distributed::Headers::B3Single,
23
+ Configuration::Ext::Distributed::PROPAGATION_STYLE_DATADOG => Distributed::Headers::Datadog
24
+ }.freeze
25
+
26
+ # inject! popolates the env with span ID, trace ID and sampling priority
27
+ def self.inject!(digest, env)
28
+ # Prevent propagation from being attempted if trace headers provided are nil.
29
+ if digest.nil?
30
+ Datadog.logger.debug(
31
+ 'Cannot inject trace headers into env to propagate over HTTP: trace headers are nil.'.freeze
32
+ )
33
+ return
34
+ end
35
+
36
+ digest = digest.to_digest if digest.is_a?(TraceOperation)
37
+
38
+ # Inject all configured propagation styles
39
+ Datadog.configuration.tracing.distributed_tracing.propagation_inject_style.each do |style|
40
+ propagator = PROPAGATION_STYLES[style]
41
+ begin
42
+ propagator.inject!(digest, env) unless propagator.nil?
43
+ rescue => e
44
+ Datadog.logger.error(
45
+ 'Error injecting propagated trace headers into the environment. ' \
46
+ "Cause: #{e} Location: #{Array(e.backtrace).first}"
47
+ )
48
+ end
49
+ end
50
+ end
51
+
52
+ # extract returns trace headers containing the span ID, trace ID and
53
+ # sampling priority defined in env.
54
+ def self.extract(env)
55
+ trace_digest = nil
56
+ dd_trace_digest = nil
57
+
58
+ Datadog.configuration.tracing.distributed_tracing.propagation_extract_style.each do |style|
59
+ propagator = PROPAGATION_STYLES[style]
60
+ next if propagator.nil?
61
+
62
+ # Extract trace headers
63
+ # DEV: `propagator.extract` will return `nil`, where `Propagation::HTTP#extract` will not
64
+ begin
65
+ extracted_trace_digest = propagator.extract(env)
66
+ rescue => e
67
+ Datadog.logger.error(
68
+ 'Error extracting propagated trace headers from the environment. ' \
69
+ "Cause: #{e} Location: #{Array(e.backtrace).first}"
70
+ )
71
+ end
72
+
73
+ # Skip this style if no valid headers were found
74
+ next if extracted_trace_digest.nil?
75
+
76
+ # Keep track of the Datadog extract trace headers, we want to return
77
+ # this one if we have one
78
+ if extracted_trace_digest && style == Configuration::Ext::Distributed::PROPAGATION_STYLE_DATADOG
79
+ dd_trace_digest = extracted_trace_digest
80
+ end
81
+
82
+ # No previously extracted trace headers, use the one we just extracted
83
+ if trace_digest.nil?
84
+ trace_digest = extracted_trace_digest
85
+ else
86
+ unless trace_digest.trace_id == extracted_trace_digest.trace_id \
87
+ && trace_digest.span_id == extracted_trace_digest.span_id
88
+ # Return an empty/new trace headers if we have a mismatch in values extracted
89
+ msg = "#{trace_digest.trace_id} != #{extracted_trace_digest.trace_id} && " \
90
+ "#{trace_digest.span_id} != #{extracted_trace_digest.span_id}"
91
+ Datadog.logger.debug(
92
+ "Cannot extract trace headers from HTTP: extracted trace headers differ, #{msg}"
93
+ )
94
+ # DEV: This will return from `self.extract` not this `each` block
95
+ return TraceDigest.new
96
+ end
97
+ end
98
+ end
99
+
100
+ # Return the extracted trace headers if we found one or else a new empty trace headers
101
+ # Always return the Datadog trace headers if one exists since it has more
102
+ # information than the B3 headers e.g. origin, expanded priority
103
+ # sampling values, etc
104
+ dd_trace_digest || trace_digest || nil
105
+ end
106
+ end
107
+ end
108
+ end
109
+ end
@@ -0,0 +1,19 @@
1
+ # typed: true
2
+
3
+ require 'datadog/core'
4
+
5
+ module Datadog
6
+ module Tracing
7
+ module Runtime
8
+ # Decorates runtime metrics feature
9
+ module Metrics
10
+ def self.associate_trace(trace)
11
+ return unless trace && !trace.empty?
12
+
13
+ # Register service as associated with metrics
14
+ Datadog.send(:components).runtime_metrics.register_service(trace.service) unless trace.service.nil?
15
+ end
16
+ end
17
+ end
18
+ end
19
+ end
@@ -0,0 +1,25 @@
1
+ # typed: true
2
+
3
+ require 'datadog/tracing/sampling/sampler'
4
+
5
+ module Datadog
6
+ module Tracing
7
+ module Sampling
8
+ # {Datadog::Tracing::Sampling::AllSampler} samples all the traces.
9
+ # @public_api
10
+ class AllSampler < Sampler
11
+ def sample?(_trace)
12
+ true
13
+ end
14
+
15
+ def sample!(trace)
16
+ trace.sampled = true
17
+ end
18
+
19
+ def sample_rate(*_)
20
+ 1.0
21
+ end
22
+ end
23
+ end
24
+ end
25
+ end
@@ -0,0 +1,27 @@
1
+ # typed: strict
2
+
3
+ module Datadog
4
+ module Tracing
5
+ module Sampling
6
+ module Ext
7
+ # Priority is a hint given to the backend so that it knows which traces to reject or kept.
8
+ # In a distributed context, it should be set before any context propagation (fork, RPC calls) to be effective.
9
+ # @public_api
10
+ module Priority
11
+ # Use this to explicitly inform the backend that a trace MUST be rejected and not stored.
12
+ # This includes rules and rate limits configured by the user
13
+ # through the {Datadog::Tracing::Sampling::RuleSampler}.
14
+ USER_REJECT = -1
15
+ # Used by the {PrioritySampler} to inform the backend that a trace should be rejected and not stored.
16
+ AUTO_REJECT = 0
17
+ # Used by the {PrioritySampler} to inform the backend that a trace should be kept and stored.
18
+ AUTO_KEEP = 1
19
+ # Use this to explicitly inform the backend that a trace MUST be kept and stored.
20
+ # This includes rules and rate limits configured by the user
21
+ # through the {Datadog::Tracing::Sampling::RuleSampler}.
22
+ USER_KEEP = 2
23
+ end
24
+ end
25
+ end
26
+ end
27
+ end
@@ -0,0 +1,68 @@
1
+ # typed: true
2
+
3
+ module Datadog
4
+ module Tracing
5
+ module Sampling
6
+ # Checks if a trace conforms to a matching criteria.
7
+ # @abstract
8
+ # @public_api
9
+ class Matcher
10
+ # Returns `true` if the trace should conforms to this rule, `false` otherwise
11
+ #
12
+ # @param [TraceOperation] trace
13
+ # @return [Boolean]
14
+ def match?(trace)
15
+ raise NotImplementedError
16
+ end
17
+ end
18
+
19
+ # A {Datadog::Sampling::Matcher} that supports matching a trace by
20
+ # trace name and/or service name.
21
+ # @public_api
22
+ class SimpleMatcher < Matcher
23
+ # Returns `true` for case equality (===) with any object
24
+ MATCH_ALL = Class.new do
25
+ # DEV: A class that implements `#===` is ~20% faster than
26
+ # DEV: a `Proc` that always returns `true`.
27
+ def ===(other)
28
+ true
29
+ end
30
+ end.new
31
+
32
+ attr_reader :name, :service
33
+
34
+ # @param name [String,Regexp,Proc] Matcher for case equality (===) with the trace name,
35
+ # defaults to always match
36
+ # @param service [String,Regexp,Proc] Matcher for case equality (===) with the service name,
37
+ # defaults to always match
38
+ def initialize(name: MATCH_ALL, service: MATCH_ALL)
39
+ super()
40
+ @name = name
41
+ @service = service
42
+ end
43
+
44
+ def match?(trace)
45
+ name === trace.name && service === trace.service
46
+ end
47
+ end
48
+
49
+ # A {Datadog::Tracing::Sampling::Matcher} that allows for arbitrary trace matching
50
+ # based on the return value of a provided block.
51
+ # @public_api
52
+ class ProcMatcher < Matcher
53
+ attr_reader :block
54
+
55
+ # @yield [name, service] Provides trace name and service to the block
56
+ # @yieldreturn [Boolean] Whether the trace conforms to this matcher
57
+ def initialize(&block)
58
+ super()
59
+ @block = block
60
+ end
61
+
62
+ def match?(trace)
63
+ block.call(trace.name, trace.service)
64
+ end
65
+ end
66
+ end
67
+ end
68
+ end