ddtrace 0.54.2 → 1.0.0.beta1

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 (1062) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +3 -0
  3. data/LICENSE-3rdparty.csv +2 -1
  4. data/README.md +4 -0
  5. data/bin/ddtracerb +5 -5
  6. data/ddtrace.gemspec +7 -4
  7. data/docs/0.x-trace.png +0 -0
  8. data/docs/1.0-trace.png +0 -0
  9. data/docs/AutoInstrumentation.md +36 -0
  10. data/docs/Deprecation.md +8 -0
  11. data/docs/DevelopmentGuide.md +1 -1
  12. data/docs/GettingStarted.md +408 -431
  13. data/docs/ProfilingDevelopment.md +12 -9
  14. data/docs/PublicApi.md +14 -0
  15. data/docs/UpgradeGuide.md +557 -0
  16. data/lib/datadog/appsec/assets/blocked.html +4 -0
  17. data/lib/datadog/appsec/assets/waf_rules/README.md +7 -0
  18. data/lib/datadog/appsec/assets/waf_rules/recommended.json +5708 -0
  19. data/lib/datadog/appsec/assets/waf_rules/risky.json +1439 -0
  20. data/lib/datadog/appsec/assets/waf_rules/strict.json +1361 -0
  21. data/lib/datadog/appsec/assets.rb +36 -0
  22. data/lib/datadog/appsec/autoload.rb +16 -0
  23. data/lib/datadog/appsec/configuration/settings.rb +173 -0
  24. data/lib/datadog/appsec/configuration.rb +70 -0
  25. data/lib/datadog/appsec/contrib/auto_instrument.rb +27 -0
  26. data/lib/datadog/appsec/contrib/configuration/settings.rb +18 -0
  27. data/lib/datadog/appsec/contrib/integration.rb +35 -0
  28. data/lib/datadog/appsec/contrib/patcher.rb +10 -0
  29. data/lib/datadog/appsec/contrib/rack/configuration/settings.rb +20 -0
  30. data/lib/datadog/appsec/contrib/rack/ext.rb +13 -0
  31. data/lib/datadog/appsec/contrib/rack/gateway/watcher.rb +128 -0
  32. data/lib/datadog/appsec/contrib/rack/integration.rb +48 -0
  33. data/lib/datadog/appsec/contrib/rack/patcher.rb +33 -0
  34. data/lib/datadog/appsec/contrib/rack/reactive/request.rb +85 -0
  35. data/lib/datadog/appsec/contrib/rack/reactive/response.rb +62 -0
  36. data/lib/datadog/appsec/contrib/rack/request.rb +43 -0
  37. data/lib/datadog/appsec/contrib/rack/request_middleware.rb +98 -0
  38. data/lib/datadog/appsec/contrib/rack/response.rb +22 -0
  39. data/lib/datadog/appsec/contrib/rails/configuration/settings.rb +20 -0
  40. data/lib/datadog/appsec/contrib/rails/ext.rb +13 -0
  41. data/lib/datadog/appsec/contrib/rails/framework.rb +28 -0
  42. data/lib/datadog/appsec/contrib/rails/integration.rb +48 -0
  43. data/lib/datadog/appsec/contrib/rails/patcher.rb +125 -0
  44. data/lib/datadog/appsec/contrib/rails/request_middleware.rb +18 -0
  45. data/lib/datadog/appsec/contrib/sinatra/configuration/settings.rb +20 -0
  46. data/lib/datadog/appsec/contrib/sinatra/ext.rb +13 -0
  47. data/lib/datadog/appsec/contrib/sinatra/framework.rb +32 -0
  48. data/lib/datadog/appsec/contrib/sinatra/integration.rb +48 -0
  49. data/lib/datadog/appsec/contrib/sinatra/patcher.rb +77 -0
  50. data/lib/datadog/appsec/contrib/sinatra/request_middleware.rb +18 -0
  51. data/lib/datadog/appsec/event.rb +111 -0
  52. data/lib/datadog/appsec/extensions.rb +120 -0
  53. data/lib/datadog/appsec/instrumentation/gateway.rb +42 -0
  54. data/lib/datadog/appsec/rate_limiter.rb +53 -0
  55. data/lib/datadog/appsec/reactive/address_hash.rb +16 -0
  56. data/lib/datadog/appsec/reactive/engine.rb +42 -0
  57. data/lib/datadog/appsec/reactive/operation.rb +50 -0
  58. data/lib/datadog/appsec/reactive/subscriber.rb +16 -0
  59. data/lib/datadog/appsec.rb +21 -0
  60. data/lib/datadog/ci/configuration/components.rb +8 -8
  61. data/lib/datadog/ci/configuration/settings.rb +12 -3
  62. data/lib/datadog/ci/contrib/cucumber/configuration/settings.rb +3 -2
  63. data/lib/datadog/ci/contrib/cucumber/ext.rb +1 -0
  64. data/lib/datadog/ci/contrib/cucumber/formatter.rb +2 -8
  65. data/lib/datadog/ci/contrib/cucumber/instrumentation.rb +1 -1
  66. data/lib/datadog/ci/contrib/cucumber/integration.rb +2 -2
  67. data/lib/datadog/ci/contrib/cucumber/patcher.rb +2 -2
  68. data/lib/datadog/ci/contrib/rspec/configuration/settings.rb +3 -2
  69. data/lib/datadog/ci/contrib/rspec/example.rb +1 -7
  70. data/lib/datadog/ci/contrib/rspec/ext.rb +1 -0
  71. data/lib/datadog/ci/contrib/rspec/integration.rb +2 -2
  72. data/lib/datadog/ci/contrib/rspec/patcher.rb +2 -2
  73. data/lib/datadog/ci/ext/app_types.rb +1 -1
  74. data/lib/datadog/ci/ext/environment.rb +105 -102
  75. data/lib/datadog/ci/ext/settings.rb +1 -1
  76. data/lib/datadog/ci/extensions.rb +4 -4
  77. data/lib/datadog/ci/flush.rb +37 -0
  78. data/lib/datadog/ci/test.rb +14 -13
  79. data/lib/datadog/ci.rb +3 -2
  80. data/lib/datadog/core/buffer/cruby.rb +54 -0
  81. data/lib/datadog/core/buffer/random.rb +134 -0
  82. data/lib/datadog/core/buffer/thread_safe.rb +57 -0
  83. data/lib/datadog/core/chunker.rb +35 -0
  84. data/lib/datadog/core/configuration/agent_settings_resolver.rb +296 -0
  85. data/lib/datadog/core/configuration/base.rb +88 -0
  86. data/lib/datadog/core/configuration/components.rb +392 -0
  87. data/lib/datadog/core/configuration/dependency_resolver.rb +27 -0
  88. data/lib/datadog/core/configuration/option.rb +68 -0
  89. data/lib/datadog/core/configuration/option_definition.rb +125 -0
  90. data/lib/datadog/core/configuration/option_definition_set.rb +21 -0
  91. data/lib/datadog/core/configuration/option_set.rb +9 -0
  92. data/lib/datadog/core/configuration/options.rb +117 -0
  93. data/lib/datadog/core/configuration/settings.rb +626 -0
  94. data/lib/datadog/core/configuration.rb +283 -0
  95. data/lib/datadog/core/diagnostics/environment_logger.rb +282 -0
  96. data/lib/datadog/core/diagnostics/ext.rb +40 -0
  97. data/lib/datadog/core/diagnostics/health.rb +36 -0
  98. data/lib/datadog/core/encoding.rb +75 -0
  99. data/lib/datadog/core/environment/ext.rb +27 -9
  100. data/lib/datadog/core/environment/identity.rb +10 -4
  101. data/lib/datadog/core/environment/socket.rb +8 -2
  102. data/lib/datadog/core/environment/variable_helpers.rb +1 -0
  103. data/lib/datadog/core/error.rb +100 -0
  104. data/lib/datadog/core/extensions.rb +15 -0
  105. data/lib/datadog/core/git/ext.rb +34 -0
  106. data/lib/datadog/core/logger.rb +45 -0
  107. data/lib/datadog/core/metrics/client.rb +187 -0
  108. data/lib/datadog/core/metrics/ext.rb +19 -0
  109. data/lib/datadog/core/metrics/helpers.rb +23 -0
  110. data/lib/datadog/core/metrics/logging.rb +42 -0
  111. data/lib/datadog/core/metrics/metric.rb +12 -0
  112. data/lib/datadog/core/metrics/options.rb +48 -0
  113. data/lib/datadog/core/pin.rb +75 -0
  114. data/lib/datadog/core/runtime/ext.rb +28 -0
  115. data/lib/datadog/core/runtime/metrics.rb +125 -0
  116. data/lib/datadog/core/utils/compression.rb +31 -0
  117. data/lib/datadog/core/utils/forking.rb +62 -0
  118. data/lib/datadog/core/utils/object_set.rb +42 -0
  119. data/lib/datadog/core/utils/only_once.rb +43 -0
  120. data/lib/datadog/core/utils/sequence.rb +20 -0
  121. data/lib/datadog/core/utils/string_table.rb +48 -0
  122. data/lib/datadog/core/utils/time.rb +53 -0
  123. data/lib/datadog/core/utils.rb +114 -0
  124. data/lib/{ddtrace → datadog/core}/vendor/multipart-post/LICENSE +0 -0
  125. data/lib/datadog/core/vendor/multipart-post/multipart/post/composite_read_io.rb +119 -0
  126. data/lib/datadog/core/vendor/multipart-post/multipart/post/multipartable.rb +60 -0
  127. data/lib/datadog/core/vendor/multipart-post/multipart/post/parts.rb +138 -0
  128. data/lib/datadog/core/vendor/multipart-post/multipart/post/version.rb +12 -0
  129. data/lib/datadog/core/vendor/multipart-post/multipart/post.rb +11 -0
  130. data/lib/datadog/core/vendor/multipart-post/multipart.rb +15 -0
  131. data/lib/datadog/core/vendor/multipart-post/net/http/post/multipart.rb +35 -0
  132. data/lib/datadog/core/worker.rb +23 -0
  133. data/lib/datadog/core/workers/async.rb +179 -0
  134. data/lib/datadog/core/workers/interval_loop.rb +118 -0
  135. data/lib/datadog/core/workers/polling.rb +58 -0
  136. data/lib/datadog/core/workers/queue.rb +43 -0
  137. data/lib/datadog/core/workers/runtime_metrics.rb +64 -0
  138. data/lib/datadog/core.rb +73 -0
  139. data/lib/datadog/opentelemetry/extensions.rb +14 -0
  140. data/lib/datadog/opentelemetry/span.rb +34 -0
  141. data/lib/{ddtrace → datadog}/opentracer/binary_propagator.rb +0 -0
  142. data/lib/datadog/opentracer/carrier.rb +8 -0
  143. data/lib/datadog/opentracer/distributed_headers.rb +57 -0
  144. data/lib/datadog/opentracer/global_tracer.rb +16 -0
  145. data/lib/datadog/opentracer/propagator.rb +25 -0
  146. data/lib/datadog/opentracer/rack_propagator.rb +71 -0
  147. data/lib/datadog/opentracer/scope.rb +17 -0
  148. data/lib/datadog/opentracer/scope_manager.rb +8 -0
  149. data/lib/datadog/opentracer/span.rb +100 -0
  150. data/lib/datadog/opentracer/span_context.rb +18 -0
  151. data/lib/datadog/opentracer/span_context_factory.rb +26 -0
  152. data/lib/datadog/opentracer/text_map_propagator.rb +86 -0
  153. data/lib/datadog/opentracer/thread_local_scope.rb +33 -0
  154. data/lib/datadog/opentracer/thread_local_scope_manager.rb +42 -0
  155. data/lib/datadog/opentracer/tracer.rb +213 -0
  156. data/lib/datadog/opentracer.rb +23 -0
  157. data/lib/{ddtrace → datadog}/profiling/backtrace_location.rb +0 -0
  158. data/lib/datadog/profiling/buffer.rb +42 -0
  159. data/lib/datadog/profiling/collectors/code_provenance.rb +113 -0
  160. data/lib/datadog/profiling/collectors/stack.rb +297 -0
  161. data/lib/datadog/profiling/encoding/profile.rb +47 -0
  162. data/lib/{ddtrace → datadog}/profiling/event.rb +0 -0
  163. data/lib/datadog/profiling/events/stack.rb +81 -0
  164. data/lib/datadog/profiling/exporter.rb +24 -0
  165. data/lib/{ddtrace → datadog}/profiling/ext/forking.rb +0 -0
  166. data/lib/datadog/profiling/ext.rb +56 -0
  167. data/lib/datadog/profiling/flush.rb +68 -0
  168. data/lib/{ddtrace → datadog}/profiling/native_extension.rb +0 -0
  169. data/lib/datadog/profiling/pprof/builder.rb +126 -0
  170. data/lib/datadog/profiling/pprof/converter.rb +103 -0
  171. data/lib/datadog/profiling/pprof/message_set.rb +15 -0
  172. data/lib/{ddtrace → datadog}/profiling/pprof/payload.rb +0 -0
  173. data/lib/{ddtrace → datadog}/profiling/pprof/pprof.proto +0 -0
  174. data/lib/datadog/profiling/pprof/pprof_pb.rb +82 -0
  175. data/lib/datadog/profiling/pprof/stack_sample.rb +140 -0
  176. data/lib/datadog/profiling/pprof/string_table.rb +11 -0
  177. data/lib/datadog/profiling/pprof/template.rb +119 -0
  178. data/lib/datadog/profiling/preload.rb +4 -0
  179. data/lib/datadog/profiling/profiler.rb +33 -0
  180. data/lib/datadog/profiling/recorder.rb +116 -0
  181. data/lib/datadog/profiling/scheduler.rb +150 -0
  182. data/lib/datadog/profiling/tasks/exec.rb +49 -0
  183. data/lib/datadog/profiling/tasks/help.rb +17 -0
  184. data/lib/datadog/profiling/tasks/setup.rb +90 -0
  185. data/lib/datadog/profiling/trace_identifiers/ddtrace.rb +44 -0
  186. data/lib/datadog/profiling/trace_identifiers/helper.rb +46 -0
  187. data/lib/{ddtrace → datadog}/profiling/transport/client.rb +0 -0
  188. data/lib/datadog/profiling/transport/http/api/endpoint.rb +106 -0
  189. data/lib/datadog/profiling/transport/http/api/instance.rb +37 -0
  190. data/lib/{ddtrace → datadog}/profiling/transport/http/api/spec.rb +0 -0
  191. data/lib/datadog/profiling/transport/http/api.rb +44 -0
  192. data/lib/datadog/profiling/transport/http/builder.rb +29 -0
  193. data/lib/datadog/profiling/transport/http/client.rb +34 -0
  194. data/lib/datadog/profiling/transport/http/response.rb +22 -0
  195. data/lib/datadog/profiling/transport/http.rb +111 -0
  196. data/lib/datadog/profiling/transport/io/client.rb +28 -0
  197. data/lib/datadog/profiling/transport/io/response.rb +17 -0
  198. data/lib/datadog/profiling/transport/io.rb +31 -0
  199. data/lib/{ddtrace → datadog}/profiling/transport/parcel.rb +0 -0
  200. data/lib/datadog/profiling/transport/request.rb +16 -0
  201. data/lib/{ddtrace → datadog}/profiling/transport/response.rb +0 -0
  202. data/lib/datadog/profiling.rb +167 -0
  203. data/lib/datadog/tracing/analytics.rb +24 -0
  204. data/lib/datadog/tracing/buffer.rb +125 -0
  205. data/lib/datadog/tracing/configuration/ext.rb +50 -0
  206. data/lib/datadog/tracing/context.rb +67 -0
  207. data/lib/datadog/tracing/context_provider.rb +67 -0
  208. data/lib/datadog/tracing/contrib/action_cable/configuration/settings.rb +34 -0
  209. data/lib/datadog/tracing/contrib/action_cable/event.rb +71 -0
  210. data/lib/datadog/tracing/contrib/action_cable/events/broadcast.rb +57 -0
  211. data/lib/datadog/tracing/contrib/action_cable/events/perform_action.rb +62 -0
  212. data/lib/datadog/tracing/contrib/action_cable/events/transmit.rb +58 -0
  213. data/lib/datadog/tracing/contrib/action_cable/events.rb +36 -0
  214. data/lib/datadog/tracing/contrib/action_cable/ext.rb +31 -0
  215. data/lib/datadog/tracing/contrib/action_cable/instrumentation.rb +91 -0
  216. data/lib/datadog/tracing/contrib/action_cable/integration.rb +49 -0
  217. data/lib/datadog/tracing/contrib/action_cable/patcher.rb +30 -0
  218. data/lib/datadog/tracing/contrib/action_mailer/configuration/settings.rb +35 -0
  219. data/lib/datadog/tracing/contrib/action_mailer/event.rb +51 -0
  220. data/lib/datadog/tracing/contrib/action_mailer/events/deliver.rb +59 -0
  221. data/lib/datadog/tracing/contrib/action_mailer/events/process.rb +46 -0
  222. data/lib/datadog/tracing/contrib/action_mailer/events.rb +33 -0
  223. data/lib/datadog/tracing/contrib/action_mailer/ext.rb +32 -0
  224. data/lib/datadog/tracing/contrib/action_mailer/integration.rb +49 -0
  225. data/lib/datadog/tracing/contrib/action_mailer/patcher.rb +28 -0
  226. data/lib/datadog/tracing/contrib/action_pack/action_controller/instrumentation.rb +155 -0
  227. data/lib/datadog/tracing/contrib/action_pack/action_controller/patcher.rb +28 -0
  228. data/lib/datadog/tracing/contrib/action_pack/configuration/settings.rb +35 -0
  229. data/lib/datadog/tracing/contrib/action_pack/ext.rb +21 -0
  230. data/lib/datadog/tracing/contrib/action_pack/integration.rb +49 -0
  231. data/lib/datadog/tracing/contrib/action_pack/patcher.rb +26 -0
  232. data/lib/datadog/tracing/contrib/action_pack/utils.rb +39 -0
  233. data/lib/datadog/tracing/contrib/action_view/configuration/settings.rb +35 -0
  234. data/lib/datadog/tracing/contrib/action_view/event.rb +34 -0
  235. data/lib/datadog/tracing/contrib/action_view/events/render_partial.rb +53 -0
  236. data/lib/datadog/tracing/contrib/action_view/events/render_template.rb +56 -0
  237. data/lib/datadog/tracing/contrib/action_view/events.rb +33 -0
  238. data/lib/datadog/tracing/contrib/action_view/ext.rb +23 -0
  239. data/lib/datadog/tracing/contrib/action_view/instrumentation/partial_renderer.rb +77 -0
  240. data/lib/datadog/tracing/contrib/action_view/instrumentation/template_renderer.rb +90 -0
  241. data/lib/datadog/tracing/contrib/action_view/integration.rb +56 -0
  242. data/lib/datadog/tracing/contrib/action_view/patcher.rb +47 -0
  243. data/lib/datadog/tracing/contrib/action_view/utils.rb +35 -0
  244. data/lib/datadog/tracing/contrib/active_job/configuration/settings.rb +36 -0
  245. data/lib/datadog/tracing/contrib/active_job/event.rb +57 -0
  246. data/lib/datadog/tracing/contrib/active_job/events/discard.rb +49 -0
  247. data/lib/datadog/tracing/contrib/active_job/events/enqueue.rb +48 -0
  248. data/lib/datadog/tracing/contrib/active_job/events/enqueue_at.rb +48 -0
  249. data/lib/datadog/tracing/contrib/active_job/events/enqueue_retry.rb +50 -0
  250. data/lib/datadog/tracing/contrib/active_job/events/perform.rb +48 -0
  251. data/lib/datadog/tracing/contrib/active_job/events/retry_stopped.rb +49 -0
  252. data/lib/datadog/tracing/contrib/active_job/events.rb +41 -0
  253. data/lib/datadog/tracing/contrib/active_job/ext.rb +38 -0
  254. data/lib/datadog/tracing/contrib/active_job/integration.rb +49 -0
  255. data/lib/datadog/tracing/contrib/active_job/log_injection.rb +25 -0
  256. data/lib/datadog/tracing/contrib/active_job/patcher.rb +35 -0
  257. data/lib/datadog/tracing/contrib/active_model_serializers/configuration/settings.rb +32 -0
  258. data/lib/datadog/tracing/contrib/active_model_serializers/event.rb +68 -0
  259. data/lib/datadog/tracing/contrib/active_model_serializers/events/render.rb +44 -0
  260. data/lib/datadog/tracing/contrib/active_model_serializers/events/serialize.rb +46 -0
  261. data/lib/datadog/tracing/contrib/active_model_serializers/events.rb +33 -0
  262. data/lib/datadog/tracing/contrib/active_model_serializers/ext.rb +23 -0
  263. data/lib/datadog/tracing/contrib/active_model_serializers/integration.rb +44 -0
  264. data/lib/datadog/tracing/contrib/active_model_serializers/patcher.rb +32 -0
  265. data/lib/datadog/tracing/contrib/active_record/configuration/makara_resolver.rb +35 -0
  266. data/lib/datadog/tracing/contrib/active_record/configuration/resolver.rb +137 -0
  267. data/lib/datadog/tracing/contrib/active_record/configuration/settings.rb +38 -0
  268. data/lib/datadog/tracing/contrib/active_record/event.rb +29 -0
  269. data/lib/datadog/tracing/contrib/active_record/events/instantiation.rb +57 -0
  270. data/lib/datadog/tracing/contrib/active_record/events/sql.rb +77 -0
  271. data/lib/datadog/tracing/contrib/active_record/events.rb +33 -0
  272. data/lib/datadog/tracing/contrib/active_record/ext.rb +28 -0
  273. data/lib/datadog/tracing/contrib/active_record/integration.rb +55 -0
  274. data/lib/datadog/tracing/contrib/active_record/patcher.rb +26 -0
  275. data/lib/datadog/tracing/contrib/active_record/utils.rb +127 -0
  276. data/lib/{ddtrace/vendor/active_record → datadog/tracing/contrib/active_record/vendor}/MIT-LICENSE +0 -0
  277. data/lib/datadog/tracing/contrib/active_record/vendor/connection_specification.rb +306 -0
  278. data/lib/datadog/tracing/contrib/active_support/cache/instrumentation.rb +269 -0
  279. data/lib/datadog/tracing/contrib/active_support/cache/patcher.rb +72 -0
  280. data/lib/datadog/tracing/contrib/active_support/cache/redis.rb +46 -0
  281. data/lib/datadog/tracing/contrib/active_support/configuration/settings.rb +34 -0
  282. data/lib/datadog/tracing/contrib/active_support/ext.rb +30 -0
  283. data/lib/datadog/tracing/contrib/active_support/integration.rb +50 -0
  284. data/lib/datadog/tracing/contrib/active_support/notifications/event.rb +70 -0
  285. data/lib/datadog/tracing/contrib/active_support/notifications/subscriber.rb +70 -0
  286. data/lib/datadog/tracing/contrib/active_support/notifications/subscription.rb +161 -0
  287. data/lib/datadog/tracing/contrib/active_support/patcher.rb +26 -0
  288. data/lib/datadog/tracing/contrib/analytics.rb +28 -0
  289. data/lib/datadog/tracing/contrib/auto_instrument.rb +50 -0
  290. data/lib/datadog/tracing/contrib/aws/configuration/settings.rb +34 -0
  291. data/lib/datadog/tracing/contrib/aws/ext.rb +26 -0
  292. data/lib/datadog/tracing/contrib/aws/instrumentation.rb +93 -0
  293. data/lib/datadog/tracing/contrib/aws/integration.rb +46 -0
  294. data/lib/datadog/tracing/contrib/aws/parsed_context.rb +59 -0
  295. data/lib/datadog/tracing/contrib/aws/patcher.rb +56 -0
  296. data/lib/datadog/tracing/contrib/aws/services.rb +122 -0
  297. data/lib/datadog/tracing/contrib/concurrent_ruby/configuration/settings.rb +22 -0
  298. data/lib/datadog/tracing/contrib/concurrent_ruby/context_composite_executor_service.rb +45 -0
  299. data/lib/datadog/tracing/contrib/concurrent_ruby/ext.rb +15 -0
  300. data/lib/datadog/tracing/contrib/concurrent_ruby/future_patch.rb +26 -0
  301. data/lib/datadog/tracing/contrib/concurrent_ruby/integration.rb +42 -0
  302. data/lib/datadog/tracing/contrib/concurrent_ruby/patcher.rb +32 -0
  303. data/lib/datadog/tracing/contrib/configurable.rb +101 -0
  304. data/lib/datadog/tracing/contrib/configuration/resolver.rb +84 -0
  305. data/lib/datadog/tracing/contrib/configuration/resolvers/pattern_resolver.rb +42 -0
  306. data/lib/datadog/tracing/contrib/configuration/settings.rb +42 -0
  307. data/lib/datadog/tracing/contrib/dalli/configuration/settings.rb +34 -0
  308. data/lib/datadog/tracing/contrib/dalli/ext.rb +23 -0
  309. data/lib/datadog/tracing/contrib/dalli/instrumentation.rb +57 -0
  310. data/lib/datadog/tracing/contrib/dalli/integration.rb +51 -0
  311. data/lib/datadog/tracing/contrib/dalli/patcher.rb +28 -0
  312. data/lib/datadog/tracing/contrib/dalli/quantize.rb +25 -0
  313. data/lib/datadog/tracing/contrib/delayed_job/configuration/settings.rb +37 -0
  314. data/lib/datadog/tracing/contrib/delayed_job/ext.rb +25 -0
  315. data/lib/datadog/tracing/contrib/delayed_job/integration.rb +42 -0
  316. data/lib/datadog/tracing/contrib/delayed_job/patcher.rb +31 -0
  317. data/lib/datadog/tracing/contrib/delayed_job/plugin.rb +100 -0
  318. data/lib/datadog/tracing/contrib/elasticsearch/configuration/settings.rb +35 -0
  319. data/lib/datadog/tracing/contrib/elasticsearch/ext.rb +25 -0
  320. data/lib/datadog/tracing/contrib/elasticsearch/integration.rb +43 -0
  321. data/lib/datadog/tracing/contrib/elasticsearch/patcher.rb +114 -0
  322. data/lib/datadog/tracing/contrib/elasticsearch/quantize.rb +88 -0
  323. data/lib/datadog/tracing/contrib/ethon/configuration/settings.rb +36 -0
  324. data/lib/datadog/tracing/contrib/ethon/easy_patch.rb +176 -0
  325. data/lib/datadog/tracing/contrib/ethon/ext.rb +23 -0
  326. data/lib/datadog/tracing/contrib/ethon/integration.rb +47 -0
  327. data/lib/datadog/tracing/contrib/ethon/multi_patch.rb +95 -0
  328. data/lib/datadog/tracing/contrib/ethon/patcher.rb +31 -0
  329. data/lib/datadog/tracing/contrib/excon/configuration/settings.rb +37 -0
  330. data/lib/datadog/tracing/contrib/excon/ext.rb +20 -0
  331. data/lib/datadog/tracing/contrib/excon/integration.rb +47 -0
  332. data/lib/datadog/tracing/contrib/excon/middleware.rb +169 -0
  333. data/lib/datadog/tracing/contrib/excon/patcher.rb +30 -0
  334. data/lib/datadog/tracing/contrib/extensions.rb +184 -0
  335. data/lib/datadog/tracing/contrib/faraday/configuration/settings.rb +41 -0
  336. data/lib/datadog/tracing/contrib/faraday/connection.rb +21 -0
  337. data/lib/datadog/tracing/contrib/faraday/ext.rb +20 -0
  338. data/lib/datadog/tracing/contrib/faraday/integration.rb +47 -0
  339. data/lib/datadog/tracing/contrib/faraday/middleware.rb +92 -0
  340. data/lib/datadog/tracing/contrib/faraday/patcher.rb +56 -0
  341. data/lib/datadog/tracing/contrib/faraday/rack_builder.rb +21 -0
  342. data/lib/datadog/tracing/contrib/grape/configuration/settings.rb +41 -0
  343. data/lib/datadog/tracing/contrib/grape/endpoint.rb +251 -0
  344. data/lib/datadog/tracing/contrib/grape/ext.rb +27 -0
  345. data/lib/datadog/tracing/contrib/grape/instrumentation.rb +36 -0
  346. data/lib/datadog/tracing/contrib/grape/integration.rb +43 -0
  347. data/lib/datadog/tracing/contrib/grape/patcher.rb +33 -0
  348. data/lib/datadog/tracing/contrib/graphql/configuration/settings.rb +35 -0
  349. data/lib/datadog/tracing/contrib/graphql/ext.rb +18 -0
  350. data/lib/datadog/tracing/contrib/graphql/integration.rb +43 -0
  351. data/lib/datadog/tracing/contrib/graphql/patcher.rb +64 -0
  352. data/lib/datadog/tracing/contrib/grpc/configuration/settings.rb +36 -0
  353. data/lib/datadog/tracing/contrib/grpc/datadog_interceptor/client.rb +83 -0
  354. data/lib/datadog/tracing/contrib/grpc/datadog_interceptor/server.rb +89 -0
  355. data/lib/datadog/tracing/contrib/grpc/datadog_interceptor.rb +103 -0
  356. data/lib/datadog/tracing/contrib/grpc/ext.rb +22 -0
  357. data/lib/datadog/tracing/contrib/grpc/integration.rb +42 -0
  358. data/lib/datadog/tracing/contrib/grpc/intercept_with_datadog.rb +52 -0
  359. data/lib/datadog/tracing/contrib/grpc/patcher.rb +37 -0
  360. data/lib/datadog/tracing/contrib/http/circuit_breaker.rb +43 -0
  361. data/lib/datadog/tracing/contrib/http/configuration/settings.rb +36 -0
  362. data/lib/datadog/tracing/contrib/http/ext.rb +20 -0
  363. data/lib/datadog/tracing/contrib/http/instrumentation.rb +138 -0
  364. data/lib/datadog/tracing/contrib/http/integration.rb +48 -0
  365. data/lib/datadog/tracing/contrib/http/patcher.rb +29 -0
  366. data/lib/datadog/tracing/contrib/http_annotation_helper.rb +16 -0
  367. data/lib/datadog/tracing/contrib/httpclient/configuration/settings.rb +36 -0
  368. data/lib/datadog/tracing/contrib/httpclient/ext.rb +20 -0
  369. data/lib/datadog/tracing/contrib/httpclient/instrumentation.rb +116 -0
  370. data/lib/datadog/tracing/contrib/httpclient/integration.rb +47 -0
  371. data/lib/datadog/tracing/contrib/httpclient/patcher.rb +41 -0
  372. data/lib/datadog/tracing/contrib/httprb/configuration/settings.rb +36 -0
  373. data/lib/datadog/tracing/contrib/httprb/ext.rb +20 -0
  374. data/lib/datadog/tracing/contrib/httprb/instrumentation.rb +127 -0
  375. data/lib/datadog/tracing/contrib/httprb/integration.rb +47 -0
  376. data/lib/datadog/tracing/contrib/httprb/patcher.rb +41 -0
  377. data/lib/datadog/tracing/contrib/integration.rb +77 -0
  378. data/lib/datadog/tracing/contrib/kafka/configuration/settings.rb +34 -0
  379. data/lib/datadog/tracing/contrib/kafka/consumer_event.rb +17 -0
  380. data/lib/datadog/tracing/contrib/kafka/consumer_group_event.rb +17 -0
  381. data/lib/datadog/tracing/contrib/kafka/event.rb +51 -0
  382. data/lib/datadog/tracing/contrib/kafka/events/connection/request.rb +41 -0
  383. data/lib/datadog/tracing/contrib/kafka/events/consumer/process_batch.rb +48 -0
  384. data/lib/datadog/tracing/contrib/kafka/events/consumer/process_message.rb +46 -0
  385. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/heartbeat.rb +46 -0
  386. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/join_group.rb +36 -0
  387. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/leave_group.rb +36 -0
  388. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/sync_group.rb +36 -0
  389. data/lib/datadog/tracing/contrib/kafka/events/produce_operation/send_messages.rb +39 -0
  390. data/lib/datadog/tracing/contrib/kafka/events/producer/deliver_messages.rb +42 -0
  391. data/lib/datadog/tracing/contrib/kafka/events.rb +47 -0
  392. data/lib/datadog/tracing/contrib/kafka/ext.rb +51 -0
  393. data/lib/datadog/tracing/contrib/kafka/integration.rb +43 -0
  394. data/lib/datadog/tracing/contrib/kafka/patcher.rb +29 -0
  395. data/lib/datadog/tracing/contrib/lograge/configuration/settings.rb +22 -0
  396. data/lib/datadog/tracing/contrib/lograge/ext.rb +14 -0
  397. data/lib/datadog/tracing/contrib/lograge/instrumentation.rb +45 -0
  398. data/lib/datadog/tracing/contrib/lograge/integration.rb +49 -0
  399. data/lib/datadog/tracing/contrib/lograge/patcher.rb +28 -0
  400. data/lib/datadog/tracing/contrib/mongodb/configuration/settings.rb +37 -0
  401. data/lib/datadog/tracing/contrib/mongodb/ext.rb +26 -0
  402. data/lib/datadog/tracing/contrib/mongodb/instrumentation.rb +46 -0
  403. data/lib/datadog/tracing/contrib/mongodb/integration.rb +47 -0
  404. data/lib/datadog/tracing/contrib/mongodb/parsers.rb +48 -0
  405. data/lib/datadog/tracing/contrib/mongodb/patcher.rb +33 -0
  406. data/lib/datadog/tracing/contrib/mongodb/subscribers.rb +120 -0
  407. data/lib/datadog/tracing/contrib/mysql2/configuration/settings.rb +34 -0
  408. data/lib/datadog/tracing/contrib/mysql2/ext.rb +21 -0
  409. data/lib/datadog/tracing/contrib/mysql2/instrumentation.rb +61 -0
  410. data/lib/datadog/tracing/contrib/mysql2/integration.rb +42 -0
  411. data/lib/datadog/tracing/contrib/mysql2/patcher.rb +30 -0
  412. data/lib/datadog/tracing/contrib/patchable.rb +108 -0
  413. data/lib/datadog/tracing/contrib/patcher.rb +73 -0
  414. data/lib/datadog/tracing/contrib/presto/configuration/settings.rb +34 -0
  415. data/lib/datadog/tracing/contrib/presto/ext.rb +31 -0
  416. data/lib/datadog/tracing/contrib/presto/instrumentation.rb +124 -0
  417. data/lib/datadog/tracing/contrib/presto/integration.rb +42 -0
  418. data/lib/datadog/tracing/contrib/presto/patcher.rb +36 -0
  419. data/lib/datadog/tracing/contrib/qless/configuration/settings.rb +39 -0
  420. data/lib/datadog/tracing/contrib/qless/ext.rb +25 -0
  421. data/lib/datadog/tracing/contrib/qless/integration.rb +42 -0
  422. data/lib/datadog/tracing/contrib/qless/patcher.rb +38 -0
  423. data/lib/datadog/tracing/contrib/qless/qless_job.rb +74 -0
  424. data/lib/datadog/tracing/contrib/qless/tracer_cleaner.rb +31 -0
  425. data/lib/datadog/tracing/contrib/que/configuration/settings.rb +48 -0
  426. data/lib/datadog/tracing/contrib/que/ext.rb +33 -0
  427. data/lib/datadog/tracing/contrib/que/integration.rb +45 -0
  428. data/lib/datadog/tracing/contrib/que/patcher.rb +28 -0
  429. data/lib/datadog/tracing/contrib/que/tracer.rb +60 -0
  430. data/lib/datadog/tracing/contrib/racecar/configuration/settings.rb +34 -0
  431. data/lib/datadog/tracing/contrib/racecar/event.rb +78 -0
  432. data/lib/datadog/tracing/contrib/racecar/events/batch.rb +34 -0
  433. data/lib/datadog/tracing/contrib/racecar/events/consume.rb +34 -0
  434. data/lib/datadog/tracing/contrib/racecar/events/message.rb +34 -0
  435. data/lib/datadog/tracing/contrib/racecar/events.rb +35 -0
  436. data/lib/datadog/tracing/contrib/racecar/ext.rb +30 -0
  437. data/lib/datadog/tracing/contrib/racecar/integration.rb +43 -0
  438. data/lib/datadog/tracing/contrib/racecar/patcher.rb +29 -0
  439. data/lib/datadog/tracing/contrib/rack/configuration/settings.rb +50 -0
  440. data/lib/datadog/tracing/contrib/rack/ext.rb +24 -0
  441. data/lib/datadog/tracing/contrib/rack/integration.rb +49 -0
  442. data/lib/datadog/tracing/contrib/rack/middlewares.rb +254 -0
  443. data/lib/datadog/tracing/contrib/rack/patcher.rb +108 -0
  444. data/lib/datadog/tracing/contrib/rack/request_queue.rb +47 -0
  445. data/lib/datadog/tracing/contrib/rails/auto_instrument_railtie.rb +10 -0
  446. data/lib/datadog/tracing/contrib/rails/configuration/settings.rb +70 -0
  447. data/lib/datadog/tracing/contrib/rails/ext.rb +18 -0
  448. data/lib/datadog/tracing/contrib/rails/framework.rb +151 -0
  449. data/lib/datadog/tracing/contrib/rails/integration.rb +48 -0
  450. data/lib/datadog/tracing/contrib/rails/log_injection.rb +46 -0
  451. data/lib/datadog/tracing/contrib/rails/middlewares.rb +46 -0
  452. data/lib/datadog/tracing/contrib/rails/patcher.rb +116 -0
  453. data/lib/datadog/tracing/contrib/rails/railtie.rb +18 -0
  454. data/lib/datadog/tracing/contrib/rails/utils.rb +27 -0
  455. data/lib/datadog/tracing/contrib/rake/configuration/settings.rb +35 -0
  456. data/lib/datadog/tracing/contrib/rake/ext.rb +25 -0
  457. data/lib/datadog/tracing/contrib/rake/instrumentation.rb +96 -0
  458. data/lib/datadog/tracing/contrib/rake/integration.rb +42 -0
  459. data/lib/datadog/tracing/contrib/rake/patcher.rb +34 -0
  460. data/lib/datadog/tracing/contrib/redis/configuration/resolver.rb +48 -0
  461. data/lib/datadog/tracing/contrib/redis/configuration/settings.rb +39 -0
  462. data/lib/datadog/tracing/contrib/redis/ext.rb +25 -0
  463. data/lib/datadog/tracing/contrib/redis/instrumentation.rb +77 -0
  464. data/lib/datadog/tracing/contrib/redis/integration.rb +46 -0
  465. data/lib/datadog/tracing/contrib/redis/patcher.rb +35 -0
  466. data/lib/datadog/tracing/contrib/redis/quantize.rb +78 -0
  467. data/lib/datadog/tracing/contrib/redis/tags.rb +53 -0
  468. data/lib/{ddtrace → datadog/tracing}/contrib/redis/vendor/LICENSE +0 -0
  469. data/lib/datadog/tracing/contrib/redis/vendor/resolver.rb +161 -0
  470. data/lib/datadog/tracing/contrib/registerable.rb +50 -0
  471. data/lib/datadog/tracing/contrib/registry.rb +51 -0
  472. data/lib/datadog/tracing/contrib/resque/configuration/settings.rb +36 -0
  473. data/lib/datadog/tracing/contrib/resque/ext.rb +20 -0
  474. data/lib/datadog/tracing/contrib/resque/integration.rb +47 -0
  475. data/lib/datadog/tracing/contrib/resque/patcher.rb +29 -0
  476. data/lib/datadog/tracing/contrib/resque/resque_job.rb +102 -0
  477. data/lib/datadog/tracing/contrib/rest_client/configuration/settings.rb +35 -0
  478. data/lib/datadog/tracing/contrib/rest_client/ext.rb +20 -0
  479. data/lib/datadog/tracing/contrib/rest_client/integration.rb +42 -0
  480. data/lib/datadog/tracing/contrib/rest_client/patcher.rb +29 -0
  481. data/lib/datadog/tracing/contrib/rest_client/request_patch.rb +104 -0
  482. data/lib/datadog/tracing/contrib/semantic_logger/configuration/settings.rb +22 -0
  483. data/lib/datadog/tracing/contrib/semantic_logger/ext.rb +14 -0
  484. data/lib/datadog/tracing/contrib/semantic_logger/instrumentation.rb +49 -0
  485. data/lib/datadog/tracing/contrib/semantic_logger/integration.rb +51 -0
  486. data/lib/datadog/tracing/contrib/semantic_logger/patcher.rb +28 -0
  487. data/lib/datadog/tracing/contrib/sequel/configuration/settings.rb +32 -0
  488. data/lib/datadog/tracing/contrib/sequel/database.rb +59 -0
  489. data/lib/datadog/tracing/contrib/sequel/dataset.rb +64 -0
  490. data/lib/datadog/tracing/contrib/sequel/ext.rb +21 -0
  491. data/lib/datadog/tracing/contrib/sequel/integration.rb +42 -0
  492. data/lib/datadog/tracing/contrib/sequel/patcher.rb +36 -0
  493. data/lib/datadog/tracing/contrib/sequel/utils.rb +86 -0
  494. data/lib/datadog/tracing/contrib/shoryuken/configuration/settings.rb +37 -0
  495. data/lib/datadog/tracing/contrib/shoryuken/ext.rb +24 -0
  496. data/lib/datadog/tracing/contrib/shoryuken/integration.rb +43 -0
  497. data/lib/datadog/tracing/contrib/shoryuken/patcher.rb +27 -0
  498. data/lib/datadog/tracing/contrib/shoryuken/tracer.rb +60 -0
  499. data/lib/datadog/tracing/contrib/sidekiq/client_tracer.rb +52 -0
  500. data/lib/datadog/tracing/contrib/sidekiq/configuration/settings.rb +42 -0
  501. data/lib/datadog/tracing/contrib/sidekiq/ext.rb +37 -0
  502. data/lib/datadog/tracing/contrib/sidekiq/integration.rb +52 -0
  503. data/lib/datadog/tracing/contrib/sidekiq/patcher.rb +70 -0
  504. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/heartbeat.rb +34 -0
  505. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/job_fetch.rb +34 -0
  506. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/scheduled_push.rb +33 -0
  507. data/lib/datadog/tracing/contrib/sidekiq/server_tracer.rb +78 -0
  508. data/lib/datadog/tracing/contrib/sidekiq/tracing.rb +43 -0
  509. data/lib/datadog/tracing/contrib/sinatra/configuration/settings.rb +42 -0
  510. data/lib/datadog/tracing/contrib/sinatra/env.rb +65 -0
  511. data/lib/datadog/tracing/contrib/sinatra/ext.rb +31 -0
  512. data/lib/datadog/tracing/contrib/sinatra/framework.rb +105 -0
  513. data/lib/datadog/tracing/contrib/sinatra/headers.rb +34 -0
  514. data/lib/datadog/tracing/contrib/sinatra/integration.rb +42 -0
  515. data/lib/datadog/tracing/contrib/sinatra/patcher.rb +76 -0
  516. data/lib/datadog/tracing/contrib/sinatra/tracer.rb +158 -0
  517. data/lib/datadog/tracing/contrib/sinatra/tracer_middleware.rb +122 -0
  518. data/lib/datadog/tracing/contrib/sneakers/configuration/settings.rb +37 -0
  519. data/lib/datadog/tracing/contrib/sneakers/ext.rb +25 -0
  520. data/lib/datadog/tracing/contrib/sneakers/integration.rb +45 -0
  521. data/lib/datadog/tracing/contrib/sneakers/patcher.rb +29 -0
  522. data/lib/datadog/tracing/contrib/sneakers/tracer.rb +57 -0
  523. data/lib/datadog/tracing/contrib/status_code_matcher.rb +74 -0
  524. data/lib/datadog/tracing/contrib/sucker_punch/configuration/settings.rb +34 -0
  525. data/lib/datadog/tracing/contrib/sucker_punch/exception_handler.rb +27 -0
  526. data/lib/datadog/tracing/contrib/sucker_punch/ext.rb +26 -0
  527. data/lib/datadog/tracing/contrib/sucker_punch/instrumentation.rb +104 -0
  528. data/lib/datadog/tracing/contrib/sucker_punch/integration.rb +42 -0
  529. data/lib/datadog/tracing/contrib/sucker_punch/patcher.rb +37 -0
  530. data/lib/datadog/tracing/contrib/utils/database.rb +30 -0
  531. data/lib/datadog/tracing/contrib/utils/quantization/hash.rb +110 -0
  532. data/lib/datadog/tracing/contrib/utils/quantization/http.rb +98 -0
  533. data/lib/datadog/tracing/contrib.rb +73 -0
  534. data/lib/datadog/tracing/correlation.rb +108 -0
  535. data/lib/datadog/tracing/distributed/headers/b3.rb +54 -0
  536. data/lib/datadog/tracing/distributed/headers/b3_single.rb +66 -0
  537. data/lib/datadog/tracing/distributed/headers/datadog.rb +51 -0
  538. data/lib/datadog/tracing/distributed/headers/ext.rb +30 -0
  539. data/lib/datadog/tracing/distributed/helpers.rb +43 -0
  540. data/lib/datadog/tracing/distributed/parser.rb +69 -0
  541. data/lib/datadog/tracing/event.rb +76 -0
  542. data/lib/datadog/tracing/flush.rb +73 -0
  543. data/lib/datadog/tracing/metadata/analytics.rb +24 -0
  544. data/lib/datadog/tracing/metadata/ext.rb +150 -0
  545. data/lib/datadog/tracing/metadata/tagging.rb +118 -0
  546. data/lib/datadog/tracing/metadata.rb +16 -0
  547. data/lib/datadog/tracing/pipeline/span_filter.rb +42 -0
  548. data/lib/datadog/tracing/pipeline/span_processor.rb +38 -0
  549. data/lib/datadog/tracing/pipeline.rb +65 -0
  550. data/lib/datadog/tracing/propagation/grpc.rb +87 -0
  551. data/lib/datadog/tracing/propagation/http.rb +108 -0
  552. data/lib/datadog/tracing/runtime/metrics.rb +18 -0
  553. data/lib/datadog/tracing/sampling/all_sampler.rb +24 -0
  554. data/lib/datadog/tracing/sampling/ext.rb +26 -0
  555. data/lib/datadog/tracing/sampling/matcher.rb +67 -0
  556. data/lib/datadog/tracing/sampling/priority_sampler.rb +112 -0
  557. data/lib/datadog/tracing/sampling/rate_by_key_sampler.rb +96 -0
  558. data/lib/datadog/tracing/sampling/rate_by_service_sampler.rb +40 -0
  559. data/lib/datadog/tracing/sampling/rate_limiter.rb +184 -0
  560. data/lib/datadog/tracing/sampling/rate_sampler.rb +54 -0
  561. data/lib/datadog/tracing/sampling/rule.rb +69 -0
  562. data/lib/datadog/tracing/sampling/rule_sampler.rb +132 -0
  563. data/lib/datadog/tracing/sampling/sampler.rb +43 -0
  564. data/lib/datadog/tracing/span.rb +210 -0
  565. data/lib/datadog/tracing/span_operation.rb +519 -0
  566. data/lib/datadog/tracing/sync_writer.rb +68 -0
  567. data/lib/datadog/tracing/trace_digest.rb +58 -0
  568. data/lib/datadog/tracing/trace_operation.rb +411 -0
  569. data/lib/datadog/tracing/trace_segment.rb +292 -0
  570. data/lib/datadog/tracing/tracer.rb +504 -0
  571. data/lib/datadog/tracing/workers/trace_writer.rb +194 -0
  572. data/lib/datadog/tracing/workers.rb +124 -0
  573. data/lib/datadog/tracing/writer.rb +179 -0
  574. data/lib/datadog/tracing.rb +140 -0
  575. data/lib/ddtrace/auto_instrument.rb +4 -1
  576. data/lib/ddtrace/profiling/preload.rb +2 -4
  577. data/lib/ddtrace/transport/ext.rb +34 -0
  578. data/lib/ddtrace/transport/http/adapters/net.rb +2 -2
  579. data/lib/ddtrace/transport/http/adapters/unix_socket.rb +2 -2
  580. data/lib/ddtrace/transport/http/api.rb +4 -11
  581. data/lib/ddtrace/transport/http/builder.rb +2 -2
  582. data/lib/ddtrace/transport/http/traces.rb +2 -0
  583. data/lib/ddtrace/transport/http.rb +22 -28
  584. data/lib/ddtrace/transport/io/traces.rb +1 -1
  585. data/lib/ddtrace/transport/io.rb +2 -2
  586. data/lib/ddtrace/transport/parcel.rb +1 -0
  587. data/lib/ddtrace/transport/serializable_trace.rb +116 -0
  588. data/lib/ddtrace/transport/statistics.rb +5 -4
  589. data/lib/ddtrace/transport/trace_formatter.rb +164 -0
  590. data/lib/ddtrace/transport/traces.rb +14 -5
  591. data/lib/ddtrace/version.rb +5 -5
  592. data/lib/ddtrace.rb +18 -39
  593. metadata +561 -485
  594. data/.yardopts +0 -5
  595. data/lib/datadog/ci/context_flush.rb +0 -29
  596. data/lib/datadog/contrib.rb +0 -71
  597. data/lib/ddtrace/analytics.rb +0 -39
  598. data/lib/ddtrace/buffer.rb +0 -340
  599. data/lib/ddtrace/chunker.rb +0 -35
  600. data/lib/ddtrace/configuration/agent_settings_resolver.rb +0 -309
  601. data/lib/ddtrace/configuration/base.rb +0 -82
  602. data/lib/ddtrace/configuration/components.rb +0 -292
  603. data/lib/ddtrace/configuration/dependency_resolver.rb +0 -25
  604. data/lib/ddtrace/configuration/option.rb +0 -65
  605. data/lib/ddtrace/configuration/option_definition.rb +0 -122
  606. data/lib/ddtrace/configuration/option_definition_set.rb +0 -19
  607. data/lib/ddtrace/configuration/option_set.rb +0 -7
  608. data/lib/ddtrace/configuration/options.rb +0 -112
  609. data/lib/ddtrace/configuration/pin_setup.rb +0 -32
  610. data/lib/ddtrace/configuration/settings.rb +0 -413
  611. data/lib/ddtrace/configuration.rb +0 -195
  612. data/lib/ddtrace/context.rb +0 -334
  613. data/lib/ddtrace/context_flush.rb +0 -82
  614. data/lib/ddtrace/context_provider.rb +0 -62
  615. data/lib/ddtrace/contrib/action_cable/configuration/settings.rb +0 -31
  616. data/lib/ddtrace/contrib/action_cable/event.rb +0 -67
  617. data/lib/ddtrace/contrib/action_cable/events/broadcast.rb +0 -50
  618. data/lib/ddtrace/contrib/action_cable/events/perform_action.rb +0 -56
  619. data/lib/ddtrace/contrib/action_cable/events/transmit.rb +0 -51
  620. data/lib/ddtrace/contrib/action_cable/events.rb +0 -34
  621. data/lib/ddtrace/contrib/action_cable/ext.rb +0 -27
  622. data/lib/ddtrace/contrib/action_cable/instrumentation.rb +0 -78
  623. data/lib/ddtrace/contrib/action_cable/integration.rb +0 -46
  624. data/lib/ddtrace/contrib/action_cable/patcher.rb +0 -29
  625. data/lib/ddtrace/contrib/action_mailer/configuration/settings.rb +0 -32
  626. data/lib/ddtrace/contrib/action_mailer/event.rb +0 -50
  627. data/lib/ddtrace/contrib/action_mailer/events/deliver.rb +0 -54
  628. data/lib/ddtrace/contrib/action_mailer/events/process.rb +0 -41
  629. data/lib/ddtrace/contrib/action_mailer/events.rb +0 -31
  630. data/lib/ddtrace/contrib/action_mailer/ext.rb +0 -32
  631. data/lib/ddtrace/contrib/action_mailer/integration.rb +0 -45
  632. data/lib/ddtrace/contrib/action_mailer/patcher.rb +0 -27
  633. data/lib/ddtrace/contrib/action_pack/action_controller/instrumentation.rb +0 -157
  634. data/lib/ddtrace/contrib/action_pack/action_controller/patcher.rb +0 -26
  635. data/lib/ddtrace/contrib/action_pack/configuration/settings.rb +0 -33
  636. data/lib/ddtrace/contrib/action_pack/ext.rb +0 -20
  637. data/lib/ddtrace/contrib/action_pack/integration.rb +0 -46
  638. data/lib/ddtrace/contrib/action_pack/patcher.rb +0 -24
  639. data/lib/ddtrace/contrib/action_pack/utils.rb +0 -37
  640. data/lib/ddtrace/contrib/action_view/configuration/settings.rb +0 -32
  641. data/lib/ddtrace/contrib/action_view/event.rb +0 -36
  642. data/lib/ddtrace/contrib/action_view/events/render_partial.rb +0 -47
  643. data/lib/ddtrace/contrib/action_view/events/render_template.rb +0 -50
  644. data/lib/ddtrace/contrib/action_view/events.rb +0 -31
  645. data/lib/ddtrace/contrib/action_view/ext.rb +0 -21
  646. data/lib/ddtrace/contrib/action_view/instrumentation/partial_renderer.rb +0 -75
  647. data/lib/ddtrace/contrib/action_view/instrumentation/template_renderer.rb +0 -168
  648. data/lib/ddtrace/contrib/action_view/integration.rb +0 -53
  649. data/lib/ddtrace/contrib/action_view/patcher.rb +0 -48
  650. data/lib/ddtrace/contrib/action_view/utils.rb +0 -33
  651. data/lib/ddtrace/contrib/active_job/configuration/settings.rb +0 -33
  652. data/lib/ddtrace/contrib/active_job/event.rb +0 -54
  653. data/lib/ddtrace/contrib/active_job/events/discard.rb +0 -46
  654. data/lib/ddtrace/contrib/active_job/events/enqueue.rb +0 -45
  655. data/lib/ddtrace/contrib/active_job/events/enqueue_at.rb +0 -45
  656. data/lib/ddtrace/contrib/active_job/events/enqueue_retry.rb +0 -47
  657. data/lib/ddtrace/contrib/active_job/events/perform.rb +0 -45
  658. data/lib/ddtrace/contrib/active_job/events/retry_stopped.rb +0 -46
  659. data/lib/ddtrace/contrib/active_job/events.rb +0 -39
  660. data/lib/ddtrace/contrib/active_job/ext.rb +0 -32
  661. data/lib/ddtrace/contrib/active_job/integration.rb +0 -46
  662. data/lib/ddtrace/contrib/active_job/log_injection.rb +0 -21
  663. data/lib/ddtrace/contrib/active_job/patcher.rb +0 -33
  664. data/lib/ddtrace/contrib/active_model_serializers/configuration/settings.rb +0 -31
  665. data/lib/ddtrace/contrib/active_model_serializers/event.rb +0 -69
  666. data/lib/ddtrace/contrib/active_model_serializers/events/render.rb +0 -33
  667. data/lib/ddtrace/contrib/active_model_serializers/events/serialize.rb +0 -36
  668. data/lib/ddtrace/contrib/active_model_serializers/events.rb +0 -31
  669. data/lib/ddtrace/contrib/active_model_serializers/ext.rb +0 -21
  670. data/lib/ddtrace/contrib/active_model_serializers/integration.rb +0 -41
  671. data/lib/ddtrace/contrib/active_model_serializers/patcher.rb +0 -30
  672. data/lib/ddtrace/contrib/active_record/configuration/makara_resolver.rb +0 -31
  673. data/lib/ddtrace/contrib/active_record/configuration/resolver.rb +0 -135
  674. data/lib/ddtrace/contrib/active_record/configuration/settings.rb +0 -36
  675. data/lib/ddtrace/contrib/active_record/event.rb +0 -31
  676. data/lib/ddtrace/contrib/active_record/events/instantiation.rb +0 -61
  677. data/lib/ddtrace/contrib/active_record/events/sql.rb +0 -69
  678. data/lib/ddtrace/contrib/active_record/events.rb +0 -31
  679. data/lib/ddtrace/contrib/active_record/ext.rb +0 -25
  680. data/lib/ddtrace/contrib/active_record/integration.rb +0 -54
  681. data/lib/ddtrace/contrib/active_record/patcher.rb +0 -24
  682. data/lib/ddtrace/contrib/active_record/utils.rb +0 -124
  683. data/lib/ddtrace/contrib/active_support/cache/instrumentation.rb +0 -259
  684. data/lib/ddtrace/contrib/active_support/cache/patcher.rb +0 -70
  685. data/lib/ddtrace/contrib/active_support/cache/redis.rb +0 -44
  686. data/lib/ddtrace/contrib/active_support/configuration/settings.rb +0 -31
  687. data/lib/ddtrace/contrib/active_support/ext.rb +0 -28
  688. data/lib/ddtrace/contrib/active_support/integration.rb +0 -47
  689. data/lib/ddtrace/contrib/active_support/notifications/event.rb +0 -76
  690. data/lib/ddtrace/contrib/active_support/notifications/subscriber.rb +0 -68
  691. data/lib/ddtrace/contrib/active_support/notifications/subscription.rb +0 -164
  692. data/lib/ddtrace/contrib/active_support/patcher.rb +0 -24
  693. data/lib/ddtrace/contrib/analytics.rb +0 -25
  694. data/lib/ddtrace/contrib/auto_instrument.rb +0 -48
  695. data/lib/ddtrace/contrib/aws/configuration/settings.rb +0 -31
  696. data/lib/ddtrace/contrib/aws/ext.rb +0 -24
  697. data/lib/ddtrace/contrib/aws/instrumentation.rb +0 -91
  698. data/lib/ddtrace/contrib/aws/integration.rb +0 -43
  699. data/lib/ddtrace/contrib/aws/parsed_context.rb +0 -57
  700. data/lib/ddtrace/contrib/aws/patcher.rb +0 -54
  701. data/lib/ddtrace/contrib/aws/services.rb +0 -119
  702. data/lib/ddtrace/contrib/concurrent_ruby/configuration/settings.rb +0 -21
  703. data/lib/ddtrace/contrib/concurrent_ruby/context_composite_executor_service.rb +0 -42
  704. data/lib/ddtrace/contrib/concurrent_ruby/ext.rb +0 -13
  705. data/lib/ddtrace/contrib/concurrent_ruby/future_patch.rb +0 -24
  706. data/lib/ddtrace/contrib/concurrent_ruby/integration.rb +0 -39
  707. data/lib/ddtrace/contrib/concurrent_ruby/patcher.rb +0 -30
  708. data/lib/ddtrace/contrib/configurable.rb +0 -103
  709. data/lib/ddtrace/contrib/configuration/resolver.rb +0 -82
  710. data/lib/ddtrace/contrib/configuration/resolvers/pattern_resolver.rb +0 -40
  711. data/lib/ddtrace/contrib/configuration/settings.rb +0 -56
  712. data/lib/ddtrace/contrib/dalli/configuration/settings.rb +0 -31
  713. data/lib/ddtrace/contrib/dalli/ext.rb +0 -21
  714. data/lib/ddtrace/contrib/dalli/instrumentation.rb +0 -55
  715. data/lib/ddtrace/contrib/dalli/integration.rb +0 -39
  716. data/lib/ddtrace/contrib/dalli/patcher.rb +0 -26
  717. data/lib/ddtrace/contrib/dalli/quantize.rb +0 -23
  718. data/lib/ddtrace/contrib/delayed_job/configuration/settings.rb +0 -33
  719. data/lib/ddtrace/contrib/delayed_job/ext.rb +0 -24
  720. data/lib/ddtrace/contrib/delayed_job/integration.rb +0 -39
  721. data/lib/ddtrace/contrib/delayed_job/patcher.rb +0 -29
  722. data/lib/ddtrace/contrib/delayed_job/plugin.rb +0 -85
  723. data/lib/ddtrace/contrib/elasticsearch/configuration/settings.rb +0 -32
  724. data/lib/ddtrace/contrib/elasticsearch/ext.rb +0 -23
  725. data/lib/ddtrace/contrib/elasticsearch/integration.rb +0 -40
  726. data/lib/ddtrace/contrib/elasticsearch/patcher.rb +0 -123
  727. data/lib/ddtrace/contrib/elasticsearch/quantize.rb +0 -84
  728. data/lib/ddtrace/contrib/ethon/configuration/settings.rb +0 -33
  729. data/lib/ddtrace/contrib/ethon/easy_patch.rb +0 -152
  730. data/lib/ddtrace/contrib/ethon/ext.rb +0 -20
  731. data/lib/ddtrace/contrib/ethon/integration.rb +0 -44
  732. data/lib/ddtrace/contrib/ethon/multi_patch.rb +0 -85
  733. data/lib/ddtrace/contrib/ethon/patcher.rb +0 -27
  734. data/lib/ddtrace/contrib/excon/configuration/settings.rb +0 -34
  735. data/lib/ddtrace/contrib/excon/ext.rb +0 -18
  736. data/lib/ddtrace/contrib/excon/integration.rb +0 -44
  737. data/lib/ddtrace/contrib/excon/middleware.rb +0 -164
  738. data/lib/ddtrace/contrib/excon/patcher.rb +0 -28
  739. data/lib/ddtrace/contrib/extensions.rb +0 -169
  740. data/lib/ddtrace/contrib/faraday/configuration/settings.rb +0 -39
  741. data/lib/ddtrace/contrib/faraday/connection.rb +0 -19
  742. data/lib/ddtrace/contrib/faraday/ext.rb +0 -18
  743. data/lib/ddtrace/contrib/faraday/integration.rb +0 -44
  744. data/lib/ddtrace/contrib/faraday/middleware.rb +0 -86
  745. data/lib/ddtrace/contrib/faraday/patcher.rb +0 -54
  746. data/lib/ddtrace/contrib/faraday/rack_builder.rb +0 -19
  747. data/lib/ddtrace/contrib/grape/configuration/settings.rb +0 -39
  748. data/lib/ddtrace/contrib/grape/endpoint.rb +0 -246
  749. data/lib/ddtrace/contrib/grape/ext.rb +0 -24
  750. data/lib/ddtrace/contrib/grape/instrumentation.rb +0 -34
  751. data/lib/ddtrace/contrib/grape/integration.rb +0 -40
  752. data/lib/ddtrace/contrib/grape/patcher.rb +0 -32
  753. data/lib/ddtrace/contrib/graphql/configuration/settings.rb +0 -33
  754. data/lib/ddtrace/contrib/graphql/ext.rb +0 -17
  755. data/lib/ddtrace/contrib/graphql/integration.rb +0 -40
  756. data/lib/ddtrace/contrib/graphql/patcher.rb +0 -61
  757. data/lib/ddtrace/contrib/grpc/configuration/settings.rb +0 -32
  758. data/lib/ddtrace/contrib/grpc/datadog_interceptor/client.rb +0 -59
  759. data/lib/ddtrace/contrib/grpc/datadog_interceptor/server.rb +0 -80
  760. data/lib/ddtrace/contrib/grpc/datadog_interceptor.rb +0 -79
  761. data/lib/ddtrace/contrib/grpc/ext.rb +0 -19
  762. data/lib/ddtrace/contrib/grpc/integration.rb +0 -39
  763. data/lib/ddtrace/contrib/grpc/intercept_with_datadog.rb +0 -50
  764. data/lib/ddtrace/contrib/grpc/patcher.rb +0 -34
  765. data/lib/ddtrace/contrib/http/circuit_breaker.rb +0 -38
  766. data/lib/ddtrace/contrib/http/configuration/settings.rb +0 -33
  767. data/lib/ddtrace/contrib/http/ext.rb +0 -18
  768. data/lib/ddtrace/contrib/http/instrumentation.rb +0 -180
  769. data/lib/ddtrace/contrib/http/integration.rb +0 -46
  770. data/lib/ddtrace/contrib/http/patcher.rb +0 -27
  771. data/lib/ddtrace/contrib/http_annotation_helper.rb +0 -11
  772. data/lib/ddtrace/contrib/httpclient/configuration/settings.rb +0 -33
  773. data/lib/ddtrace/contrib/httpclient/ext.rb +0 -18
  774. data/lib/ddtrace/contrib/httpclient/instrumentation.rb +0 -148
  775. data/lib/ddtrace/contrib/httpclient/integration.rb +0 -44
  776. data/lib/ddtrace/contrib/httpclient/patcher.rb +0 -39
  777. data/lib/ddtrace/contrib/httprb/configuration/settings.rb +0 -33
  778. data/lib/ddtrace/contrib/httprb/ext.rb +0 -18
  779. data/lib/ddtrace/contrib/httprb/instrumentation.rb +0 -158
  780. data/lib/ddtrace/contrib/httprb/integration.rb +0 -44
  781. data/lib/ddtrace/contrib/httprb/patcher.rb +0 -39
  782. data/lib/ddtrace/contrib/integration.rb +0 -17
  783. data/lib/ddtrace/contrib/kafka/configuration/settings.rb +0 -31
  784. data/lib/ddtrace/contrib/kafka/consumer_event.rb +0 -15
  785. data/lib/ddtrace/contrib/kafka/consumer_group_event.rb +0 -15
  786. data/lib/ddtrace/contrib/kafka/event.rb +0 -52
  787. data/lib/ddtrace/contrib/kafka/events/connection/request.rb +0 -35
  788. data/lib/ddtrace/contrib/kafka/events/consumer/process_batch.rb +0 -42
  789. data/lib/ddtrace/contrib/kafka/events/consumer/process_message.rb +0 -40
  790. data/lib/ddtrace/contrib/kafka/events/consumer_group/heartbeat.rb +0 -40
  791. data/lib/ddtrace/contrib/kafka/events/consumer_group/join_group.rb +0 -30
  792. data/lib/ddtrace/contrib/kafka/events/consumer_group/leave_group.rb +0 -30
  793. data/lib/ddtrace/contrib/kafka/events/consumer_group/sync_group.rb +0 -30
  794. data/lib/ddtrace/contrib/kafka/events/produce_operation/send_messages.rb +0 -33
  795. data/lib/ddtrace/contrib/kafka/events/producer/deliver_messages.rb +0 -36
  796. data/lib/ddtrace/contrib/kafka/events.rb +0 -45
  797. data/lib/ddtrace/contrib/kafka/ext.rb +0 -42
  798. data/lib/ddtrace/contrib/kafka/integration.rb +0 -40
  799. data/lib/ddtrace/contrib/kafka/patcher.rb +0 -27
  800. data/lib/ddtrace/contrib/lograge/configuration/settings.rb +0 -19
  801. data/lib/ddtrace/contrib/lograge/ext.rb +0 -11
  802. data/lib/ddtrace/contrib/lograge/instrumentation.rb +0 -39
  803. data/lib/ddtrace/contrib/lograge/integration.rb +0 -46
  804. data/lib/ddtrace/contrib/lograge/patcher.rb +0 -26
  805. data/lib/ddtrace/contrib/mongodb/configuration/settings.rb +0 -34
  806. data/lib/ddtrace/contrib/mongodb/ext.rb +0 -24
  807. data/lib/ddtrace/contrib/mongodb/instrumentation.rb +0 -70
  808. data/lib/ddtrace/contrib/mongodb/integration.rb +0 -44
  809. data/lib/ddtrace/contrib/mongodb/parsers.rb +0 -69
  810. data/lib/ddtrace/contrib/mongodb/patcher.rb +0 -32
  811. data/lib/ddtrace/contrib/mongodb/subscribers.rb +0 -112
  812. data/lib/ddtrace/contrib/mysql2/configuration/settings.rb +0 -31
  813. data/lib/ddtrace/contrib/mysql2/ext.rb +0 -19
  814. data/lib/ddtrace/contrib/mysql2/instrumentation.rb +0 -65
  815. data/lib/ddtrace/contrib/mysql2/integration.rb +0 -39
  816. data/lib/ddtrace/contrib/mysql2/patcher.rb +0 -28
  817. data/lib/ddtrace/contrib/patchable.rb +0 -71
  818. data/lib/ddtrace/contrib/patcher.rb +0 -66
  819. data/lib/ddtrace/contrib/presto/configuration/settings.rb +0 -31
  820. data/lib/ddtrace/contrib/presto/ext.rb +0 -29
  821. data/lib/ddtrace/contrib/presto/instrumentation.rb +0 -111
  822. data/lib/ddtrace/contrib/presto/integration.rb +0 -39
  823. data/lib/ddtrace/contrib/presto/patcher.rb +0 -34
  824. data/lib/ddtrace/contrib/qless/configuration/settings.rb +0 -36
  825. data/lib/ddtrace/contrib/qless/ext.rb +0 -21
  826. data/lib/ddtrace/contrib/qless/integration.rb +0 -39
  827. data/lib/ddtrace/contrib/qless/patcher.rb +0 -35
  828. data/lib/ddtrace/contrib/qless/qless_job.rb +0 -74
  829. data/lib/ddtrace/contrib/qless/tracer_cleaner.rb +0 -34
  830. data/lib/ddtrace/contrib/que/configuration/settings.rb +0 -44
  831. data/lib/ddtrace/contrib/que/ext.rb +0 -31
  832. data/lib/ddtrace/contrib/que/integration.rb +0 -43
  833. data/lib/ddtrace/contrib/que/patcher.rb +0 -25
  834. data/lib/ddtrace/contrib/que/tracer.rb +0 -58
  835. data/lib/ddtrace/contrib/racecar/configuration/settings.rb +0 -31
  836. data/lib/ddtrace/contrib/racecar/event.rb +0 -77
  837. data/lib/ddtrace/contrib/racecar/events/batch.rb +0 -28
  838. data/lib/ddtrace/contrib/racecar/events/consume.rb +0 -28
  839. data/lib/ddtrace/contrib/racecar/events/message.rb +0 -28
  840. data/lib/ddtrace/contrib/racecar/events.rb +0 -33
  841. data/lib/ddtrace/contrib/racecar/ext.rb +0 -26
  842. data/lib/ddtrace/contrib/racecar/integration.rb +0 -40
  843. data/lib/ddtrace/contrib/racecar/patcher.rb +0 -27
  844. data/lib/ddtrace/contrib/rack/configuration/settings.rb +0 -47
  845. data/lib/ddtrace/contrib/rack/ext.rb +0 -22
  846. data/lib/ddtrace/contrib/rack/integration.rb +0 -46
  847. data/lib/ddtrace/contrib/rack/middlewares.rb +0 -288
  848. data/lib/ddtrace/contrib/rack/patcher.rb +0 -106
  849. data/lib/ddtrace/contrib/rack/request_queue.rb +0 -45
  850. data/lib/ddtrace/contrib/rails/auto_instrument_railtie.rb +0 -10
  851. data/lib/ddtrace/contrib/rails/configuration/settings.rb +0 -101
  852. data/lib/ddtrace/contrib/rails/ext.rb +0 -18
  853. data/lib/ddtrace/contrib/rails/framework.rb +0 -172
  854. data/lib/ddtrace/contrib/rails/integration.rb +0 -45
  855. data/lib/ddtrace/contrib/rails/log_injection.rb +0 -42
  856. data/lib/ddtrace/contrib/rails/middlewares.rb +0 -44
  857. data/lib/ddtrace/contrib/rails/patcher.rb +0 -119
  858. data/lib/ddtrace/contrib/rails/railtie.rb +0 -18
  859. data/lib/ddtrace/contrib/rails/utils.rb +0 -25
  860. data/lib/ddtrace/contrib/rake/configuration/settings.rb +0 -32
  861. data/lib/ddtrace/contrib/rake/ext.rb +0 -22
  862. data/lib/ddtrace/contrib/rake/instrumentation.rb +0 -91
  863. data/lib/ddtrace/contrib/rake/integration.rb +0 -39
  864. data/lib/ddtrace/contrib/rake/patcher.rb +0 -31
  865. data/lib/ddtrace/contrib/redis/configuration/resolver.rb +0 -46
  866. data/lib/ddtrace/contrib/redis/configuration/settings.rb +0 -36
  867. data/lib/ddtrace/contrib/redis/ext.rb +0 -23
  868. data/lib/ddtrace/contrib/redis/instrumentation.rb +0 -90
  869. data/lib/ddtrace/contrib/redis/integration.rb +0 -43
  870. data/lib/ddtrace/contrib/redis/patcher.rb +0 -33
  871. data/lib/ddtrace/contrib/redis/quantize.rb +0 -76
  872. data/lib/ddtrace/contrib/redis/tags.rb +0 -47
  873. data/lib/ddtrace/contrib/redis/vendor/resolver.rb +0 -159
  874. data/lib/ddtrace/contrib/registerable.rb +0 -33
  875. data/lib/ddtrace/contrib/registry.rb +0 -43
  876. data/lib/ddtrace/contrib/resque/configuration/settings.rb +0 -49
  877. data/lib/ddtrace/contrib/resque/ext.rb +0 -18
  878. data/lib/ddtrace/contrib/resque/integration.rb +0 -44
  879. data/lib/ddtrace/contrib/resque/patcher.rb +0 -30
  880. data/lib/ddtrace/contrib/resque/resque_job.rb +0 -104
  881. data/lib/ddtrace/contrib/rest_client/configuration/settings.rb +0 -32
  882. data/lib/ddtrace/contrib/rest_client/ext.rb +0 -18
  883. data/lib/ddtrace/contrib/rest_client/integration.rb +0 -39
  884. data/lib/ddtrace/contrib/rest_client/patcher.rb +0 -25
  885. data/lib/ddtrace/contrib/rest_client/request_patch.rb +0 -92
  886. data/lib/ddtrace/contrib/semantic_logger/configuration/settings.rb +0 -19
  887. data/lib/ddtrace/contrib/semantic_logger/ext.rb +0 -11
  888. data/lib/ddtrace/contrib/semantic_logger/instrumentation.rb +0 -43
  889. data/lib/ddtrace/contrib/semantic_logger/integration.rb +0 -48
  890. data/lib/ddtrace/contrib/semantic_logger/patcher.rb +0 -26
  891. data/lib/ddtrace/contrib/sequel/configuration/settings.rb +0 -29
  892. data/lib/ddtrace/contrib/sequel/database.rb +0 -64
  893. data/lib/ddtrace/contrib/sequel/dataset.rb +0 -64
  894. data/lib/ddtrace/contrib/sequel/ext.rb +0 -20
  895. data/lib/ddtrace/contrib/sequel/integration.rb +0 -39
  896. data/lib/ddtrace/contrib/sequel/patcher.rb +0 -34
  897. data/lib/ddtrace/contrib/sequel/utils.rb +0 -75
  898. data/lib/ddtrace/contrib/shoryuken/configuration/settings.rb +0 -32
  899. data/lib/ddtrace/contrib/shoryuken/ext.rb +0 -22
  900. data/lib/ddtrace/contrib/shoryuken/integration.rb +0 -40
  901. data/lib/ddtrace/contrib/shoryuken/patcher.rb +0 -25
  902. data/lib/ddtrace/contrib/shoryuken/tracer.rb +0 -56
  903. data/lib/ddtrace/contrib/sidekiq/client_tracer.rb +0 -44
  904. data/lib/ddtrace/contrib/sidekiq/configuration/settings.rb +0 -38
  905. data/lib/ddtrace/contrib/sidekiq/ext.rb +0 -31
  906. data/lib/ddtrace/contrib/sidekiq/integration.rb +0 -49
  907. data/lib/ddtrace/contrib/sidekiq/patcher.rb +0 -68
  908. data/lib/ddtrace/contrib/sidekiq/server_internal_tracer/heartbeat.rb +0 -30
  909. data/lib/ddtrace/contrib/sidekiq/server_internal_tracer/job_fetch.rb +0 -30
  910. data/lib/ddtrace/contrib/sidekiq/server_internal_tracer/scheduled_push.rb +0 -29
  911. data/lib/ddtrace/contrib/sidekiq/server_tracer.rb +0 -66
  912. data/lib/ddtrace/contrib/sidekiq/tracing.rb +0 -45
  913. data/lib/ddtrace/contrib/sinatra/configuration/settings.rb +0 -40
  914. data/lib/ddtrace/contrib/sinatra/env.rb +0 -59
  915. data/lib/ddtrace/contrib/sinatra/ext.rb +0 -28
  916. data/lib/ddtrace/contrib/sinatra/headers.rb +0 -30
  917. data/lib/ddtrace/contrib/sinatra/integration.rb +0 -39
  918. data/lib/ddtrace/contrib/sinatra/patcher.rb +0 -30
  919. data/lib/ddtrace/contrib/sinatra/tracer.rb +0 -150
  920. data/lib/ddtrace/contrib/sinatra/tracer_middleware.rb +0 -112
  921. data/lib/ddtrace/contrib/sneakers/configuration/settings.rb +0 -34
  922. data/lib/ddtrace/contrib/sneakers/ext.rb +0 -23
  923. data/lib/ddtrace/contrib/sneakers/integration.rb +0 -42
  924. data/lib/ddtrace/contrib/sneakers/patcher.rb +0 -25
  925. data/lib/ddtrace/contrib/sneakers/tracer.rb +0 -54
  926. data/lib/ddtrace/contrib/status_code_matcher.rb +0 -70
  927. data/lib/ddtrace/contrib/sucker_punch/configuration/settings.rb +0 -31
  928. data/lib/ddtrace/contrib/sucker_punch/exception_handler.rb +0 -25
  929. data/lib/ddtrace/contrib/sucker_punch/ext.rb +0 -22
  930. data/lib/ddtrace/contrib/sucker_punch/instrumentation.rb +0 -89
  931. data/lib/ddtrace/contrib/sucker_punch/integration.rb +0 -39
  932. data/lib/ddtrace/contrib/sucker_punch/patcher.rb +0 -44
  933. data/lib/ddtrace/correlation.rb +0 -40
  934. data/lib/ddtrace/diagnostics/environment_logger.rb +0 -280
  935. data/lib/ddtrace/diagnostics/health.rb +0 -34
  936. data/lib/ddtrace/distributed_tracing/headers/b3.rb +0 -45
  937. data/lib/ddtrace/distributed_tracing/headers/b3_single.rb +0 -57
  938. data/lib/ddtrace/distributed_tracing/headers/datadog.rb +0 -43
  939. data/lib/ddtrace/distributed_tracing/headers/headers.rb +0 -72
  940. data/lib/ddtrace/distributed_tracing/headers/helpers.rb +0 -44
  941. data/lib/ddtrace/encoding.rb +0 -72
  942. data/lib/ddtrace/error.rb +0 -97
  943. data/lib/ddtrace/event.rb +0 -53
  944. data/lib/ddtrace/ext/analytics.rb +0 -13
  945. data/lib/ddtrace/ext/app_types.rb +0 -12
  946. data/lib/ddtrace/ext/correlation.rb +0 -12
  947. data/lib/ddtrace/ext/diagnostics.rb +0 -37
  948. data/lib/ddtrace/ext/distributed.rb +0 -40
  949. data/lib/ddtrace/ext/environment.rb +0 -24
  950. data/lib/ddtrace/ext/errors.rb +0 -11
  951. data/lib/ddtrace/ext/forced_tracing.rb +0 -26
  952. data/lib/ddtrace/ext/git.rb +0 -32
  953. data/lib/ddtrace/ext/http.rb +0 -47
  954. data/lib/ddtrace/ext/integration.rb +0 -9
  955. data/lib/ddtrace/ext/manual_tracing.rb +0 -10
  956. data/lib/ddtrace/ext/metrics.rb +0 -16
  957. data/lib/ddtrace/ext/net.rb +0 -11
  958. data/lib/ddtrace/ext/priority.rb +0 -19
  959. data/lib/ddtrace/ext/profiling.rb +0 -53
  960. data/lib/ddtrace/ext/runtime.rb +0 -25
  961. data/lib/ddtrace/ext/sampling.rb +0 -17
  962. data/lib/ddtrace/ext/sql.rb +0 -9
  963. data/lib/ddtrace/ext/test.rb +0 -9
  964. data/lib/ddtrace/ext/transport.rb +0 -32
  965. data/lib/ddtrace/forced_tracing.rb +0 -39
  966. data/lib/ddtrace/logger.rb +0 -41
  967. data/lib/ddtrace/metrics.rb +0 -282
  968. data/lib/ddtrace/opentelemetry/extensions.rb +0 -14
  969. data/lib/ddtrace/opentelemetry/span.rb +0 -34
  970. data/lib/ddtrace/opentracer/carrier.rb +0 -7
  971. data/lib/ddtrace/opentracer/distributed_headers.rb +0 -56
  972. data/lib/ddtrace/opentracer/global_tracer.rb +0 -16
  973. data/lib/ddtrace/opentracer/propagator.rb +0 -23
  974. data/lib/ddtrace/opentracer/rack_propagator.rb +0 -61
  975. data/lib/ddtrace/opentracer/scope.rb +0 -16
  976. data/lib/ddtrace/opentracer/scope_manager.rb +0 -7
  977. data/lib/ddtrace/opentracer/span.rb +0 -95
  978. data/lib/ddtrace/opentracer/span_context.rb +0 -15
  979. data/lib/ddtrace/opentracer/span_context_factory.rb +0 -24
  980. data/lib/ddtrace/opentracer/text_map_propagator.rb +0 -76
  981. data/lib/ddtrace/opentracer/thread_local_scope.rb +0 -32
  982. data/lib/ddtrace/opentracer/thread_local_scope_manager.rb +0 -41
  983. data/lib/ddtrace/opentracer/tracer.rb +0 -209
  984. data/lib/ddtrace/opentracer.rb +0 -22
  985. data/lib/ddtrace/patcher.rb +0 -69
  986. data/lib/ddtrace/pin.rb +0 -86
  987. data/lib/ddtrace/pipeline/span_filter.rb +0 -39
  988. data/lib/ddtrace/pipeline/span_processor.rb +0 -21
  989. data/lib/ddtrace/pipeline.rb +0 -47
  990. data/lib/ddtrace/profiling/buffer.rb +0 -42
  991. data/lib/ddtrace/profiling/collectors/stack.rb +0 -297
  992. data/lib/ddtrace/profiling/encoding/profile.rb +0 -46
  993. data/lib/ddtrace/profiling/events/stack.rb +0 -81
  994. data/lib/ddtrace/profiling/exporter.rb +0 -24
  995. data/lib/ddtrace/profiling/flush.rb +0 -44
  996. data/lib/ddtrace/profiling/pprof/builder.rb +0 -126
  997. data/lib/ddtrace/profiling/pprof/converter.rb +0 -103
  998. data/lib/ddtrace/profiling/pprof/message_set.rb +0 -15
  999. data/lib/ddtrace/profiling/pprof/pprof_pb.rb +0 -82
  1000. data/lib/ddtrace/profiling/pprof/stack_sample.rb +0 -140
  1001. data/lib/ddtrace/profiling/pprof/string_table.rb +0 -11
  1002. data/lib/ddtrace/profiling/pprof/template.rb +0 -119
  1003. data/lib/ddtrace/profiling/profiler.rb +0 -31
  1004. data/lib/ddtrace/profiling/recorder.rb +0 -96
  1005. data/lib/ddtrace/profiling/scheduler.rb +0 -150
  1006. data/lib/ddtrace/profiling/tasks/setup.rb +0 -90
  1007. data/lib/ddtrace/profiling/trace_identifiers/ddtrace.rb +0 -42
  1008. data/lib/ddtrace/profiling/trace_identifiers/helper.rb +0 -46
  1009. data/lib/ddtrace/profiling/transport/http/api/endpoint.rb +0 -94
  1010. data/lib/ddtrace/profiling/transport/http/api/instance.rb +0 -37
  1011. data/lib/ddtrace/profiling/transport/http/api.rb +0 -44
  1012. data/lib/ddtrace/profiling/transport/http/builder.rb +0 -29
  1013. data/lib/ddtrace/profiling/transport/http/client.rb +0 -34
  1014. data/lib/ddtrace/profiling/transport/http/response.rb +0 -22
  1015. data/lib/ddtrace/profiling/transport/http.rb +0 -111
  1016. data/lib/ddtrace/profiling/transport/io/client.rb +0 -28
  1017. data/lib/ddtrace/profiling/transport/io/response.rb +0 -17
  1018. data/lib/ddtrace/profiling/transport/io.rb +0 -31
  1019. data/lib/ddtrace/profiling/transport/request.rb +0 -16
  1020. data/lib/ddtrace/profiling.rb +0 -149
  1021. data/lib/ddtrace/propagation/grpc_propagator.rb +0 -75
  1022. data/lib/ddtrace/propagation/http_propagator.rb +0 -91
  1023. data/lib/ddtrace/quantization/hash.rb +0 -104
  1024. data/lib/ddtrace/quantization/http.rb +0 -90
  1025. data/lib/ddtrace/runtime/metrics.rb +0 -135
  1026. data/lib/ddtrace/sampler.rb +0 -303
  1027. data/lib/ddtrace/sampling/matcher.rb +0 -58
  1028. data/lib/ddtrace/sampling/rate_limiter.rb +0 -177
  1029. data/lib/ddtrace/sampling/rule.rb +0 -62
  1030. data/lib/ddtrace/sampling/rule_sampler.rb +0 -133
  1031. data/lib/ddtrace/sampling.rb +0 -3
  1032. data/lib/ddtrace/span.rb +0 -445
  1033. data/lib/ddtrace/sync_writer.rb +0 -69
  1034. data/lib/ddtrace/tasks/exec.rb +0 -47
  1035. data/lib/ddtrace/tasks/help.rb +0 -15
  1036. data/lib/ddtrace/tracer.rb +0 -449
  1037. data/lib/ddtrace/utils/compression.rb +0 -28
  1038. data/lib/ddtrace/utils/database.rb +0 -26
  1039. data/lib/ddtrace/utils/forking.rb +0 -53
  1040. data/lib/ddtrace/utils/object_set.rb +0 -40
  1041. data/lib/ddtrace/utils/only_once.rb +0 -41
  1042. data/lib/ddtrace/utils/sequence.rb +0 -18
  1043. data/lib/ddtrace/utils/string_table.rb +0 -46
  1044. data/lib/ddtrace/utils/time.rb +0 -51
  1045. data/lib/ddtrace/utils.rb +0 -80
  1046. data/lib/ddtrace/vendor/active_record/connection_specification.rb +0 -302
  1047. data/lib/ddtrace/vendor/multipart-post/multipart/post/composite_read_io.rb +0 -117
  1048. data/lib/ddtrace/vendor/multipart-post/multipart/post/multipartable.rb +0 -58
  1049. data/lib/ddtrace/vendor/multipart-post/multipart/post/parts.rb +0 -136
  1050. data/lib/ddtrace/vendor/multipart-post/multipart/post/version.rb +0 -10
  1051. data/lib/ddtrace/vendor/multipart-post/multipart/post.rb +0 -9
  1052. data/lib/ddtrace/vendor/multipart-post/multipart.rb +0 -13
  1053. data/lib/ddtrace/vendor/multipart-post/net/http/post/multipart.rb +0 -33
  1054. data/lib/ddtrace/worker.rb +0 -21
  1055. data/lib/ddtrace/workers/async.rb +0 -175
  1056. data/lib/ddtrace/workers/interval_loop.rb +0 -116
  1057. data/lib/ddtrace/workers/polling.rb +0 -56
  1058. data/lib/ddtrace/workers/queue.rb +0 -41
  1059. data/lib/ddtrace/workers/runtime_metrics.rb +0 -65
  1060. data/lib/ddtrace/workers/trace_writer.rb +0 -200
  1061. data/lib/ddtrace/workers.rb +0 -123
  1062. data/lib/ddtrace/writer.rb +0 -200
@@ -0,0 +1,283 @@
1
+ # typed: true
2
+ require 'forwardable'
3
+ require 'datadog/core/configuration/components'
4
+ require 'datadog/core/configuration/settings'
5
+ require 'datadog/core/logger'
6
+ require 'datadog/core/pin'
7
+
8
+ module Datadog
9
+ module Core
10
+ # Configuration provides a unique access point for configurations
11
+ module Configuration # rubocop:disable Metrics/ModuleLength
12
+ include Kernel # Ensure that kernel methods are always available (https://sorbet.org/docs/error-reference#7003)
13
+ extend Forwardable
14
+
15
+ # Used to ensure that @components initialization/reconfiguration is performed one-at-a-time, by a single thread.
16
+ #
17
+ # This is important because components can end up being accessed from multiple application threads (for instance on
18
+ # a threaded webserver), and we don't want their initialization to clash (for instance, starting two profilers...).
19
+ #
20
+ # Note that a Mutex **IS NOT** reentrant: the same thread cannot grab the same Mutex more than once.
21
+ # This means below we are careful not to nest calls to methods that would trigger initialization and grab the lock.
22
+ #
23
+ # Every method that directly or indirectly mutates @components should be holding the lock (through
24
+ # #safely_synchronize) while doing so.
25
+ COMPONENTS_WRITE_LOCK = Mutex.new
26
+ private_constant :COMPONENTS_WRITE_LOCK
27
+
28
+ # We use a separate lock when reading the @components, so that they continue to be accessible during reconfiguration.
29
+ # This was needed because we ran into several issues where we still needed to read the old
30
+ # components while the COMPONENTS_WRITE_LOCK was being held (see https://github.com/DataDog/dd-trace-rb/pull/1387
31
+ # and https://github.com/DataDog/dd-trace-rb/pull/1373#issuecomment-799593022 ).
32
+ #
33
+ # Technically on MRI we could get away without this lock, but on non-MRI Rubies, we may run into issues because
34
+ # we fall into the "UnsafeDCLFactory" case of https://shipilev.net/blog/2014/safe-public-construction/ .
35
+ # Specifically, on JRuby reads from the @components do NOT have volatile semantics, and on TruffleRuby they do
36
+ # BUT just as an implementation detail, see https://github.com/jruby/jruby/wiki/Concurrency-in-jruby#volatility and
37
+ # https://github.com/DataDog/dd-trace-rb/pull/1329#issuecomment-776750377 .
38
+ # Concurrency is hard.
39
+ COMPONENTS_READ_LOCK = Mutex.new
40
+ private_constant :COMPONENTS_READ_LOCK
41
+
42
+ attr_writer :configuration
43
+
44
+ # Current Datadog configuration.
45
+ #
46
+ # Access to non-global configuration will raise an error.
47
+ #
48
+ # To modify the configuration, use {.configure}.
49
+ #
50
+ # @return [Datadog::Core::Configuration::Settings]
51
+ # @!attribute [r] configuration
52
+ # @public_api
53
+ def configuration
54
+ @configuration ||= Settings.new
55
+ end
56
+
57
+ # Apply global configuration changes to `Datadog`. An example of a {.configure} call:
58
+ #
59
+ # ```
60
+ # Datadog.configure do |c|
61
+ # c.service = 'my-service'
62
+ # c.env = 'staging'
63
+ # # c.diagnostics.debug = true # Enables debug output
64
+ # end
65
+ # ```
66
+ #
67
+ # See {Datadog::Core::Configuration::Settings} for all available options, defaults, and
68
+ # available environment variables for configuration.
69
+ #
70
+ # Only permits access to global configuration settings; others will raise an error.
71
+ # If you wish to configure a setting for a specific Datadog component (e.g. Tracing),
72
+ # use the corresponding `Datadog::COMPONENT.configure` method instead.
73
+ #
74
+ # Because many configuration changes require restarting internal components,
75
+ # invoking {.configure} is the only safe way to change `Datadog` configuration.
76
+ #
77
+ # Successive calls to {.configure} maintain the previous configuration values:
78
+ # configuration is additive between {.configure} calls.
79
+ #
80
+ # The yielded configuration `c` comes pre-populated from environment variables, if
81
+ # any are applicable.
82
+ #
83
+ # @yieldparam [Datadog::Core::Configuration::Settings] c the mutable configuration object
84
+ def configure
85
+ configuration = self.configuration
86
+ yield(configuration)
87
+
88
+ safely_synchronize do |write_components|
89
+ write_components.call(
90
+ if components?
91
+ replace_components!(configuration, @components)
92
+ else
93
+ build_components(configuration)
94
+ end
95
+ )
96
+ end
97
+
98
+ configuration
99
+ end
100
+
101
+ # Apply configuration changes only to a specific Ruby object.
102
+ #
103
+ # Certain integrations or Datadog features may use these
104
+ # settings to customize behavior for this object.
105
+ #
106
+ # An example of a {.configure_onto} call:
107
+ #
108
+ # ```
109
+ # client = Net::HTTP.new(host, port)
110
+ # Datadog.configure_onto(client, service_name: 'api-requests', split_by_domain: true)
111
+ # ```
112
+ #
113
+ # In this example, it will configure the `client` object with custom options
114
+ # `service_name: 'api-requests', split_by_domain: true`. The `Net::HTTP` integration
115
+ # will then use these customized options when the `client` is used, whereas other
116
+ # clients will use the `service_name: 'http-requests'` configuration provided to the
117
+ # `Datadog.configure` call block.
118
+ #
119
+ # {.configure_onto} is used to separate cases where spans generated by certain objects
120
+ # require exceptional options.
121
+ #
122
+ # The configuration keyword arguments provided should match well known options defined
123
+ # in the integration or feature that would use them.
124
+ #
125
+ # For example, for `Datadog.configure_onto(redis_client, **opts)`, `opts` can be
126
+ # any of the options in the Redis {Datadog::Tracing::Contrib::Redis::Configuration::Settings} class.
127
+ #
128
+ # @param [Object] target the object to receive configuration options
129
+ # @param [Hash] opts keyword arguments respective to the integration this object belongs to
130
+ # @public_api
131
+ def configure_onto(target, **opts)
132
+ Pin.set_on(target, **opts)
133
+ end
134
+
135
+ # Get configuration changes applied only to a specific Ruby object, via {.configure_onto}.
136
+ # An example of an object with specific configuration:
137
+ #
138
+ # ```
139
+ # client = Net::HTTP.new(host, port)
140
+ # Datadog.configure_onto(client, service_name: 'api-requests', split_by_domain: true)
141
+ # config = Datadog.configuration_for(client)
142
+ # config[:service_name] # => 'api-requests'
143
+ # config[:split_by_domain] # => true
144
+ # ```
145
+ #
146
+ # @param [Object] target the object to receive configuration options
147
+ # @param [Object] option an option to retrieve from the object configuration
148
+ # @public_api
149
+ def configuration_for(target, option = nil)
150
+ pin = Pin.get_from(target)
151
+ return pin unless option
152
+
153
+ pin[option] if pin
154
+ end
155
+
156
+ def_delegators \
157
+ :components,
158
+ :health_metrics
159
+
160
+ def logger
161
+ # avoid initializing components if they didn't already exist
162
+ current_components = components(allow_initialization: false)
163
+
164
+ if current_components
165
+ @temp_logger = nil
166
+ current_components.logger
167
+ else
168
+ logger_without_components
169
+ end
170
+ end
171
+
172
+ # Gracefully shuts down all components.
173
+ #
174
+ # Components will still respond to method calls as usual,
175
+ # but might not internally perform their work after shutdown.
176
+ #
177
+ # This avoids errors being raised across the host application
178
+ # during shutdown, while allowing for graceful decommission of resources.
179
+ #
180
+ # Components won't be automatically reinitialized after a shutdown.
181
+ def shutdown!
182
+ safely_synchronize do
183
+ @components.shutdown! if components?
184
+ end
185
+ end
186
+
187
+ protected
188
+
189
+ def components(allow_initialization: true)
190
+ current_components = COMPONENTS_READ_LOCK.synchronize { defined?(@components) && @components }
191
+ return current_components if current_components || !allow_initialization
192
+
193
+ safely_synchronize do |write_components|
194
+ (defined?(@components) && @components) || write_components.call(build_components(configuration))
195
+ end
196
+ end
197
+
198
+ private
199
+
200
+ # Gracefully shuts down Datadog components and disposes of component references,
201
+ # allowing execution to start anew.
202
+ #
203
+ # In contrast with +#shutdown!+, components will be automatically
204
+ # reinitialized after a reset.
205
+ #
206
+ # Used internally to ensure a clean environment between test runs.
207
+ def reset!
208
+ safely_synchronize do |write_components|
209
+ @components.shutdown! if components?
210
+ write_components.call(nil)
211
+ configuration.reset!
212
+ end
213
+ end
214
+
215
+ def safely_synchronize
216
+ # Writes to @components should only happen through this proc. Because this proc is only accessible to callers of
217
+ # safely_synchronize, this forces all writers to go through this method.
218
+ write_components = proc do |new_value|
219
+ COMPONENTS_READ_LOCK.synchronize { @components = new_value }
220
+ end
221
+
222
+ COMPONENTS_WRITE_LOCK.synchronize do
223
+ begin
224
+ yield write_components
225
+ rescue ThreadError => e
226
+ logger_without_components.error(
227
+ 'Detected deadlock during ddtrace initialization. ' \
228
+ 'Please report this at https://github.com/DataDog/dd-trace-rb/blob/master/CONTRIBUTING.md#found-a-bug' \
229
+ "\n\tSource:\n\t#{Array(e.backtrace).join("\n\t")}"
230
+ )
231
+ nil
232
+ end
233
+ end
234
+ end
235
+
236
+ def components?
237
+ # This does not need to grab the COMPONENTS_READ_LOCK because it's not returning the components
238
+ (defined?(@components) && @components) != nil
239
+ end
240
+
241
+ def build_components(settings)
242
+ components = Components.new(settings)
243
+ components.startup!(settings)
244
+ components
245
+ end
246
+
247
+ def replace_components!(settings, old)
248
+ components = Components.new(settings)
249
+
250
+ old.shutdown!(components)
251
+ components.startup!(settings)
252
+ components
253
+ end
254
+
255
+ def logger_without_components
256
+ # Use default logger without initializing components.
257
+ # This enables logging during initialization, otherwise we'd run into deadlocks.
258
+ @temp_logger ||= begin
259
+ logger = configuration.logger.instance || Core::Logger.new($stdout)
260
+ logger.level = configuration.diagnostics.debug ? ::Logger::DEBUG : configuration.logger.level
261
+ logger
262
+ end
263
+ end
264
+
265
+ # Called from our at_exit hook whenever there was a pending Interrupt exception (e.g. typically due to ctrl+c)
266
+ # to print a nice message whenever we're taking a bit longer than usual to finish the process.
267
+ def handle_interrupt_shutdown!
268
+ logger = Datadog.logger
269
+ shutdown_thread = Thread.new { shutdown! }
270
+ print_message_treshold_seconds = 0.2
271
+
272
+ slow_shutdown = shutdown_thread.join(print_message_treshold_seconds).nil?
273
+
274
+ if slow_shutdown
275
+ logger.info 'Reporting remaining data... Press ctrl+c to exit immediately.'
276
+ shutdown_thread.join
277
+ end
278
+
279
+ nil
280
+ end
281
+ end
282
+ end
283
+ end
@@ -0,0 +1,282 @@
1
+ # typed: true
2
+ require 'date'
3
+ require 'json'
4
+ require 'rbconfig'
5
+
6
+ module Datadog
7
+ module Core
8
+ module Diagnostics
9
+ # A holistic collection of the environment in which ddtrace is running.
10
+ # This logger should allow for easy reporting by users to Datadog support.
11
+ #
12
+ module EnvironmentLogger
13
+ class << self
14
+ # Outputs environment information to {Datadog.logger}.
15
+ # Executes only once for the lifetime of the program.
16
+ def log!(transport_responses)
17
+ return if (defined?(@executed) && @executed) || !log?
18
+
19
+ @executed = true
20
+
21
+ data = EnvironmentCollector.new.collect!(transport_responses)
22
+ data.reject! { |_, v| v.nil? } # Remove empty values from hash output
23
+
24
+ log_environment!(data.to_json)
25
+ log_error!('Agent Error'.freeze, data[:agent_error]) if data[:agent_error]
26
+ rescue => e
27
+ Datadog.logger.warn("Failed to collect environment information: #{e} Location: #{Array(e.backtrace).first}")
28
+ end
29
+
30
+ private
31
+
32
+ def log_environment!(line)
33
+ Datadog.logger.info("DATADOG CONFIGURATION - #{line}")
34
+ end
35
+
36
+ def log_error!(type, error)
37
+ Datadog.logger.warn("DATADOG DIAGNOSTIC - #{type}: #{error}")
38
+ end
39
+
40
+ # Are we logging the environment data?
41
+ def log?
42
+ startup_logs_enabled = Datadog.configuration.diagnostics.startup_logs.enabled
43
+ if startup_logs_enabled.nil?
44
+ !repl? # Suppress logs if we running in a REPL
45
+ else
46
+ startup_logs_enabled
47
+ end
48
+ end
49
+
50
+ REPL_PROGRAM_NAMES = %w[irb pry].freeze
51
+
52
+ def repl?
53
+ REPL_PROGRAM_NAMES.include?($PROGRAM_NAME)
54
+ end
55
+ end
56
+ end
57
+
58
+ # Collects environment information for diagnostic logging
59
+ class EnvironmentCollector
60
+ # @return [String] current time in ISO8601 format
61
+ def date
62
+ DateTime.now.iso8601
63
+ end
64
+
65
+ # Best portable guess of OS information.
66
+ # @return [String] platform string
67
+ def os_name
68
+ RbConfig::CONFIG['host'.freeze]
69
+ end
70
+
71
+ # @return [String] ddtrace version
72
+ def version
73
+ DDTrace::VERSION::STRING
74
+ end
75
+
76
+ # @return [String] "ruby"
77
+ def lang
78
+ Core::Environment::Ext::LANG
79
+ end
80
+
81
+ # Supported Ruby language version.
82
+ # Will be distinct from VM version for non-MRI environments.
83
+ # @return [String]
84
+ def lang_version
85
+ Core::Environment::Ext::LANG_VERSION
86
+ end
87
+
88
+ # @return [String] configured application environment
89
+ def env
90
+ Datadog.configuration.env
91
+ end
92
+
93
+ # @return [Boolean, nil]
94
+ def enabled
95
+ Datadog.configuration.tracing.enabled
96
+ end
97
+
98
+ # @return [String] configured application service name
99
+ def service
100
+ Datadog.configuration.service
101
+ end
102
+
103
+ # @return [String] configured application version
104
+ def dd_version
105
+ Datadog.configuration.version
106
+ end
107
+
108
+ # @return [String] target agent URL for trace flushing
109
+ def agent_url
110
+ # Retrieve the effect agent URL, regardless of how it was configured
111
+ transport = Tracing.send(:tracer).writer.transport
112
+ adapter = transport.client.api.adapter
113
+ adapter.url
114
+ end
115
+
116
+ # Error returned by Datadog agent during a tracer flush attempt
117
+ # @return [String] concatenated list of transport errors
118
+ def agent_error(transport_responses)
119
+ error_responses = transport_responses.reject(&:ok?)
120
+
121
+ return nil if error_responses.empty?
122
+
123
+ error_responses.map(&:inspect).join(','.freeze)
124
+ end
125
+
126
+ # @return [Boolean, nil] debug mode enabled in configuration
127
+ def debug
128
+ !!Datadog.configuration.diagnostics.debug
129
+ end
130
+
131
+ # @return [Boolean, nil] analytics enabled in configuration
132
+ def analytics_enabled
133
+ !!Datadog.configuration.tracing.analytics.enabled
134
+ end
135
+
136
+ # @return [Numeric, nil] tracer sample rate configured
137
+ def sample_rate
138
+ sampler = Datadog.configuration.tracing.sampler
139
+ return nil unless sampler
140
+
141
+ sampler.sample_rate(nil) rescue nil
142
+ end
143
+
144
+ # DEV: We currently only support SimpleRule instances.
145
+ # DEV: These are the most commonly used rules.
146
+ # DEV: We should expand support for other rules in the future,
147
+ # DEV: although it is tricky to serialize arbitrary rules.
148
+ #
149
+ # @return [Hash, nil] sample rules configured
150
+ def sampling_rules
151
+ sampler = Datadog.configuration.tracing.sampler
152
+ return nil unless sampler.is_a?(Tracing::Sampling::PrioritySampler) &&
153
+ sampler.priority_sampler.is_a?(Tracing::Sampling::RuleSampler)
154
+
155
+ sampler.priority_sampler.rules.map do |rule|
156
+ next unless rule.is_a?(Tracing::Sampling::SimpleRule)
157
+
158
+ {
159
+ name: rule.matcher.name,
160
+ service: rule.matcher.service,
161
+ sample_rate: rule.sampler.sample_rate(nil)
162
+ }
163
+ end.compact
164
+ end
165
+
166
+ # @return [Hash, nil] concatenated list of global tracer tags configured
167
+ def tags
168
+ tags = Datadog.configuration.tags
169
+ return nil if tags.empty?
170
+
171
+ hash_serializer(tags)
172
+ end
173
+
174
+ # @return [Boolean, nil] runtime metrics enabled in configuration
175
+ def runtime_metrics_enabled
176
+ Datadog.configuration.runtime_metrics.enabled
177
+ end
178
+
179
+ # Concatenated list of integrations activated, with their gem version.
180
+ # Example: "rails@6.0.3,rack@2.2.3"
181
+ #
182
+ # @return [String, nil]
183
+ def integrations_loaded
184
+ integrations = instrumented_integrations
185
+ return if integrations.empty?
186
+
187
+ integrations.map { |name, integration| "#{name}@#{integration.class.version}" }.join(','.freeze)
188
+ end
189
+
190
+ # Ruby VM name and version.
191
+ # Examples: "ruby-2.7.1", "jruby-9.2.11.1", "truffleruby-20.1.0"
192
+ # @return [String, nil]
193
+ def vm
194
+ # RUBY_ENGINE_VERSION returns the VM version, which
195
+ # will differ from RUBY_VERSION for non-mri VMs.
196
+ if defined?(RUBY_ENGINE_VERSION)
197
+ "#{RUBY_ENGINE}-#{RUBY_ENGINE_VERSION}"
198
+ else
199
+ # Ruby < 2.3 doesn't support RUBY_ENGINE_VERSION
200
+ "#{RUBY_ENGINE}-#{RUBY_VERSION}"
201
+ end
202
+ end
203
+
204
+ # @return [Boolean, nil] partial flushing enabled in configuration
205
+ def partial_flushing_enabled
206
+ !!Datadog.configuration.tracing.partial_flush.enabled
207
+ end
208
+
209
+ # @return [Boolean, nil] priority sampling enabled in configuration
210
+ def priority_sampling_enabled
211
+ !!Datadog.configuration.tracing.priority_sampling
212
+ end
213
+
214
+ # @return [Boolean, nil] health metrics enabled in configuration
215
+ def health_metrics_enabled
216
+ !!Datadog.configuration.diagnostics.health_metrics.enabled
217
+ end
218
+
219
+ # TODO: Populate when profiling is implemented
220
+ # def profiling_enabled
221
+ # end
222
+
223
+ # TODO: Populate when automatic log correlation is implemented
224
+ # def logs_correlation_enabled
225
+ # end
226
+
227
+ # @return [Hash] environment information available at call time
228
+ def collect!(transport_responses)
229
+ {
230
+ date: date,
231
+ os_name: os_name,
232
+ version: version,
233
+ lang: lang,
234
+ lang_version: lang_version,
235
+ env: env,
236
+ enabled: enabled,
237
+ service: service,
238
+ dd_version: dd_version,
239
+ agent_url: agent_url,
240
+ agent_error: agent_error(transport_responses),
241
+ debug: debug,
242
+ analytics_enabled: analytics_enabled,
243
+ sample_rate: sample_rate,
244
+ sampling_rules: sampling_rules,
245
+ tags: tags,
246
+ runtime_metrics_enabled: runtime_metrics_enabled,
247
+ integrations_loaded: integrations_loaded,
248
+ vm: vm,
249
+ partial_flushing_enabled: partial_flushing_enabled,
250
+ priority_sampling_enabled: priority_sampling_enabled,
251
+ health_metrics_enabled: health_metrics_enabled,
252
+ **instrumented_integrations_settings
253
+ }
254
+ end
255
+
256
+ private
257
+
258
+ def instrumented_integrations
259
+ Datadog.configuration.instrumented_integrations
260
+ end
261
+
262
+ # Capture all active integration settings into "integrationName_settingName: value" entries.
263
+ def instrumented_integrations_settings
264
+ instrumented_integrations.flat_map do |name, integration|
265
+ integration.configuration.to_h.flat_map do |setting, value|
266
+ next [] if setting == :tracer # Skip internal Ruby objects
267
+
268
+ # Convert value to a string to avoid custom #to_json
269
+ # handlers possibly causing errors.
270
+ [[:"integration_#{name}_#{setting}", value.to_s]]
271
+ end
272
+ end.to_h
273
+ end
274
+
275
+ # Outputs "k1:v1,k2:v2,..."
276
+ def hash_serializer(h)
277
+ h.map { |k, v| "#{k}:#{v}" }.join(','.freeze)
278
+ end
279
+ end
280
+ end
281
+ end
282
+ end
@@ -0,0 +1,40 @@
1
+ # typed: true
2
+ module Datadog
3
+ module Core
4
+ module Diagnostics
5
+ # @public_api
6
+ module Ext
7
+ DD_TRACE_STARTUP_LOGS = 'DD_TRACE_STARTUP_LOGS'.freeze
8
+ DD_TRACE_DEBUG = 'DD_TRACE_DEBUG'.freeze
9
+ DD_TRACE_ENABLED = 'DD_TRACE_ENABLED'.freeze
10
+ # Health
11
+ module Health
12
+ # Metrics
13
+ module Metrics
14
+ ENV_ENABLED = 'DD_HEALTH_METRICS_ENABLED'.freeze
15
+
16
+ METRIC_API_ERRORS = 'datadog.tracer.api.errors'.freeze
17
+ METRIC_API_REQUESTS = 'datadog.tracer.api.requests'.freeze
18
+ METRIC_API_RESPONSES = 'datadog.tracer.api.responses'.freeze
19
+ METRIC_ERROR_CONTEXT_OVERFLOW = 'datadog.tracer.error.context_overflow'.freeze
20
+ METRIC_ERROR_INSTRUMENTATION_PATCH = 'datadog.tracer.error.instrumentation_patch'.freeze
21
+ METRIC_ERROR_SPAN_FINISH = 'datadog.tracer.error.span_finish'.freeze
22
+ METRIC_ERROR_UNFINISHED_SPANS = 'datadog.tracer.error.unfinished_spans'.freeze
23
+ METRIC_INSTRUMENTATION_PATCHED = 'datadog.tracer.instrumentation_patched'.freeze
24
+ METRIC_QUEUE_ACCEPTED = 'datadog.tracer.queue.accepted'.freeze
25
+ METRIC_QUEUE_ACCEPTED_LENGTHS = 'datadog.tracer.queue.accepted_lengths'.freeze
26
+ METRIC_QUEUE_DROPPED = 'datadog.tracer.queue.dropped'.freeze
27
+ METRIC_QUEUE_LENGTH = 'datadog.tracer.queue.length'.freeze
28
+ METRIC_QUEUE_MAX_LENGTH = 'datadog.tracer.queue.max_length'.freeze
29
+ METRIC_QUEUE_SPANS = 'datadog.tracer.queue.spans'.freeze
30
+ METRIC_SAMPLING_SERVICE_CACHE_LENGTH = 'datadog.tracer.sampling.service_cache_length'.freeze
31
+ METRIC_TRACES_FILTERED = 'datadog.tracer.traces.filtered'.freeze
32
+ METRIC_TRANSPORT_CHUNKED = 'datadog.tracer.transport.chunked'.freeze
33
+ METRIC_TRANSPORT_TRACE_TOO_LARGE = 'datadog.tracer.transport.trace_too_large'.freeze
34
+ METRIC_WRITER_CPU_TIME = 'datadog.tracer.writer.cpu_time'.freeze
35
+ end
36
+ end
37
+ end
38
+ end
39
+ end
40
+ end
@@ -0,0 +1,36 @@
1
+ # typed: false
2
+ require 'datadog/core/diagnostics/ext'
3
+ require 'datadog/core/metrics/client'
4
+
5
+ module Datadog
6
+ module Core
7
+ module Diagnostics
8
+ # Health-related diagnostics
9
+ module Health
10
+ # Health metrics for diagnostics
11
+ class Metrics < Core::Metrics::Client
12
+ count :api_errors, Ext::Health::Metrics::METRIC_API_ERRORS
13
+ count :api_requests, Ext::Health::Metrics::METRIC_API_REQUESTS
14
+ count :api_responses, Ext::Health::Metrics::METRIC_API_RESPONSES
15
+ count :error_context_overflow, Ext::Health::Metrics::METRIC_ERROR_CONTEXT_OVERFLOW
16
+ count :error_instrumentation_patch, Ext::Health::Metrics::METRIC_ERROR_INSTRUMENTATION_PATCH
17
+ count :error_span_finish, Ext::Health::Metrics::METRIC_ERROR_SPAN_FINISH
18
+ count :error_unfinished_spans, Ext::Health::Metrics::METRIC_ERROR_UNFINISHED_SPANS
19
+ count :instrumentation_patched, Ext::Health::Metrics::METRIC_INSTRUMENTATION_PATCHED
20
+ count :queue_accepted, Ext::Health::Metrics::METRIC_QUEUE_ACCEPTED
21
+ count :queue_accepted_lengths, Ext::Health::Metrics::METRIC_QUEUE_ACCEPTED_LENGTHS
22
+ count :queue_dropped, Ext::Health::Metrics::METRIC_QUEUE_DROPPED
23
+ count :traces_filtered, Ext::Health::Metrics::METRIC_TRACES_FILTERED
24
+ count :transport_trace_too_large, Ext::Health::Metrics::METRIC_TRANSPORT_TRACE_TOO_LARGE
25
+ count :transport_chunked, Ext::Health::Metrics::METRIC_TRANSPORT_CHUNKED
26
+ count :writer_cpu_time, Ext::Health::Metrics::METRIC_WRITER_CPU_TIME
27
+
28
+ gauge :queue_length, Ext::Health::Metrics::METRIC_QUEUE_LENGTH
29
+ gauge :queue_max_length, Ext::Health::Metrics::METRIC_QUEUE_MAX_LENGTH
30
+ gauge :queue_spans, Ext::Health::Metrics::METRIC_QUEUE_SPANS
31
+ gauge :sampling_service_cache_length, Ext::Health::Metrics::METRIC_SAMPLING_SERVICE_CACHE_LENGTH
32
+ end
33
+ end
34
+ end
35
+ end
36
+ end