ddtrace 0.54.2 → 1.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1192) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +528 -2
  3. data/LICENSE-3rdparty.csv +6 -1
  4. data/README.md +10 -1
  5. data/bin/ddtracerb +5 -5
  6. data/ext/ddtrace_profiling_loader/ddtrace_profiling_loader.c +134 -0
  7. data/ext/ddtrace_profiling_loader/extconf.rb +74 -0
  8. data/ext/ddtrace_profiling_native_extension/NativeExtensionDesign.md +79 -9
  9. data/ext/ddtrace_profiling_native_extension/clock_id.h +22 -1
  10. data/ext/ddtrace_profiling_native_extension/clock_id_from_pthread.c +33 -10
  11. data/ext/ddtrace_profiling_native_extension/clock_id_noop.c +11 -2
  12. data/ext/ddtrace_profiling_native_extension/collectors_cpu_and_wall_time.c +899 -0
  13. data/ext/ddtrace_profiling_native_extension/collectors_cpu_and_wall_time.h +9 -0
  14. data/ext/ddtrace_profiling_native_extension/collectors_cpu_and_wall_time_worker.c +776 -0
  15. data/ext/ddtrace_profiling_native_extension/collectors_dynamic_sampling_rate.c +142 -0
  16. data/ext/ddtrace_profiling_native_extension/collectors_dynamic_sampling_rate.h +14 -0
  17. data/ext/ddtrace_profiling_native_extension/collectors_idle_sampling_helper.c +241 -0
  18. data/ext/ddtrace_profiling_native_extension/collectors_idle_sampling_helper.h +3 -0
  19. data/ext/ddtrace_profiling_native_extension/collectors_stack.c +390 -0
  20. data/ext/ddtrace_profiling_native_extension/collectors_stack.h +18 -0
  21. data/ext/ddtrace_profiling_native_extension/extconf.rb +165 -114
  22. data/ext/ddtrace_profiling_native_extension/helpers.h +17 -0
  23. data/ext/ddtrace_profiling_native_extension/http_transport.c +353 -0
  24. data/ext/ddtrace_profiling_native_extension/libdatadog_helpers.h +14 -0
  25. data/ext/ddtrace_profiling_native_extension/native_extension_helpers.rb +297 -0
  26. data/ext/ddtrace_profiling_native_extension/private_vm_api_access.c +810 -9
  27. data/ext/ddtrace_profiling_native_extension/private_vm_api_access.h +42 -0
  28. data/ext/ddtrace_profiling_native_extension/profiling.c +231 -2
  29. data/ext/ddtrace_profiling_native_extension/ruby_helpers.c +110 -0
  30. data/ext/ddtrace_profiling_native_extension/ruby_helpers.h +89 -0
  31. data/ext/ddtrace_profiling_native_extension/setup_signal_handler.c +115 -0
  32. data/ext/ddtrace_profiling_native_extension/setup_signal_handler.h +11 -0
  33. data/ext/ddtrace_profiling_native_extension/stack_recorder.c +487 -0
  34. data/ext/ddtrace_profiling_native_extension/stack_recorder.h +39 -0
  35. data/ext/ddtrace_profiling_native_extension/time_helpers.c +17 -0
  36. data/ext/ddtrace_profiling_native_extension/time_helpers.h +10 -0
  37. data/lib/datadog/appsec/assets/blocked.html +99 -0
  38. data/lib/datadog/appsec/assets/blocked.json +1 -0
  39. data/lib/datadog/appsec/assets/blocked.text +5 -0
  40. data/lib/datadog/appsec/assets/waf_rules/README.md +7 -0
  41. data/lib/datadog/appsec/assets/waf_rules/recommended.json +6521 -0
  42. data/lib/datadog/appsec/assets/waf_rules/risky.json +1499 -0
  43. data/lib/datadog/appsec/assets/waf_rules/strict.json +1533 -0
  44. data/lib/datadog/appsec/assets.rb +38 -0
  45. data/lib/datadog/appsec/autoload.rb +18 -0
  46. data/lib/datadog/appsec/configuration/settings.rb +198 -0
  47. data/lib/datadog/appsec/configuration.rb +84 -0
  48. data/lib/datadog/appsec/contrib/auto_instrument.rb +27 -0
  49. data/lib/datadog/appsec/contrib/configuration/settings.rb +20 -0
  50. data/lib/datadog/appsec/contrib/integration.rb +37 -0
  51. data/lib/datadog/appsec/contrib/patcher.rb +12 -0
  52. data/lib/datadog/appsec/contrib/rack/configuration/settings.rb +22 -0
  53. data/lib/datadog/appsec/contrib/rack/ext.rb +15 -0
  54. data/lib/datadog/appsec/contrib/rack/gateway/watcher.rb +174 -0
  55. data/lib/datadog/appsec/contrib/rack/integration.rb +49 -0
  56. data/lib/datadog/appsec/contrib/rack/patcher.rb +32 -0
  57. data/lib/datadog/appsec/contrib/rack/reactive/request.rb +83 -0
  58. data/lib/datadog/appsec/contrib/rack/reactive/request_body.rb +64 -0
  59. data/lib/datadog/appsec/contrib/rack/reactive/response.rb +64 -0
  60. data/lib/datadog/appsec/contrib/rack/request.rb +78 -0
  61. data/lib/datadog/appsec/contrib/rack/request_body_middleware.rb +41 -0
  62. data/lib/datadog/appsec/contrib/rack/request_middleware.rb +139 -0
  63. data/lib/datadog/appsec/contrib/rack/response.rb +24 -0
  64. data/lib/datadog/appsec/contrib/rails/configuration/settings.rb +22 -0
  65. data/lib/datadog/appsec/contrib/rails/ext.rb +15 -0
  66. data/lib/datadog/appsec/contrib/rails/framework.rb +30 -0
  67. data/lib/datadog/appsec/contrib/rails/gateway/watcher.rb +82 -0
  68. data/lib/datadog/appsec/contrib/rails/integration.rb +48 -0
  69. data/lib/datadog/appsec/contrib/rails/patcher.rb +159 -0
  70. data/lib/datadog/appsec/contrib/rails/reactive/action.rb +68 -0
  71. data/lib/datadog/appsec/contrib/rails/request.rb +36 -0
  72. data/lib/datadog/appsec/contrib/rails/request_middleware.rb +20 -0
  73. data/lib/datadog/appsec/contrib/sinatra/configuration/settings.rb +22 -0
  74. data/lib/datadog/appsec/contrib/sinatra/ext.rb +16 -0
  75. data/lib/datadog/appsec/contrib/sinatra/framework.rb +34 -0
  76. data/lib/datadog/appsec/contrib/sinatra/gateway/watcher.rb +126 -0
  77. data/lib/datadog/appsec/contrib/sinatra/integration.rb +48 -0
  78. data/lib/datadog/appsec/contrib/sinatra/patcher.rb +151 -0
  79. data/lib/datadog/appsec/contrib/sinatra/reactive/routed.rb +63 -0
  80. data/lib/datadog/appsec/contrib/sinatra/request_middleware.rb +20 -0
  81. data/lib/datadog/appsec/event.rb +117 -0
  82. data/lib/datadog/appsec/extensions.rb +128 -0
  83. data/lib/datadog/appsec/instrumentation/gateway.rb +58 -0
  84. data/lib/datadog/appsec/processor.rb +198 -0
  85. data/lib/datadog/appsec/rate_limiter.rb +60 -0
  86. data/lib/datadog/appsec/reactive/address_hash.rb +18 -0
  87. data/lib/datadog/appsec/reactive/engine.rb +44 -0
  88. data/lib/datadog/appsec/reactive/operation.rb +51 -0
  89. data/lib/datadog/appsec/reactive/subscriber.rb +18 -0
  90. data/lib/datadog/appsec/response.rb +54 -0
  91. data/lib/datadog/appsec.rb +23 -0
  92. data/lib/datadog/ci/configuration/components.rb +9 -8
  93. data/lib/datadog/ci/configuration/settings.rb +20 -4
  94. data/lib/datadog/ci/contrib/cucumber/configuration/settings.rb +5 -3
  95. data/lib/datadog/ci/contrib/cucumber/ext.rb +2 -0
  96. data/lib/datadog/ci/contrib/cucumber/formatter.rb +9 -14
  97. data/lib/datadog/ci/contrib/cucumber/instrumentation.rb +3 -2
  98. data/lib/datadog/ci/contrib/cucumber/integration.rb +6 -5
  99. data/lib/datadog/ci/contrib/cucumber/patcher.rb +4 -3
  100. data/lib/datadog/ci/contrib/rspec/configuration/settings.rb +5 -3
  101. data/lib/datadog/ci/contrib/rspec/example.rb +9 -14
  102. data/lib/datadog/ci/contrib/rspec/ext.rb +2 -0
  103. data/lib/datadog/ci/contrib/rspec/integration.rb +6 -5
  104. data/lib/datadog/ci/contrib/rspec/patcher.rb +4 -3
  105. data/lib/datadog/ci/ext/app_types.rb +2 -1
  106. data/lib/datadog/ci/ext/environment.rb +149 -117
  107. data/lib/datadog/ci/ext/settings.rb +2 -1
  108. data/lib/datadog/ci/ext/test.rb +1 -0
  109. data/lib/datadog/ci/extensions.rb +7 -6
  110. data/lib/datadog/ci/flush.rb +38 -0
  111. data/lib/datadog/ci/test.rb +17 -15
  112. data/lib/datadog/ci.rb +7 -4
  113. data/lib/datadog/core/buffer/cruby.rb +55 -0
  114. data/lib/datadog/core/buffer/random.rb +134 -0
  115. data/lib/datadog/core/buffer/thread_safe.rb +58 -0
  116. data/lib/datadog/core/chunker.rb +35 -0
  117. data/lib/datadog/core/configuration/agent_settings_resolver.rb +362 -0
  118. data/lib/datadog/core/configuration/base.rb +98 -0
  119. data/lib/datadog/core/configuration/components.rb +462 -0
  120. data/lib/datadog/core/configuration/dependency_resolver.rb +28 -0
  121. data/lib/datadog/core/configuration/ext.rb +18 -0
  122. data/lib/datadog/core/configuration/option.rb +69 -0
  123. data/lib/datadog/core/configuration/option_definition.rb +126 -0
  124. data/lib/datadog/core/configuration/option_definition_set.rb +22 -0
  125. data/lib/datadog/core/configuration/option_set.rb +10 -0
  126. data/lib/datadog/core/configuration/options.rb +118 -0
  127. data/lib/datadog/core/configuration/settings.rb +444 -0
  128. data/lib/datadog/core/configuration.rb +289 -0
  129. data/lib/datadog/core/diagnostics/environment_logger.rb +287 -0
  130. data/lib/datadog/core/diagnostics/health.rb +19 -0
  131. data/lib/datadog/core/encoding.rb +76 -0
  132. data/lib/datadog/core/environment/cgroup.rb +5 -2
  133. data/lib/datadog/core/environment/class_count.rb +1 -0
  134. data/lib/datadog/core/environment/container.rb +4 -2
  135. data/lib/datadog/core/environment/ext.rb +29 -10
  136. data/lib/datadog/core/environment/gc.rb +1 -0
  137. data/lib/datadog/core/environment/identity.rb +12 -5
  138. data/lib/datadog/core/environment/platform.rb +40 -0
  139. data/lib/datadog/core/environment/socket.rb +9 -2
  140. data/lib/datadog/core/environment/thread_count.rb +1 -0
  141. data/lib/datadog/core/environment/variable_helpers.rb +85 -11
  142. data/lib/datadog/core/environment/vm_cache.rb +1 -0
  143. data/lib/datadog/core/error.rb +101 -0
  144. data/lib/datadog/core/extensions.rb +16 -0
  145. data/lib/datadog/core/git/ext.rb +35 -0
  146. data/lib/datadog/core/header_collection.rb +41 -0
  147. data/lib/datadog/core/logger.rb +46 -0
  148. data/lib/datadog/core/logging/ext.rb +11 -0
  149. data/lib/datadog/core/metrics/client.rb +198 -0
  150. data/lib/datadog/core/metrics/ext.rb +20 -0
  151. data/lib/datadog/core/metrics/helpers.rb +25 -0
  152. data/lib/datadog/core/metrics/logging.rb +44 -0
  153. data/lib/datadog/core/metrics/metric.rb +14 -0
  154. data/lib/datadog/core/metrics/options.rb +50 -0
  155. data/lib/datadog/core/pin.rb +75 -0
  156. data/lib/datadog/core/runtime/ext.rb +28 -0
  157. data/lib/datadog/core/runtime/metrics.rb +126 -0
  158. data/lib/datadog/core/telemetry/client.rb +79 -0
  159. data/lib/datadog/core/telemetry/collector.rb +232 -0
  160. data/lib/datadog/core/telemetry/emitter.rb +48 -0
  161. data/lib/datadog/core/telemetry/event.rb +71 -0
  162. data/lib/datadog/core/telemetry/ext.rb +11 -0
  163. data/lib/datadog/core/telemetry/heartbeat.rb +37 -0
  164. data/lib/datadog/core/telemetry/http/adapters/net.rb +113 -0
  165. data/lib/datadog/core/telemetry/http/env.rb +20 -0
  166. data/lib/datadog/core/telemetry/http/ext.rb +20 -0
  167. data/lib/datadog/core/telemetry/http/response.rb +68 -0
  168. data/lib/datadog/core/telemetry/http/transport.rb +53 -0
  169. data/lib/datadog/core/telemetry/v1/app_event.rb +52 -0
  170. data/lib/datadog/core/telemetry/v1/application.rb +86 -0
  171. data/lib/datadog/core/telemetry/v1/configuration.rb +25 -0
  172. data/lib/datadog/core/telemetry/v1/dependency.rb +36 -0
  173. data/lib/datadog/core/telemetry/v1/host.rb +51 -0
  174. data/lib/datadog/core/telemetry/v1/integration.rb +58 -0
  175. data/lib/datadog/core/telemetry/v1/product.rb +28 -0
  176. data/lib/datadog/core/telemetry/v1/telemetry_request.rb +100 -0
  177. data/lib/datadog/core/utils/compression.rb +36 -0
  178. data/lib/datadog/core/utils/forking.rb +63 -0
  179. data/lib/datadog/core/utils/object_set.rb +43 -0
  180. data/lib/datadog/core/utils/only_once.rb +44 -0
  181. data/lib/datadog/core/utils/safe_dup.rb +27 -0
  182. data/lib/datadog/core/utils/sequence.rb +26 -0
  183. data/lib/datadog/core/utils/string_table.rb +49 -0
  184. data/lib/datadog/core/utils/time.rb +54 -0
  185. data/lib/datadog/core/utils.rb +94 -0
  186. data/lib/datadog/core/vendor/multipart-post/multipart/post/composite_read_io.rb +120 -0
  187. data/lib/datadog/core/vendor/multipart-post/multipart/post/multipartable.rb +61 -0
  188. data/lib/datadog/core/vendor/multipart-post/multipart/post/parts.rb +139 -0
  189. data/lib/datadog/core/vendor/multipart-post/multipart/post/version.rb +13 -0
  190. data/lib/datadog/core/vendor/multipart-post/multipart/post.rb +12 -0
  191. data/lib/datadog/core/vendor/multipart-post/multipart.rb +16 -0
  192. data/lib/datadog/core/vendor/multipart-post/net/http/post/multipart.rb +36 -0
  193. data/lib/datadog/core/worker.rb +24 -0
  194. data/lib/datadog/core/workers/async.rb +180 -0
  195. data/lib/datadog/core/workers/interval_loop.rb +119 -0
  196. data/lib/datadog/core/workers/polling.rb +59 -0
  197. data/lib/datadog/core/workers/queue.rb +44 -0
  198. data/lib/datadog/core/workers/runtime_metrics.rb +62 -0
  199. data/lib/datadog/core.rb +46 -0
  200. data/lib/datadog/kit/enable_core_dumps.rb +50 -0
  201. data/lib/datadog/kit/identity.rb +63 -0
  202. data/lib/datadog/kit.rb +11 -0
  203. data/lib/datadog/opentracer/binary_propagator.rb +26 -0
  204. data/lib/datadog/opentracer/carrier.rb +9 -0
  205. data/lib/datadog/opentracer/distributed_headers.rb +56 -0
  206. data/lib/datadog/opentracer/global_tracer.rb +17 -0
  207. data/lib/datadog/opentracer/propagator.rb +26 -0
  208. data/lib/datadog/opentracer/rack_propagator.rb +73 -0
  209. data/lib/datadog/opentracer/scope.rb +18 -0
  210. data/lib/datadog/opentracer/scope_manager.rb +9 -0
  211. data/lib/datadog/opentracer/span.rb +101 -0
  212. data/lib/datadog/opentracer/span_context.rb +19 -0
  213. data/lib/datadog/opentracer/span_context_factory.rb +27 -0
  214. data/lib/datadog/opentracer/text_map_propagator.rb +88 -0
  215. data/lib/datadog/opentracer/thread_local_scope.rb +34 -0
  216. data/lib/datadog/opentracer/thread_local_scope_manager.rb +66 -0
  217. data/lib/datadog/opentracer/tracer.rb +214 -0
  218. data/lib/datadog/opentracer.rb +24 -0
  219. data/lib/datadog/profiling/backtrace_location.rb +34 -0
  220. data/lib/datadog/profiling/buffer.rb +43 -0
  221. data/lib/datadog/profiling/collectors/code_provenance.rb +115 -0
  222. data/lib/datadog/profiling/collectors/cpu_and_wall_time.rb +43 -0
  223. data/lib/datadog/profiling/collectors/cpu_and_wall_time_worker.rb +91 -0
  224. data/lib/datadog/profiling/collectors/dynamic_sampling_rate.rb +14 -0
  225. data/lib/datadog/profiling/collectors/idle_sampling_helper.rb +68 -0
  226. data/lib/datadog/profiling/collectors/old_stack.rb +305 -0
  227. data/lib/datadog/profiling/collectors/stack.rb +13 -0
  228. data/lib/datadog/profiling/encoding/profile.rb +43 -0
  229. data/lib/datadog/profiling/event.rb +15 -0
  230. data/lib/datadog/profiling/events/stack.rb +82 -0
  231. data/lib/datadog/profiling/exporter.rb +85 -0
  232. data/lib/datadog/profiling/ext/forking.rb +98 -0
  233. data/lib/datadog/profiling/ext.rb +45 -0
  234. data/lib/datadog/profiling/flush.rb +38 -0
  235. data/lib/datadog/profiling/http_transport.rb +132 -0
  236. data/lib/datadog/profiling/load_native_extension.rb +22 -0
  237. data/lib/datadog/profiling/native_extension.rb +41 -0
  238. data/lib/datadog/profiling/old_recorder.rb +109 -0
  239. data/lib/datadog/profiling/pprof/builder.rb +127 -0
  240. data/lib/datadog/profiling/pprof/converter.rb +104 -0
  241. data/lib/datadog/profiling/pprof/message_set.rb +16 -0
  242. data/lib/datadog/profiling/pprof/payload.rb +20 -0
  243. data/lib/datadog/profiling/pprof/pprof_pb.rb +83 -0
  244. data/lib/datadog/profiling/pprof/stack_sample.rb +141 -0
  245. data/lib/datadog/profiling/pprof/string_table.rb +12 -0
  246. data/lib/datadog/profiling/pprof/template.rb +120 -0
  247. data/lib/datadog/profiling/preload.rb +5 -0
  248. data/lib/datadog/profiling/profiler.rb +41 -0
  249. data/lib/datadog/profiling/scheduler.rb +130 -0
  250. data/lib/datadog/profiling/stack_recorder.rb +79 -0
  251. data/lib/datadog/profiling/tag_builder.rb +53 -0
  252. data/lib/datadog/profiling/tasks/exec.rb +50 -0
  253. data/lib/datadog/profiling/tasks/help.rb +18 -0
  254. data/lib/datadog/profiling/tasks/setup.rb +86 -0
  255. data/lib/datadog/profiling/trace_identifiers/ddtrace.rb +45 -0
  256. data/lib/datadog/profiling/trace_identifiers/helper.rb +47 -0
  257. data/lib/datadog/profiling.rb +173 -0
  258. data/lib/datadog/tracing/analytics.rb +25 -0
  259. data/lib/datadog/tracing/buffer.rb +132 -0
  260. data/lib/datadog/tracing/client_ip.rb +164 -0
  261. data/lib/datadog/tracing/configuration/ext.rb +95 -0
  262. data/lib/datadog/tracing/configuration/settings.rb +433 -0
  263. data/lib/datadog/tracing/context.rb +68 -0
  264. data/lib/datadog/tracing/context_provider.rb +82 -0
  265. data/lib/datadog/tracing/contrib/action_cable/configuration/settings.rb +35 -0
  266. data/lib/datadog/tracing/contrib/action_cable/event.rb +71 -0
  267. data/lib/datadog/tracing/contrib/action_cable/events/broadcast.rb +58 -0
  268. data/lib/datadog/tracing/contrib/action_cable/events/perform_action.rb +63 -0
  269. data/lib/datadog/tracing/contrib/action_cable/events/transmit.rb +59 -0
  270. data/lib/datadog/tracing/contrib/action_cable/events.rb +37 -0
  271. data/lib/datadog/tracing/contrib/action_cable/ext.rb +32 -0
  272. data/lib/datadog/tracing/contrib/action_cable/instrumentation.rb +90 -0
  273. data/lib/datadog/tracing/contrib/action_cable/integration.rb +50 -0
  274. data/lib/datadog/tracing/contrib/action_cable/patcher.rb +31 -0
  275. data/lib/datadog/tracing/contrib/action_mailer/configuration/settings.rb +36 -0
  276. data/lib/datadog/tracing/contrib/action_mailer/event.rb +52 -0
  277. data/lib/datadog/tracing/contrib/action_mailer/events/deliver.rb +60 -0
  278. data/lib/datadog/tracing/contrib/action_mailer/events/process.rb +47 -0
  279. data/lib/datadog/tracing/contrib/action_mailer/events.rb +34 -0
  280. data/lib/datadog/tracing/contrib/action_mailer/ext.rb +33 -0
  281. data/lib/datadog/tracing/contrib/action_mailer/integration.rb +50 -0
  282. data/lib/datadog/tracing/contrib/action_mailer/patcher.rb +29 -0
  283. data/lib/datadog/tracing/contrib/action_pack/action_controller/instrumentation.rb +160 -0
  284. data/lib/datadog/tracing/contrib/action_pack/action_controller/patcher.rb +29 -0
  285. data/lib/datadog/tracing/contrib/action_pack/configuration/settings.rb +36 -0
  286. data/lib/datadog/tracing/contrib/action_pack/ext.rb +22 -0
  287. data/lib/datadog/tracing/contrib/action_pack/integration.rb +50 -0
  288. data/lib/datadog/tracing/contrib/action_pack/patcher.rb +27 -0
  289. data/lib/datadog/tracing/contrib/action_pack/utils.rb +40 -0
  290. data/lib/datadog/tracing/contrib/action_view/configuration/settings.rb +36 -0
  291. data/lib/datadog/tracing/contrib/action_view/event.rb +35 -0
  292. data/lib/datadog/tracing/contrib/action_view/events/render_partial.rb +54 -0
  293. data/lib/datadog/tracing/contrib/action_view/events/render_template.rb +57 -0
  294. data/lib/datadog/tracing/contrib/action_view/events.rb +34 -0
  295. data/lib/datadog/tracing/contrib/action_view/ext.rb +24 -0
  296. data/lib/datadog/tracing/contrib/action_view/instrumentation/partial_renderer.rb +78 -0
  297. data/lib/datadog/tracing/contrib/action_view/instrumentation/template_renderer.rb +91 -0
  298. data/lib/datadog/tracing/contrib/action_view/integration.rb +57 -0
  299. data/lib/datadog/tracing/contrib/action_view/patcher.rb +47 -0
  300. data/lib/datadog/tracing/contrib/action_view/utils.rb +36 -0
  301. data/lib/datadog/tracing/contrib/active_job/configuration/settings.rb +37 -0
  302. data/lib/datadog/tracing/contrib/active_job/event.rb +58 -0
  303. data/lib/datadog/tracing/contrib/active_job/events/discard.rb +50 -0
  304. data/lib/datadog/tracing/contrib/active_job/events/enqueue.rb +49 -0
  305. data/lib/datadog/tracing/contrib/active_job/events/enqueue_at.rb +49 -0
  306. data/lib/datadog/tracing/contrib/active_job/events/enqueue_retry.rb +51 -0
  307. data/lib/datadog/tracing/contrib/active_job/events/perform.rb +49 -0
  308. data/lib/datadog/tracing/contrib/active_job/events/retry_stopped.rb +50 -0
  309. data/lib/datadog/tracing/contrib/active_job/events.rb +42 -0
  310. data/lib/datadog/tracing/contrib/active_job/ext.rb +39 -0
  311. data/lib/datadog/tracing/contrib/active_job/integration.rb +50 -0
  312. data/lib/datadog/tracing/contrib/active_job/log_injection.rb +24 -0
  313. data/lib/datadog/tracing/contrib/active_job/patcher.rb +36 -0
  314. data/lib/datadog/tracing/contrib/active_model_serializers/configuration/settings.rb +33 -0
  315. data/lib/datadog/tracing/contrib/active_model_serializers/event.rb +68 -0
  316. data/lib/datadog/tracing/contrib/active_model_serializers/events/render.rb +45 -0
  317. data/lib/datadog/tracing/contrib/active_model_serializers/events/serialize.rb +47 -0
  318. data/lib/datadog/tracing/contrib/active_model_serializers/events.rb +34 -0
  319. data/lib/datadog/tracing/contrib/active_model_serializers/ext.rb +24 -0
  320. data/lib/datadog/tracing/contrib/active_model_serializers/integration.rb +45 -0
  321. data/lib/datadog/tracing/contrib/active_model_serializers/patcher.rb +32 -0
  322. data/lib/datadog/tracing/contrib/active_record/configuration/makara_resolver.rb +36 -0
  323. data/lib/datadog/tracing/contrib/active_record/configuration/resolver.rb +138 -0
  324. data/lib/datadog/tracing/contrib/active_record/configuration/settings.rb +39 -0
  325. data/lib/datadog/tracing/contrib/active_record/event.rb +30 -0
  326. data/lib/datadog/tracing/contrib/active_record/events/instantiation.rb +58 -0
  327. data/lib/datadog/tracing/contrib/active_record/events/sql.rb +78 -0
  328. data/lib/datadog/tracing/contrib/active_record/events.rb +34 -0
  329. data/lib/datadog/tracing/contrib/active_record/ext.rb +29 -0
  330. data/lib/datadog/tracing/contrib/active_record/integration.rb +56 -0
  331. data/lib/datadog/tracing/contrib/active_record/patcher.rb +27 -0
  332. data/lib/datadog/tracing/contrib/active_record/utils.rb +128 -0
  333. data/lib/datadog/tracing/contrib/active_record/vendor/connection_specification.rb +307 -0
  334. data/lib/datadog/tracing/contrib/active_support/cache/instrumentation.rb +280 -0
  335. data/lib/datadog/tracing/contrib/active_support/cache/patcher.rb +73 -0
  336. data/lib/datadog/tracing/contrib/active_support/cache/redis.rb +47 -0
  337. data/lib/datadog/tracing/contrib/active_support/configuration/settings.rb +35 -0
  338. data/lib/datadog/tracing/contrib/active_support/ext.rb +31 -0
  339. data/lib/datadog/tracing/contrib/active_support/integration.rb +51 -0
  340. data/lib/datadog/tracing/contrib/active_support/notifications/event.rb +71 -0
  341. data/lib/datadog/tracing/contrib/active_support/notifications/subscriber.rb +71 -0
  342. data/lib/datadog/tracing/contrib/active_support/notifications/subscription.rb +164 -0
  343. data/lib/datadog/tracing/contrib/active_support/patcher.rb +27 -0
  344. data/lib/datadog/tracing/contrib/analytics.rb +29 -0
  345. data/lib/datadog/tracing/contrib/auto_instrument.rb +53 -0
  346. data/lib/datadog/tracing/contrib/aws/configuration/settings.rb +38 -0
  347. data/lib/datadog/tracing/contrib/aws/ext.rb +28 -0
  348. data/lib/datadog/tracing/contrib/aws/instrumentation.rb +96 -0
  349. data/lib/datadog/tracing/contrib/aws/integration.rb +47 -0
  350. data/lib/datadog/tracing/contrib/aws/parsed_context.rb +60 -0
  351. data/lib/datadog/tracing/contrib/aws/patcher.rb +57 -0
  352. data/lib/datadog/tracing/contrib/aws/services.rb +121 -0
  353. data/lib/datadog/tracing/contrib/concurrent_ruby/configuration/settings.rb +23 -0
  354. data/lib/datadog/tracing/contrib/concurrent_ruby/context_composite_executor_service.rb +53 -0
  355. data/lib/datadog/tracing/contrib/concurrent_ruby/ext.rb +16 -0
  356. data/lib/datadog/tracing/contrib/concurrent_ruby/future_patch.rb +27 -0
  357. data/lib/datadog/tracing/contrib/concurrent_ruby/integration.rb +43 -0
  358. data/lib/datadog/tracing/contrib/concurrent_ruby/patcher.rb +33 -0
  359. data/lib/datadog/tracing/contrib/configurable.rb +102 -0
  360. data/lib/datadog/tracing/contrib/configuration/resolver.rb +85 -0
  361. data/lib/datadog/tracing/contrib/configuration/resolvers/pattern_resolver.rb +43 -0
  362. data/lib/datadog/tracing/contrib/configuration/settings.rb +43 -0
  363. data/lib/datadog/tracing/contrib/dalli/configuration/settings.rb +38 -0
  364. data/lib/datadog/tracing/contrib/dalli/ext.rb +26 -0
  365. data/lib/datadog/tracing/contrib/dalli/instrumentation.rb +61 -0
  366. data/lib/datadog/tracing/contrib/dalli/integration.rb +52 -0
  367. data/lib/datadog/tracing/contrib/dalli/patcher.rb +28 -0
  368. data/lib/datadog/tracing/contrib/dalli/quantize.rb +26 -0
  369. data/lib/datadog/tracing/contrib/delayed_job/configuration/settings.rb +38 -0
  370. data/lib/datadog/tracing/contrib/delayed_job/ext.rb +28 -0
  371. data/lib/datadog/tracing/contrib/delayed_job/integration.rb +43 -0
  372. data/lib/datadog/tracing/contrib/delayed_job/patcher.rb +37 -0
  373. data/lib/datadog/tracing/contrib/delayed_job/plugin.rb +104 -0
  374. data/lib/datadog/tracing/contrib/delayed_job/server_internal_tracer/worker.rb +32 -0
  375. data/lib/datadog/tracing/contrib/elasticsearch/configuration/settings.rb +40 -0
  376. data/lib/datadog/tracing/contrib/elasticsearch/ext.rb +29 -0
  377. data/lib/datadog/tracing/contrib/elasticsearch/integration.rb +50 -0
  378. data/lib/datadog/tracing/contrib/elasticsearch/patcher.rb +153 -0
  379. data/lib/datadog/tracing/contrib/elasticsearch/quantize.rb +89 -0
  380. data/lib/datadog/tracing/contrib/ethon/configuration/settings.rb +42 -0
  381. data/lib/datadog/tracing/contrib/ethon/easy_patch.rb +176 -0
  382. data/lib/datadog/tracing/contrib/ethon/ext.rb +25 -0
  383. data/lib/datadog/tracing/contrib/ethon/integration.rb +48 -0
  384. data/lib/datadog/tracing/contrib/ethon/multi_patch.rb +97 -0
  385. data/lib/datadog/tracing/contrib/ethon/patcher.rb +31 -0
  386. data/lib/datadog/tracing/contrib/excon/configuration/settings.rb +42 -0
  387. data/lib/datadog/tracing/contrib/excon/ext.rb +22 -0
  388. data/lib/datadog/tracing/contrib/excon/integration.rb +48 -0
  389. data/lib/datadog/tracing/contrib/excon/middleware.rb +171 -0
  390. data/lib/datadog/tracing/contrib/excon/patcher.rb +31 -0
  391. data/lib/datadog/tracing/contrib/ext.rb +25 -0
  392. data/lib/datadog/tracing/contrib/extensions.rb +199 -0
  393. data/lib/datadog/tracing/contrib/faraday/configuration/settings.rb +46 -0
  394. data/lib/datadog/tracing/contrib/faraday/connection.rb +22 -0
  395. data/lib/datadog/tracing/contrib/faraday/ext.rb +22 -0
  396. data/lib/datadog/tracing/contrib/faraday/integration.rb +48 -0
  397. data/lib/datadog/tracing/contrib/faraday/middleware.rb +93 -0
  398. data/lib/datadog/tracing/contrib/faraday/patcher.rb +56 -0
  399. data/lib/datadog/tracing/contrib/faraday/rack_builder.rb +22 -0
  400. data/lib/datadog/tracing/contrib/grape/configuration/settings.rb +42 -0
  401. data/lib/datadog/tracing/contrib/grape/endpoint.rb +250 -0
  402. data/lib/datadog/tracing/contrib/grape/ext.rb +28 -0
  403. data/lib/datadog/tracing/contrib/grape/instrumentation.rb +37 -0
  404. data/lib/datadog/tracing/contrib/grape/integration.rb +44 -0
  405. data/lib/datadog/tracing/contrib/grape/patcher.rb +33 -0
  406. data/lib/datadog/tracing/contrib/graphql/configuration/settings.rb +36 -0
  407. data/lib/datadog/tracing/contrib/graphql/ext.rb +19 -0
  408. data/lib/datadog/tracing/contrib/graphql/integration.rb +44 -0
  409. data/lib/datadog/tracing/contrib/graphql/patcher.rb +90 -0
  410. data/lib/datadog/tracing/contrib/grpc/configuration/settings.rb +43 -0
  411. data/lib/datadog/tracing/contrib/grpc/datadog_interceptor/client.rb +99 -0
  412. data/lib/datadog/tracing/contrib/grpc/datadog_interceptor/server.rb +90 -0
  413. data/lib/datadog/tracing/contrib/grpc/datadog_interceptor.rb +107 -0
  414. data/lib/datadog/tracing/contrib/grpc/distributed/fetcher.rb +27 -0
  415. data/lib/datadog/tracing/contrib/grpc/distributed/propagation.rb +43 -0
  416. data/lib/datadog/tracing/contrib/grpc/ext.rb +27 -0
  417. data/lib/datadog/tracing/contrib/grpc/integration.rb +43 -0
  418. data/lib/datadog/tracing/contrib/grpc/intercept_with_datadog.rb +53 -0
  419. data/lib/datadog/tracing/contrib/grpc/patcher.rb +35 -0
  420. data/lib/datadog/tracing/contrib/hanami/action_tracer.rb +47 -0
  421. data/lib/datadog/tracing/contrib/hanami/configuration/settings.rb +22 -0
  422. data/lib/datadog/tracing/contrib/hanami/ext.rb +24 -0
  423. data/lib/datadog/tracing/contrib/hanami/integration.rb +44 -0
  424. data/lib/datadog/tracing/contrib/hanami/patcher.rb +33 -0
  425. data/lib/datadog/tracing/contrib/hanami/plugin.rb +23 -0
  426. data/lib/datadog/tracing/contrib/hanami/renderer_policy_tracing.rb +41 -0
  427. data/lib/datadog/tracing/contrib/hanami/router_tracing.rb +44 -0
  428. data/lib/datadog/tracing/contrib/http/circuit_breaker.rb +43 -0
  429. data/lib/datadog/tracing/contrib/http/configuration/settings.rb +42 -0
  430. data/lib/datadog/tracing/contrib/http/distributed/fetcher.rb +32 -0
  431. data/lib/datadog/tracing/contrib/http/distributed/propagation.rb +38 -0
  432. data/lib/datadog/tracing/contrib/http/ext.rb +22 -0
  433. data/lib/datadog/tracing/contrib/http/instrumentation.rb +140 -0
  434. data/lib/datadog/tracing/contrib/http/integration.rb +49 -0
  435. data/lib/datadog/tracing/contrib/http/patcher.rb +30 -0
  436. data/lib/datadog/tracing/contrib/http_annotation_helper.rb +17 -0
  437. data/lib/datadog/tracing/contrib/httpclient/configuration/settings.rb +42 -0
  438. data/lib/datadog/tracing/contrib/httpclient/ext.rb +22 -0
  439. data/lib/datadog/tracing/contrib/httpclient/instrumentation.rb +118 -0
  440. data/lib/datadog/tracing/contrib/httpclient/integration.rb +48 -0
  441. data/lib/datadog/tracing/contrib/httpclient/patcher.rb +42 -0
  442. data/lib/datadog/tracing/contrib/httprb/configuration/settings.rb +42 -0
  443. data/lib/datadog/tracing/contrib/httprb/ext.rb +22 -0
  444. data/lib/datadog/tracing/contrib/httprb/instrumentation.rb +129 -0
  445. data/lib/datadog/tracing/contrib/httprb/integration.rb +48 -0
  446. data/lib/datadog/tracing/contrib/httprb/patcher.rb +42 -0
  447. data/lib/datadog/tracing/contrib/integration.rb +78 -0
  448. data/lib/datadog/tracing/contrib/kafka/configuration/settings.rb +35 -0
  449. data/lib/datadog/tracing/contrib/kafka/consumer_event.rb +19 -0
  450. data/lib/datadog/tracing/contrib/kafka/consumer_group_event.rb +18 -0
  451. data/lib/datadog/tracing/contrib/kafka/event.rb +52 -0
  452. data/lib/datadog/tracing/contrib/kafka/events/connection/request.rb +42 -0
  453. data/lib/datadog/tracing/contrib/kafka/events/consumer/process_batch.rb +49 -0
  454. data/lib/datadog/tracing/contrib/kafka/events/consumer/process_message.rb +47 -0
  455. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/heartbeat.rb +47 -0
  456. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/join_group.rb +37 -0
  457. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/leave_group.rb +37 -0
  458. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/sync_group.rb +37 -0
  459. data/lib/datadog/tracing/contrib/kafka/events/produce_operation/send_messages.rb +41 -0
  460. data/lib/datadog/tracing/contrib/kafka/events/producer/deliver_messages.rb +44 -0
  461. data/lib/datadog/tracing/contrib/kafka/events.rb +48 -0
  462. data/lib/datadog/tracing/contrib/kafka/ext.rb +52 -0
  463. data/lib/datadog/tracing/contrib/kafka/integration.rb +44 -0
  464. data/lib/datadog/tracing/contrib/kafka/patcher.rb +29 -0
  465. data/lib/datadog/tracing/contrib/lograge/configuration/settings.rb +23 -0
  466. data/lib/datadog/tracing/contrib/lograge/ext.rb +15 -0
  467. data/lib/datadog/tracing/contrib/lograge/instrumentation.rb +46 -0
  468. data/lib/datadog/tracing/contrib/lograge/integration.rb +50 -0
  469. data/lib/datadog/tracing/contrib/lograge/patcher.rb +29 -0
  470. data/lib/datadog/tracing/contrib/mongodb/configuration/settings.rb +42 -0
  471. data/lib/datadog/tracing/contrib/mongodb/ext.rb +35 -0
  472. data/lib/datadog/tracing/contrib/mongodb/instrumentation.rb +47 -0
  473. data/lib/datadog/tracing/contrib/mongodb/integration.rb +48 -0
  474. data/lib/datadog/tracing/contrib/mongodb/parsers.rb +49 -0
  475. data/lib/datadog/tracing/contrib/mongodb/patcher.rb +34 -0
  476. data/lib/datadog/tracing/contrib/mongodb/subscribers.rb +127 -0
  477. data/lib/datadog/tracing/contrib/mysql2/configuration/settings.rb +50 -0
  478. data/lib/datadog/tracing/contrib/mysql2/ext.rb +24 -0
  479. data/lib/datadog/tracing/contrib/mysql2/instrumentation.rb +77 -0
  480. data/lib/datadog/tracing/contrib/mysql2/integration.rb +43 -0
  481. data/lib/datadog/tracing/contrib/mysql2/patcher.rb +31 -0
  482. data/lib/datadog/tracing/contrib/patchable.rb +109 -0
  483. data/lib/datadog/tracing/contrib/patcher.rb +86 -0
  484. data/lib/datadog/tracing/contrib/pg/configuration/settings.rb +50 -0
  485. data/lib/datadog/tracing/contrib/pg/ext.rb +33 -0
  486. data/lib/datadog/tracing/contrib/pg/instrumentation.rb +155 -0
  487. data/lib/datadog/tracing/contrib/pg/integration.rb +43 -0
  488. data/lib/datadog/tracing/contrib/pg/patcher.rb +31 -0
  489. data/lib/datadog/tracing/contrib/presto/configuration/settings.rb +38 -0
  490. data/lib/datadog/tracing/contrib/presto/ext.rb +33 -0
  491. data/lib/datadog/tracing/contrib/presto/instrumentation.rb +124 -0
  492. data/lib/datadog/tracing/contrib/presto/integration.rb +43 -0
  493. data/lib/datadog/tracing/contrib/presto/patcher.rb +37 -0
  494. data/lib/datadog/tracing/contrib/propagation/sql_comment/comment.rb +43 -0
  495. data/lib/datadog/tracing/contrib/propagation/sql_comment/ext.rb +33 -0
  496. data/lib/datadog/tracing/contrib/propagation/sql_comment/mode.rb +28 -0
  497. data/lib/datadog/tracing/contrib/propagation/sql_comment.rb +47 -0
  498. data/lib/datadog/tracing/contrib/qless/configuration/settings.rb +40 -0
  499. data/lib/datadog/tracing/contrib/qless/ext.rb +26 -0
  500. data/lib/datadog/tracing/contrib/qless/integration.rb +43 -0
  501. data/lib/datadog/tracing/contrib/qless/patcher.rb +37 -0
  502. data/lib/datadog/tracing/contrib/qless/qless_job.rb +74 -0
  503. data/lib/datadog/tracing/contrib/qless/tracer_cleaner.rb +30 -0
  504. data/lib/datadog/tracing/contrib/que/configuration/settings.rb +49 -0
  505. data/lib/datadog/tracing/contrib/que/ext.rb +34 -0
  506. data/lib/datadog/tracing/contrib/que/integration.rb +46 -0
  507. data/lib/datadog/tracing/contrib/que/patcher.rb +28 -0
  508. data/lib/datadog/tracing/contrib/que/tracer.rb +63 -0
  509. data/lib/datadog/tracing/contrib/racecar/configuration/settings.rb +35 -0
  510. data/lib/datadog/tracing/contrib/racecar/event.rb +78 -0
  511. data/lib/datadog/tracing/contrib/racecar/events/batch.rb +38 -0
  512. data/lib/datadog/tracing/contrib/racecar/events/consume.rb +35 -0
  513. data/lib/datadog/tracing/contrib/racecar/events/message.rb +38 -0
  514. data/lib/datadog/tracing/contrib/racecar/events.rb +36 -0
  515. data/lib/datadog/tracing/contrib/racecar/ext.rb +31 -0
  516. data/lib/datadog/tracing/contrib/racecar/integration.rb +44 -0
  517. data/lib/datadog/tracing/contrib/racecar/patcher.rb +29 -0
  518. data/lib/datadog/tracing/contrib/rack/configuration/settings.rb +51 -0
  519. data/lib/datadog/tracing/contrib/rack/ext.rb +25 -0
  520. data/lib/datadog/tracing/contrib/rack/header_collection.rb +35 -0
  521. data/lib/datadog/tracing/contrib/rack/integration.rb +50 -0
  522. data/lib/datadog/tracing/contrib/rack/middlewares.rb +323 -0
  523. data/lib/datadog/tracing/contrib/rack/patcher.rb +119 -0
  524. data/lib/datadog/tracing/contrib/rack/request_queue.rb +48 -0
  525. data/lib/datadog/tracing/contrib/rails/auto_instrument_railtie.rb +12 -0
  526. data/lib/datadog/tracing/contrib/rails/configuration/settings.rb +74 -0
  527. data/lib/datadog/tracing/contrib/rails/ext.rb +19 -0
  528. data/lib/datadog/tracing/contrib/rails/framework.rb +148 -0
  529. data/lib/datadog/tracing/contrib/rails/integration.rb +49 -0
  530. data/lib/datadog/tracing/contrib/rails/log_injection.rb +32 -0
  531. data/lib/datadog/tracing/contrib/rails/middlewares.rb +46 -0
  532. data/lib/datadog/tracing/contrib/rails/patcher.rb +120 -0
  533. data/lib/datadog/tracing/contrib/rails/railtie.rb +19 -0
  534. data/lib/datadog/tracing/contrib/rails/utils.rb +28 -0
  535. data/lib/datadog/tracing/contrib/rake/configuration/settings.rb +51 -0
  536. data/lib/datadog/tracing/contrib/rake/ext.rb +26 -0
  537. data/lib/datadog/tracing/contrib/rake/instrumentation.rb +103 -0
  538. data/lib/datadog/tracing/contrib/rake/integration.rb +43 -0
  539. data/lib/datadog/tracing/contrib/rake/patcher.rb +33 -0
  540. data/lib/datadog/tracing/contrib/redis/configuration/resolver.rb +49 -0
  541. data/lib/datadog/tracing/contrib/redis/configuration/settings.rb +43 -0
  542. data/lib/datadog/tracing/contrib/redis/ext.rb +29 -0
  543. data/lib/datadog/tracing/contrib/redis/instrumentation.rb +88 -0
  544. data/lib/datadog/tracing/contrib/redis/integration.rb +80 -0
  545. data/lib/datadog/tracing/contrib/redis/patcher.rb +79 -0
  546. data/lib/datadog/tracing/contrib/redis/quantize.rb +82 -0
  547. data/lib/datadog/tracing/contrib/redis/tags.rb +56 -0
  548. data/lib/datadog/tracing/contrib/redis/trace_middleware.rb +72 -0
  549. data/lib/datadog/tracing/contrib/redis/vendor/resolver.rb +162 -0
  550. data/lib/datadog/tracing/contrib/registerable.rb +50 -0
  551. data/lib/datadog/tracing/contrib/registry.rb +52 -0
  552. data/lib/datadog/tracing/contrib/resque/configuration/settings.rb +37 -0
  553. data/lib/datadog/tracing/contrib/resque/ext.rb +21 -0
  554. data/lib/datadog/tracing/contrib/resque/integration.rb +48 -0
  555. data/lib/datadog/tracing/contrib/resque/patcher.rb +29 -0
  556. data/lib/datadog/tracing/contrib/resque/resque_job.rb +104 -0
  557. data/lib/datadog/tracing/contrib/rest_client/configuration/settings.rb +42 -0
  558. data/lib/datadog/tracing/contrib/rest_client/ext.rb +22 -0
  559. data/lib/datadog/tracing/contrib/rest_client/integration.rb +43 -0
  560. data/lib/datadog/tracing/contrib/rest_client/patcher.rb +29 -0
  561. data/lib/datadog/tracing/contrib/rest_client/request_patch.rb +106 -0
  562. data/lib/datadog/tracing/contrib/semantic_logger/configuration/settings.rb +23 -0
  563. data/lib/datadog/tracing/contrib/semantic_logger/ext.rb +15 -0
  564. data/lib/datadog/tracing/contrib/semantic_logger/instrumentation.rb +50 -0
  565. data/lib/datadog/tracing/contrib/semantic_logger/integration.rb +52 -0
  566. data/lib/datadog/tracing/contrib/semantic_logger/patcher.rb +29 -0
  567. data/lib/datadog/tracing/contrib/sequel/configuration/settings.rb +33 -0
  568. data/lib/datadog/tracing/contrib/sequel/database.rb +59 -0
  569. data/lib/datadog/tracing/contrib/sequel/dataset.rb +64 -0
  570. data/lib/datadog/tracing/contrib/sequel/ext.rb +22 -0
  571. data/lib/datadog/tracing/contrib/sequel/integration.rb +43 -0
  572. data/lib/datadog/tracing/contrib/sequel/patcher.rb +37 -0
  573. data/lib/datadog/tracing/contrib/sequel/utils.rb +87 -0
  574. data/lib/datadog/tracing/contrib/shoryuken/configuration/settings.rb +38 -0
  575. data/lib/datadog/tracing/contrib/shoryuken/ext.rb +25 -0
  576. data/lib/datadog/tracing/contrib/shoryuken/integration.rb +44 -0
  577. data/lib/datadog/tracing/contrib/shoryuken/patcher.rb +28 -0
  578. data/lib/datadog/tracing/contrib/shoryuken/tracer.rb +63 -0
  579. data/lib/datadog/tracing/contrib/sidekiq/client_tracer.rb +57 -0
  580. data/lib/datadog/tracing/contrib/sidekiq/configuration/settings.rb +44 -0
  581. data/lib/datadog/tracing/contrib/sidekiq/ext.rb +44 -0
  582. data/lib/datadog/tracing/contrib/sidekiq/integration.rb +53 -0
  583. data/lib/datadog/tracing/contrib/sidekiq/patcher.rb +78 -0
  584. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/heartbeat.rb +52 -0
  585. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/job_fetch.rb +34 -0
  586. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/redis_info.rb +32 -0
  587. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/scheduled_poller.rb +53 -0
  588. data/lib/datadog/tracing/contrib/sidekiq/server_tracer.rb +102 -0
  589. data/lib/datadog/tracing/contrib/sidekiq/tracing.rb +44 -0
  590. data/lib/datadog/tracing/contrib/sinatra/configuration/settings.rb +43 -0
  591. data/lib/datadog/tracing/contrib/sinatra/env.rb +55 -0
  592. data/lib/datadog/tracing/contrib/sinatra/ext.rb +36 -0
  593. data/lib/datadog/tracing/contrib/sinatra/framework.rb +116 -0
  594. data/lib/datadog/tracing/contrib/sinatra/headers.rb +35 -0
  595. data/lib/datadog/tracing/contrib/sinatra/integration.rb +43 -0
  596. data/lib/datadog/tracing/contrib/sinatra/patcher.rb +76 -0
  597. data/lib/datadog/tracing/contrib/sinatra/tracer.rb +86 -0
  598. data/lib/datadog/tracing/contrib/sinatra/tracer_middleware.rb +127 -0
  599. data/lib/datadog/tracing/contrib/sneakers/configuration/settings.rb +38 -0
  600. data/lib/datadog/tracing/contrib/sneakers/ext.rb +26 -0
  601. data/lib/datadog/tracing/contrib/sneakers/integration.rb +46 -0
  602. data/lib/datadog/tracing/contrib/sneakers/patcher.rb +29 -0
  603. data/lib/datadog/tracing/contrib/sneakers/tracer.rb +59 -0
  604. data/lib/datadog/tracing/contrib/status_code_matcher.rb +75 -0
  605. data/lib/datadog/tracing/contrib/sucker_punch/configuration/settings.rb +35 -0
  606. data/lib/datadog/tracing/contrib/sucker_punch/exception_handler.rb +28 -0
  607. data/lib/datadog/tracing/contrib/sucker_punch/ext.rb +27 -0
  608. data/lib/datadog/tracing/contrib/sucker_punch/instrumentation.rb +104 -0
  609. data/lib/datadog/tracing/contrib/sucker_punch/integration.rb +43 -0
  610. data/lib/datadog/tracing/contrib/sucker_punch/patcher.rb +36 -0
  611. data/lib/datadog/tracing/contrib/utils/database.rb +31 -0
  612. data/lib/datadog/tracing/contrib/utils/quantization/hash.rb +111 -0
  613. data/lib/datadog/tracing/contrib/utils/quantization/http.rb +181 -0
  614. data/lib/datadog/tracing/contrib.rb +78 -0
  615. data/lib/datadog/tracing/correlation.rb +100 -0
  616. data/lib/datadog/tracing/diagnostics/ext.rb +36 -0
  617. data/lib/datadog/tracing/diagnostics/health.rb +40 -0
  618. data/lib/datadog/tracing/distributed/b3_multi.rb +66 -0
  619. data/lib/datadog/tracing/distributed/b3_single.rb +66 -0
  620. data/lib/datadog/tracing/distributed/datadog.rb +153 -0
  621. data/lib/datadog/tracing/distributed/datadog_tags_codec.rb +85 -0
  622. data/lib/datadog/tracing/distributed/fetcher.rb +30 -0
  623. data/lib/datadog/tracing/distributed/headers/ext.rb +35 -0
  624. data/lib/datadog/tracing/distributed/helpers.rb +80 -0
  625. data/lib/datadog/tracing/distributed/none.rb +19 -0
  626. data/lib/datadog/tracing/distributed/propagation.rb +127 -0
  627. data/lib/datadog/tracing/distributed/trace_context.rb +369 -0
  628. data/lib/datadog/tracing/event.rb +78 -0
  629. data/lib/datadog/tracing/flush.rb +96 -0
  630. data/lib/datadog/tracing/metadata/analytics.rb +26 -0
  631. data/lib/datadog/tracing/metadata/errors.rb +24 -0
  632. data/lib/datadog/tracing/metadata/ext.rb +178 -0
  633. data/lib/datadog/tracing/metadata/tagging.rb +125 -0
  634. data/lib/datadog/tracing/metadata.rb +20 -0
  635. data/lib/datadog/tracing/pipeline/span_filter.rb +46 -0
  636. data/lib/datadog/tracing/pipeline/span_processor.rb +39 -0
  637. data/lib/datadog/tracing/pipeline.rb +65 -0
  638. data/lib/datadog/tracing/propagation/http.rb +14 -0
  639. data/lib/datadog/tracing/runtime/metrics.rb +19 -0
  640. data/lib/datadog/tracing/sampling/all_sampler.rb +25 -0
  641. data/lib/datadog/tracing/sampling/ext.rb +58 -0
  642. data/lib/datadog/tracing/sampling/matcher.rb +68 -0
  643. data/lib/datadog/tracing/sampling/priority_sampler.rb +165 -0
  644. data/lib/datadog/tracing/sampling/rate_by_key_sampler.rb +96 -0
  645. data/lib/datadog/tracing/sampling/rate_by_service_sampler.rb +65 -0
  646. data/lib/datadog/tracing/sampling/rate_limiter.rb +188 -0
  647. data/lib/datadog/tracing/sampling/rate_sampler.rb +72 -0
  648. data/lib/datadog/tracing/sampling/rule.rb +76 -0
  649. data/lib/datadog/tracing/sampling/rule_sampler.rb +132 -0
  650. data/lib/datadog/tracing/sampling/sampler.rb +44 -0
  651. data/lib/datadog/tracing/sampling/span/ext.rb +25 -0
  652. data/lib/datadog/tracing/sampling/span/matcher.rb +89 -0
  653. data/lib/datadog/tracing/sampling/span/rule.rb +82 -0
  654. data/lib/datadog/tracing/sampling/span/rule_parser.rb +104 -0
  655. data/lib/datadog/tracing/sampling/span/sampler.rb +75 -0
  656. data/lib/datadog/tracing/span.rb +216 -0
  657. data/lib/datadog/tracing/span_operation.rb +520 -0
  658. data/lib/datadog/tracing/sync_writer.rb +69 -0
  659. data/lib/datadog/tracing/trace_digest.rb +136 -0
  660. data/lib/datadog/tracing/trace_operation.rb +468 -0
  661. data/lib/datadog/tracing/trace_segment.rb +212 -0
  662. data/lib/datadog/tracing/tracer.rb +533 -0
  663. data/lib/datadog/tracing/utils.rb +50 -0
  664. data/lib/datadog/tracing/workers/trace_writer.rb +195 -0
  665. data/lib/datadog/tracing/workers.rb +125 -0
  666. data/lib/datadog/tracing/writer.rb +187 -0
  667. data/lib/datadog/tracing.rb +142 -0
  668. data/lib/ddtrace/auto_instrument.rb +14 -3
  669. data/lib/ddtrace/auto_instrument_base.rb +1 -0
  670. data/lib/ddtrace/profiling/preload.rb +2 -2
  671. data/lib/ddtrace/transport/ext.rb +41 -0
  672. data/lib/ddtrace/transport/http/adapters/net.rb +5 -3
  673. data/lib/ddtrace/transport/http/adapters/registry.rb +1 -0
  674. data/lib/ddtrace/transport/http/adapters/test.rb +2 -1
  675. data/lib/ddtrace/transport/http/adapters/unix_socket.rb +4 -3
  676. data/lib/ddtrace/transport/http/api/endpoint.rb +1 -0
  677. data/lib/ddtrace/transport/http/api/fallbacks.rb +1 -0
  678. data/lib/ddtrace/transport/http/api/instance.rb +1 -0
  679. data/lib/ddtrace/transport/http/api/map.rb +2 -1
  680. data/lib/ddtrace/transport/http/api/spec.rb +1 -0
  681. data/lib/ddtrace/transport/http/api.rb +8 -14
  682. data/lib/ddtrace/transport/http/builder.rb +7 -6
  683. data/lib/ddtrace/transport/http/client.rb +5 -3
  684. data/lib/ddtrace/transport/http/env.rb +1 -0
  685. data/lib/ddtrace/transport/http/response.rb +36 -5
  686. data/lib/ddtrace/transport/http/statistics.rb +2 -1
  687. data/lib/ddtrace/transport/http/traces.rb +6 -3
  688. data/lib/ddtrace/transport/http.rb +39 -31
  689. data/lib/ddtrace/transport/io/client.rb +6 -3
  690. data/lib/ddtrace/transport/io/response.rb +2 -1
  691. data/lib/ddtrace/transport/io/traces.rb +5 -4
  692. data/lib/ddtrace/transport/io.rb +5 -4
  693. data/lib/ddtrace/transport/parcel.rb +2 -0
  694. data/lib/ddtrace/transport/request.rb +1 -0
  695. data/lib/ddtrace/transport/response.rb +1 -0
  696. data/lib/ddtrace/transport/serializable_trace.rb +118 -0
  697. data/lib/ddtrace/transport/statistics.rb +6 -4
  698. data/lib/ddtrace/transport/trace_formatter.rb +191 -0
  699. data/lib/ddtrace/transport/traces.rb +20 -8
  700. data/lib/ddtrace/version.rb +15 -13
  701. data/lib/ddtrace.rb +9 -48
  702. metadata +673 -497
  703. data/.editorconfig +0 -22
  704. data/.gitignore +0 -67
  705. data/.yardopts +0 -5
  706. data/CONTRIBUTING.md +0 -81
  707. data/ddtrace.gemspec +0 -56
  708. data/docs/DevelopmentGuide.md +0 -259
  709. data/docs/GettingStarted.md +0 -2626
  710. data/docs/ProfilingDevelopment.md +0 -107
  711. data/lib/datadog/ci/context_flush.rb +0 -29
  712. data/lib/datadog/contrib.rb +0 -71
  713. data/lib/ddtrace/analytics.rb +0 -39
  714. data/lib/ddtrace/buffer.rb +0 -340
  715. data/lib/ddtrace/chunker.rb +0 -35
  716. data/lib/ddtrace/configuration/agent_settings_resolver.rb +0 -309
  717. data/lib/ddtrace/configuration/base.rb +0 -82
  718. data/lib/ddtrace/configuration/components.rb +0 -292
  719. data/lib/ddtrace/configuration/dependency_resolver.rb +0 -25
  720. data/lib/ddtrace/configuration/option.rb +0 -65
  721. data/lib/ddtrace/configuration/option_definition.rb +0 -122
  722. data/lib/ddtrace/configuration/option_definition_set.rb +0 -19
  723. data/lib/ddtrace/configuration/option_set.rb +0 -7
  724. data/lib/ddtrace/configuration/options.rb +0 -112
  725. data/lib/ddtrace/configuration/pin_setup.rb +0 -32
  726. data/lib/ddtrace/configuration/settings.rb +0 -413
  727. data/lib/ddtrace/configuration.rb +0 -195
  728. data/lib/ddtrace/context.rb +0 -334
  729. data/lib/ddtrace/context_flush.rb +0 -82
  730. data/lib/ddtrace/context_provider.rb +0 -62
  731. data/lib/ddtrace/contrib/action_cable/configuration/settings.rb +0 -31
  732. data/lib/ddtrace/contrib/action_cable/event.rb +0 -67
  733. data/lib/ddtrace/contrib/action_cable/events/broadcast.rb +0 -50
  734. data/lib/ddtrace/contrib/action_cable/events/perform_action.rb +0 -56
  735. data/lib/ddtrace/contrib/action_cable/events/transmit.rb +0 -51
  736. data/lib/ddtrace/contrib/action_cable/events.rb +0 -34
  737. data/lib/ddtrace/contrib/action_cable/ext.rb +0 -27
  738. data/lib/ddtrace/contrib/action_cable/instrumentation.rb +0 -78
  739. data/lib/ddtrace/contrib/action_cable/integration.rb +0 -46
  740. data/lib/ddtrace/contrib/action_cable/patcher.rb +0 -29
  741. data/lib/ddtrace/contrib/action_mailer/configuration/settings.rb +0 -32
  742. data/lib/ddtrace/contrib/action_mailer/event.rb +0 -50
  743. data/lib/ddtrace/contrib/action_mailer/events/deliver.rb +0 -54
  744. data/lib/ddtrace/contrib/action_mailer/events/process.rb +0 -41
  745. data/lib/ddtrace/contrib/action_mailer/events.rb +0 -31
  746. data/lib/ddtrace/contrib/action_mailer/ext.rb +0 -32
  747. data/lib/ddtrace/contrib/action_mailer/integration.rb +0 -45
  748. data/lib/ddtrace/contrib/action_mailer/patcher.rb +0 -27
  749. data/lib/ddtrace/contrib/action_pack/action_controller/instrumentation.rb +0 -157
  750. data/lib/ddtrace/contrib/action_pack/action_controller/patcher.rb +0 -26
  751. data/lib/ddtrace/contrib/action_pack/configuration/settings.rb +0 -33
  752. data/lib/ddtrace/contrib/action_pack/ext.rb +0 -20
  753. data/lib/ddtrace/contrib/action_pack/integration.rb +0 -46
  754. data/lib/ddtrace/contrib/action_pack/patcher.rb +0 -24
  755. data/lib/ddtrace/contrib/action_pack/utils.rb +0 -37
  756. data/lib/ddtrace/contrib/action_view/configuration/settings.rb +0 -32
  757. data/lib/ddtrace/contrib/action_view/event.rb +0 -36
  758. data/lib/ddtrace/contrib/action_view/events/render_partial.rb +0 -47
  759. data/lib/ddtrace/contrib/action_view/events/render_template.rb +0 -50
  760. data/lib/ddtrace/contrib/action_view/events.rb +0 -31
  761. data/lib/ddtrace/contrib/action_view/ext.rb +0 -21
  762. data/lib/ddtrace/contrib/action_view/instrumentation/partial_renderer.rb +0 -75
  763. data/lib/ddtrace/contrib/action_view/instrumentation/template_renderer.rb +0 -168
  764. data/lib/ddtrace/contrib/action_view/integration.rb +0 -53
  765. data/lib/ddtrace/contrib/action_view/patcher.rb +0 -48
  766. data/lib/ddtrace/contrib/action_view/utils.rb +0 -33
  767. data/lib/ddtrace/contrib/active_job/configuration/settings.rb +0 -33
  768. data/lib/ddtrace/contrib/active_job/event.rb +0 -54
  769. data/lib/ddtrace/contrib/active_job/events/discard.rb +0 -46
  770. data/lib/ddtrace/contrib/active_job/events/enqueue.rb +0 -45
  771. data/lib/ddtrace/contrib/active_job/events/enqueue_at.rb +0 -45
  772. data/lib/ddtrace/contrib/active_job/events/enqueue_retry.rb +0 -47
  773. data/lib/ddtrace/contrib/active_job/events/perform.rb +0 -45
  774. data/lib/ddtrace/contrib/active_job/events/retry_stopped.rb +0 -46
  775. data/lib/ddtrace/contrib/active_job/events.rb +0 -39
  776. data/lib/ddtrace/contrib/active_job/ext.rb +0 -32
  777. data/lib/ddtrace/contrib/active_job/integration.rb +0 -46
  778. data/lib/ddtrace/contrib/active_job/log_injection.rb +0 -21
  779. data/lib/ddtrace/contrib/active_job/patcher.rb +0 -33
  780. data/lib/ddtrace/contrib/active_model_serializers/configuration/settings.rb +0 -31
  781. data/lib/ddtrace/contrib/active_model_serializers/event.rb +0 -69
  782. data/lib/ddtrace/contrib/active_model_serializers/events/render.rb +0 -33
  783. data/lib/ddtrace/contrib/active_model_serializers/events/serialize.rb +0 -36
  784. data/lib/ddtrace/contrib/active_model_serializers/events.rb +0 -31
  785. data/lib/ddtrace/contrib/active_model_serializers/ext.rb +0 -21
  786. data/lib/ddtrace/contrib/active_model_serializers/integration.rb +0 -41
  787. data/lib/ddtrace/contrib/active_model_serializers/patcher.rb +0 -30
  788. data/lib/ddtrace/contrib/active_record/configuration/makara_resolver.rb +0 -31
  789. data/lib/ddtrace/contrib/active_record/configuration/resolver.rb +0 -135
  790. data/lib/ddtrace/contrib/active_record/configuration/settings.rb +0 -36
  791. data/lib/ddtrace/contrib/active_record/event.rb +0 -31
  792. data/lib/ddtrace/contrib/active_record/events/instantiation.rb +0 -61
  793. data/lib/ddtrace/contrib/active_record/events/sql.rb +0 -69
  794. data/lib/ddtrace/contrib/active_record/events.rb +0 -31
  795. data/lib/ddtrace/contrib/active_record/ext.rb +0 -25
  796. data/lib/ddtrace/contrib/active_record/integration.rb +0 -54
  797. data/lib/ddtrace/contrib/active_record/patcher.rb +0 -24
  798. data/lib/ddtrace/contrib/active_record/utils.rb +0 -124
  799. data/lib/ddtrace/contrib/active_support/cache/instrumentation.rb +0 -259
  800. data/lib/ddtrace/contrib/active_support/cache/patcher.rb +0 -70
  801. data/lib/ddtrace/contrib/active_support/cache/redis.rb +0 -44
  802. data/lib/ddtrace/contrib/active_support/configuration/settings.rb +0 -31
  803. data/lib/ddtrace/contrib/active_support/ext.rb +0 -28
  804. data/lib/ddtrace/contrib/active_support/integration.rb +0 -47
  805. data/lib/ddtrace/contrib/active_support/notifications/event.rb +0 -76
  806. data/lib/ddtrace/contrib/active_support/notifications/subscriber.rb +0 -68
  807. data/lib/ddtrace/contrib/active_support/notifications/subscription.rb +0 -164
  808. data/lib/ddtrace/contrib/active_support/patcher.rb +0 -24
  809. data/lib/ddtrace/contrib/analytics.rb +0 -25
  810. data/lib/ddtrace/contrib/auto_instrument.rb +0 -48
  811. data/lib/ddtrace/contrib/aws/configuration/settings.rb +0 -31
  812. data/lib/ddtrace/contrib/aws/ext.rb +0 -24
  813. data/lib/ddtrace/contrib/aws/instrumentation.rb +0 -91
  814. data/lib/ddtrace/contrib/aws/integration.rb +0 -43
  815. data/lib/ddtrace/contrib/aws/parsed_context.rb +0 -57
  816. data/lib/ddtrace/contrib/aws/patcher.rb +0 -54
  817. data/lib/ddtrace/contrib/aws/services.rb +0 -119
  818. data/lib/ddtrace/contrib/concurrent_ruby/configuration/settings.rb +0 -21
  819. data/lib/ddtrace/contrib/concurrent_ruby/context_composite_executor_service.rb +0 -42
  820. data/lib/ddtrace/contrib/concurrent_ruby/ext.rb +0 -13
  821. data/lib/ddtrace/contrib/concurrent_ruby/future_patch.rb +0 -24
  822. data/lib/ddtrace/contrib/concurrent_ruby/integration.rb +0 -39
  823. data/lib/ddtrace/contrib/concurrent_ruby/patcher.rb +0 -30
  824. data/lib/ddtrace/contrib/configurable.rb +0 -103
  825. data/lib/ddtrace/contrib/configuration/resolver.rb +0 -82
  826. data/lib/ddtrace/contrib/configuration/resolvers/pattern_resolver.rb +0 -40
  827. data/lib/ddtrace/contrib/configuration/settings.rb +0 -56
  828. data/lib/ddtrace/contrib/dalli/configuration/settings.rb +0 -31
  829. data/lib/ddtrace/contrib/dalli/ext.rb +0 -21
  830. data/lib/ddtrace/contrib/dalli/instrumentation.rb +0 -55
  831. data/lib/ddtrace/contrib/dalli/integration.rb +0 -39
  832. data/lib/ddtrace/contrib/dalli/patcher.rb +0 -26
  833. data/lib/ddtrace/contrib/dalli/quantize.rb +0 -23
  834. data/lib/ddtrace/contrib/delayed_job/configuration/settings.rb +0 -33
  835. data/lib/ddtrace/contrib/delayed_job/ext.rb +0 -24
  836. data/lib/ddtrace/contrib/delayed_job/integration.rb +0 -39
  837. data/lib/ddtrace/contrib/delayed_job/patcher.rb +0 -29
  838. data/lib/ddtrace/contrib/delayed_job/plugin.rb +0 -85
  839. data/lib/ddtrace/contrib/elasticsearch/configuration/settings.rb +0 -32
  840. data/lib/ddtrace/contrib/elasticsearch/ext.rb +0 -23
  841. data/lib/ddtrace/contrib/elasticsearch/integration.rb +0 -40
  842. data/lib/ddtrace/contrib/elasticsearch/patcher.rb +0 -123
  843. data/lib/ddtrace/contrib/elasticsearch/quantize.rb +0 -84
  844. data/lib/ddtrace/contrib/ethon/configuration/settings.rb +0 -33
  845. data/lib/ddtrace/contrib/ethon/easy_patch.rb +0 -152
  846. data/lib/ddtrace/contrib/ethon/ext.rb +0 -20
  847. data/lib/ddtrace/contrib/ethon/integration.rb +0 -44
  848. data/lib/ddtrace/contrib/ethon/multi_patch.rb +0 -85
  849. data/lib/ddtrace/contrib/ethon/patcher.rb +0 -27
  850. data/lib/ddtrace/contrib/excon/configuration/settings.rb +0 -34
  851. data/lib/ddtrace/contrib/excon/ext.rb +0 -18
  852. data/lib/ddtrace/contrib/excon/integration.rb +0 -44
  853. data/lib/ddtrace/contrib/excon/middleware.rb +0 -164
  854. data/lib/ddtrace/contrib/excon/patcher.rb +0 -28
  855. data/lib/ddtrace/contrib/extensions.rb +0 -169
  856. data/lib/ddtrace/contrib/faraday/configuration/settings.rb +0 -39
  857. data/lib/ddtrace/contrib/faraday/connection.rb +0 -19
  858. data/lib/ddtrace/contrib/faraday/ext.rb +0 -18
  859. data/lib/ddtrace/contrib/faraday/integration.rb +0 -44
  860. data/lib/ddtrace/contrib/faraday/middleware.rb +0 -86
  861. data/lib/ddtrace/contrib/faraday/patcher.rb +0 -54
  862. data/lib/ddtrace/contrib/faraday/rack_builder.rb +0 -19
  863. data/lib/ddtrace/contrib/grape/configuration/settings.rb +0 -39
  864. data/lib/ddtrace/contrib/grape/endpoint.rb +0 -246
  865. data/lib/ddtrace/contrib/grape/ext.rb +0 -24
  866. data/lib/ddtrace/contrib/grape/instrumentation.rb +0 -34
  867. data/lib/ddtrace/contrib/grape/integration.rb +0 -40
  868. data/lib/ddtrace/contrib/grape/patcher.rb +0 -32
  869. data/lib/ddtrace/contrib/graphql/configuration/settings.rb +0 -33
  870. data/lib/ddtrace/contrib/graphql/ext.rb +0 -17
  871. data/lib/ddtrace/contrib/graphql/integration.rb +0 -40
  872. data/lib/ddtrace/contrib/graphql/patcher.rb +0 -61
  873. data/lib/ddtrace/contrib/grpc/configuration/settings.rb +0 -32
  874. data/lib/ddtrace/contrib/grpc/datadog_interceptor/client.rb +0 -59
  875. data/lib/ddtrace/contrib/grpc/datadog_interceptor/server.rb +0 -80
  876. data/lib/ddtrace/contrib/grpc/datadog_interceptor.rb +0 -79
  877. data/lib/ddtrace/contrib/grpc/ext.rb +0 -19
  878. data/lib/ddtrace/contrib/grpc/integration.rb +0 -39
  879. data/lib/ddtrace/contrib/grpc/intercept_with_datadog.rb +0 -50
  880. data/lib/ddtrace/contrib/grpc/patcher.rb +0 -34
  881. data/lib/ddtrace/contrib/http/circuit_breaker.rb +0 -38
  882. data/lib/ddtrace/contrib/http/configuration/settings.rb +0 -33
  883. data/lib/ddtrace/contrib/http/ext.rb +0 -18
  884. data/lib/ddtrace/contrib/http/instrumentation.rb +0 -180
  885. data/lib/ddtrace/contrib/http/integration.rb +0 -46
  886. data/lib/ddtrace/contrib/http/patcher.rb +0 -27
  887. data/lib/ddtrace/contrib/http_annotation_helper.rb +0 -11
  888. data/lib/ddtrace/contrib/httpclient/configuration/settings.rb +0 -33
  889. data/lib/ddtrace/contrib/httpclient/ext.rb +0 -18
  890. data/lib/ddtrace/contrib/httpclient/instrumentation.rb +0 -148
  891. data/lib/ddtrace/contrib/httpclient/integration.rb +0 -44
  892. data/lib/ddtrace/contrib/httpclient/patcher.rb +0 -39
  893. data/lib/ddtrace/contrib/httprb/configuration/settings.rb +0 -33
  894. data/lib/ddtrace/contrib/httprb/ext.rb +0 -18
  895. data/lib/ddtrace/contrib/httprb/instrumentation.rb +0 -158
  896. data/lib/ddtrace/contrib/httprb/integration.rb +0 -44
  897. data/lib/ddtrace/contrib/httprb/patcher.rb +0 -39
  898. data/lib/ddtrace/contrib/integration.rb +0 -17
  899. data/lib/ddtrace/contrib/kafka/configuration/settings.rb +0 -31
  900. data/lib/ddtrace/contrib/kafka/consumer_event.rb +0 -15
  901. data/lib/ddtrace/contrib/kafka/consumer_group_event.rb +0 -15
  902. data/lib/ddtrace/contrib/kafka/event.rb +0 -52
  903. data/lib/ddtrace/contrib/kafka/events/connection/request.rb +0 -35
  904. data/lib/ddtrace/contrib/kafka/events/consumer/process_batch.rb +0 -42
  905. data/lib/ddtrace/contrib/kafka/events/consumer/process_message.rb +0 -40
  906. data/lib/ddtrace/contrib/kafka/events/consumer_group/heartbeat.rb +0 -40
  907. data/lib/ddtrace/contrib/kafka/events/consumer_group/join_group.rb +0 -30
  908. data/lib/ddtrace/contrib/kafka/events/consumer_group/leave_group.rb +0 -30
  909. data/lib/ddtrace/contrib/kafka/events/consumer_group/sync_group.rb +0 -30
  910. data/lib/ddtrace/contrib/kafka/events/produce_operation/send_messages.rb +0 -33
  911. data/lib/ddtrace/contrib/kafka/events/producer/deliver_messages.rb +0 -36
  912. data/lib/ddtrace/contrib/kafka/events.rb +0 -45
  913. data/lib/ddtrace/contrib/kafka/ext.rb +0 -42
  914. data/lib/ddtrace/contrib/kafka/integration.rb +0 -40
  915. data/lib/ddtrace/contrib/kafka/patcher.rb +0 -27
  916. data/lib/ddtrace/contrib/lograge/configuration/settings.rb +0 -19
  917. data/lib/ddtrace/contrib/lograge/ext.rb +0 -11
  918. data/lib/ddtrace/contrib/lograge/instrumentation.rb +0 -39
  919. data/lib/ddtrace/contrib/lograge/integration.rb +0 -46
  920. data/lib/ddtrace/contrib/lograge/patcher.rb +0 -26
  921. data/lib/ddtrace/contrib/mongodb/configuration/settings.rb +0 -34
  922. data/lib/ddtrace/contrib/mongodb/ext.rb +0 -24
  923. data/lib/ddtrace/contrib/mongodb/instrumentation.rb +0 -70
  924. data/lib/ddtrace/contrib/mongodb/integration.rb +0 -44
  925. data/lib/ddtrace/contrib/mongodb/parsers.rb +0 -69
  926. data/lib/ddtrace/contrib/mongodb/patcher.rb +0 -32
  927. data/lib/ddtrace/contrib/mongodb/subscribers.rb +0 -112
  928. data/lib/ddtrace/contrib/mysql2/configuration/settings.rb +0 -31
  929. data/lib/ddtrace/contrib/mysql2/ext.rb +0 -19
  930. data/lib/ddtrace/contrib/mysql2/instrumentation.rb +0 -65
  931. data/lib/ddtrace/contrib/mysql2/integration.rb +0 -39
  932. data/lib/ddtrace/contrib/mysql2/patcher.rb +0 -28
  933. data/lib/ddtrace/contrib/patchable.rb +0 -71
  934. data/lib/ddtrace/contrib/patcher.rb +0 -66
  935. data/lib/ddtrace/contrib/presto/configuration/settings.rb +0 -31
  936. data/lib/ddtrace/contrib/presto/ext.rb +0 -29
  937. data/lib/ddtrace/contrib/presto/instrumentation.rb +0 -111
  938. data/lib/ddtrace/contrib/presto/integration.rb +0 -39
  939. data/lib/ddtrace/contrib/presto/patcher.rb +0 -34
  940. data/lib/ddtrace/contrib/qless/configuration/settings.rb +0 -36
  941. data/lib/ddtrace/contrib/qless/ext.rb +0 -21
  942. data/lib/ddtrace/contrib/qless/integration.rb +0 -39
  943. data/lib/ddtrace/contrib/qless/patcher.rb +0 -35
  944. data/lib/ddtrace/contrib/qless/qless_job.rb +0 -74
  945. data/lib/ddtrace/contrib/qless/tracer_cleaner.rb +0 -34
  946. data/lib/ddtrace/contrib/que/configuration/settings.rb +0 -44
  947. data/lib/ddtrace/contrib/que/ext.rb +0 -31
  948. data/lib/ddtrace/contrib/que/integration.rb +0 -43
  949. data/lib/ddtrace/contrib/que/patcher.rb +0 -25
  950. data/lib/ddtrace/contrib/que/tracer.rb +0 -58
  951. data/lib/ddtrace/contrib/racecar/configuration/settings.rb +0 -31
  952. data/lib/ddtrace/contrib/racecar/event.rb +0 -77
  953. data/lib/ddtrace/contrib/racecar/events/batch.rb +0 -28
  954. data/lib/ddtrace/contrib/racecar/events/consume.rb +0 -28
  955. data/lib/ddtrace/contrib/racecar/events/message.rb +0 -28
  956. data/lib/ddtrace/contrib/racecar/events.rb +0 -33
  957. data/lib/ddtrace/contrib/racecar/ext.rb +0 -26
  958. data/lib/ddtrace/contrib/racecar/integration.rb +0 -40
  959. data/lib/ddtrace/contrib/racecar/patcher.rb +0 -27
  960. data/lib/ddtrace/contrib/rack/configuration/settings.rb +0 -47
  961. data/lib/ddtrace/contrib/rack/ext.rb +0 -22
  962. data/lib/ddtrace/contrib/rack/integration.rb +0 -46
  963. data/lib/ddtrace/contrib/rack/middlewares.rb +0 -288
  964. data/lib/ddtrace/contrib/rack/patcher.rb +0 -106
  965. data/lib/ddtrace/contrib/rack/request_queue.rb +0 -45
  966. data/lib/ddtrace/contrib/rails/auto_instrument_railtie.rb +0 -10
  967. data/lib/ddtrace/contrib/rails/configuration/settings.rb +0 -101
  968. data/lib/ddtrace/contrib/rails/ext.rb +0 -18
  969. data/lib/ddtrace/contrib/rails/framework.rb +0 -172
  970. data/lib/ddtrace/contrib/rails/integration.rb +0 -45
  971. data/lib/ddtrace/contrib/rails/log_injection.rb +0 -42
  972. data/lib/ddtrace/contrib/rails/middlewares.rb +0 -44
  973. data/lib/ddtrace/contrib/rails/patcher.rb +0 -119
  974. data/lib/ddtrace/contrib/rails/railtie.rb +0 -18
  975. data/lib/ddtrace/contrib/rails/utils.rb +0 -25
  976. data/lib/ddtrace/contrib/rake/configuration/settings.rb +0 -32
  977. data/lib/ddtrace/contrib/rake/ext.rb +0 -22
  978. data/lib/ddtrace/contrib/rake/instrumentation.rb +0 -91
  979. data/lib/ddtrace/contrib/rake/integration.rb +0 -39
  980. data/lib/ddtrace/contrib/rake/patcher.rb +0 -31
  981. data/lib/ddtrace/contrib/redis/configuration/resolver.rb +0 -46
  982. data/lib/ddtrace/contrib/redis/configuration/settings.rb +0 -36
  983. data/lib/ddtrace/contrib/redis/ext.rb +0 -23
  984. data/lib/ddtrace/contrib/redis/instrumentation.rb +0 -90
  985. data/lib/ddtrace/contrib/redis/integration.rb +0 -43
  986. data/lib/ddtrace/contrib/redis/patcher.rb +0 -33
  987. data/lib/ddtrace/contrib/redis/quantize.rb +0 -76
  988. data/lib/ddtrace/contrib/redis/tags.rb +0 -47
  989. data/lib/ddtrace/contrib/redis/vendor/resolver.rb +0 -159
  990. data/lib/ddtrace/contrib/registerable.rb +0 -33
  991. data/lib/ddtrace/contrib/registry.rb +0 -43
  992. data/lib/ddtrace/contrib/resque/configuration/settings.rb +0 -49
  993. data/lib/ddtrace/contrib/resque/ext.rb +0 -18
  994. data/lib/ddtrace/contrib/resque/integration.rb +0 -44
  995. data/lib/ddtrace/contrib/resque/patcher.rb +0 -30
  996. data/lib/ddtrace/contrib/resque/resque_job.rb +0 -104
  997. data/lib/ddtrace/contrib/rest_client/configuration/settings.rb +0 -32
  998. data/lib/ddtrace/contrib/rest_client/ext.rb +0 -18
  999. data/lib/ddtrace/contrib/rest_client/integration.rb +0 -39
  1000. data/lib/ddtrace/contrib/rest_client/patcher.rb +0 -25
  1001. data/lib/ddtrace/contrib/rest_client/request_patch.rb +0 -92
  1002. data/lib/ddtrace/contrib/semantic_logger/configuration/settings.rb +0 -19
  1003. data/lib/ddtrace/contrib/semantic_logger/ext.rb +0 -11
  1004. data/lib/ddtrace/contrib/semantic_logger/instrumentation.rb +0 -43
  1005. data/lib/ddtrace/contrib/semantic_logger/integration.rb +0 -48
  1006. data/lib/ddtrace/contrib/semantic_logger/patcher.rb +0 -26
  1007. data/lib/ddtrace/contrib/sequel/configuration/settings.rb +0 -29
  1008. data/lib/ddtrace/contrib/sequel/database.rb +0 -64
  1009. data/lib/ddtrace/contrib/sequel/dataset.rb +0 -64
  1010. data/lib/ddtrace/contrib/sequel/ext.rb +0 -20
  1011. data/lib/ddtrace/contrib/sequel/integration.rb +0 -39
  1012. data/lib/ddtrace/contrib/sequel/patcher.rb +0 -34
  1013. data/lib/ddtrace/contrib/sequel/utils.rb +0 -75
  1014. data/lib/ddtrace/contrib/shoryuken/configuration/settings.rb +0 -32
  1015. data/lib/ddtrace/contrib/shoryuken/ext.rb +0 -22
  1016. data/lib/ddtrace/contrib/shoryuken/integration.rb +0 -40
  1017. data/lib/ddtrace/contrib/shoryuken/patcher.rb +0 -25
  1018. data/lib/ddtrace/contrib/shoryuken/tracer.rb +0 -56
  1019. data/lib/ddtrace/contrib/sidekiq/client_tracer.rb +0 -44
  1020. data/lib/ddtrace/contrib/sidekiq/configuration/settings.rb +0 -38
  1021. data/lib/ddtrace/contrib/sidekiq/ext.rb +0 -31
  1022. data/lib/ddtrace/contrib/sidekiq/integration.rb +0 -49
  1023. data/lib/ddtrace/contrib/sidekiq/patcher.rb +0 -68
  1024. data/lib/ddtrace/contrib/sidekiq/server_internal_tracer/heartbeat.rb +0 -30
  1025. data/lib/ddtrace/contrib/sidekiq/server_internal_tracer/job_fetch.rb +0 -30
  1026. data/lib/ddtrace/contrib/sidekiq/server_internal_tracer/scheduled_push.rb +0 -29
  1027. data/lib/ddtrace/contrib/sidekiq/server_tracer.rb +0 -66
  1028. data/lib/ddtrace/contrib/sidekiq/tracing.rb +0 -45
  1029. data/lib/ddtrace/contrib/sinatra/configuration/settings.rb +0 -40
  1030. data/lib/ddtrace/contrib/sinatra/env.rb +0 -59
  1031. data/lib/ddtrace/contrib/sinatra/ext.rb +0 -28
  1032. data/lib/ddtrace/contrib/sinatra/headers.rb +0 -30
  1033. data/lib/ddtrace/contrib/sinatra/integration.rb +0 -39
  1034. data/lib/ddtrace/contrib/sinatra/patcher.rb +0 -30
  1035. data/lib/ddtrace/contrib/sinatra/tracer.rb +0 -150
  1036. data/lib/ddtrace/contrib/sinatra/tracer_middleware.rb +0 -112
  1037. data/lib/ddtrace/contrib/sneakers/configuration/settings.rb +0 -34
  1038. data/lib/ddtrace/contrib/sneakers/ext.rb +0 -23
  1039. data/lib/ddtrace/contrib/sneakers/integration.rb +0 -42
  1040. data/lib/ddtrace/contrib/sneakers/patcher.rb +0 -25
  1041. data/lib/ddtrace/contrib/sneakers/tracer.rb +0 -54
  1042. data/lib/ddtrace/contrib/status_code_matcher.rb +0 -70
  1043. data/lib/ddtrace/contrib/sucker_punch/configuration/settings.rb +0 -31
  1044. data/lib/ddtrace/contrib/sucker_punch/exception_handler.rb +0 -25
  1045. data/lib/ddtrace/contrib/sucker_punch/ext.rb +0 -22
  1046. data/lib/ddtrace/contrib/sucker_punch/instrumentation.rb +0 -89
  1047. data/lib/ddtrace/contrib/sucker_punch/integration.rb +0 -39
  1048. data/lib/ddtrace/contrib/sucker_punch/patcher.rb +0 -44
  1049. data/lib/ddtrace/correlation.rb +0 -40
  1050. data/lib/ddtrace/diagnostics/environment_logger.rb +0 -280
  1051. data/lib/ddtrace/diagnostics/health.rb +0 -34
  1052. data/lib/ddtrace/distributed_tracing/headers/b3.rb +0 -45
  1053. data/lib/ddtrace/distributed_tracing/headers/b3_single.rb +0 -57
  1054. data/lib/ddtrace/distributed_tracing/headers/datadog.rb +0 -43
  1055. data/lib/ddtrace/distributed_tracing/headers/headers.rb +0 -72
  1056. data/lib/ddtrace/distributed_tracing/headers/helpers.rb +0 -44
  1057. data/lib/ddtrace/encoding.rb +0 -72
  1058. data/lib/ddtrace/error.rb +0 -97
  1059. data/lib/ddtrace/event.rb +0 -53
  1060. data/lib/ddtrace/ext/analytics.rb +0 -13
  1061. data/lib/ddtrace/ext/app_types.rb +0 -12
  1062. data/lib/ddtrace/ext/correlation.rb +0 -12
  1063. data/lib/ddtrace/ext/diagnostics.rb +0 -37
  1064. data/lib/ddtrace/ext/distributed.rb +0 -40
  1065. data/lib/ddtrace/ext/environment.rb +0 -24
  1066. data/lib/ddtrace/ext/errors.rb +0 -11
  1067. data/lib/ddtrace/ext/forced_tracing.rb +0 -26
  1068. data/lib/ddtrace/ext/git.rb +0 -32
  1069. data/lib/ddtrace/ext/http.rb +0 -47
  1070. data/lib/ddtrace/ext/integration.rb +0 -9
  1071. data/lib/ddtrace/ext/manual_tracing.rb +0 -10
  1072. data/lib/ddtrace/ext/metrics.rb +0 -16
  1073. data/lib/ddtrace/ext/net.rb +0 -11
  1074. data/lib/ddtrace/ext/priority.rb +0 -19
  1075. data/lib/ddtrace/ext/profiling.rb +0 -53
  1076. data/lib/ddtrace/ext/runtime.rb +0 -25
  1077. data/lib/ddtrace/ext/sampling.rb +0 -17
  1078. data/lib/ddtrace/ext/sql.rb +0 -9
  1079. data/lib/ddtrace/ext/test.rb +0 -9
  1080. data/lib/ddtrace/ext/transport.rb +0 -32
  1081. data/lib/ddtrace/forced_tracing.rb +0 -39
  1082. data/lib/ddtrace/logger.rb +0 -41
  1083. data/lib/ddtrace/metrics.rb +0 -282
  1084. data/lib/ddtrace/opentelemetry/extensions.rb +0 -14
  1085. data/lib/ddtrace/opentelemetry/span.rb +0 -34
  1086. data/lib/ddtrace/opentracer/binary_propagator.rb +0 -25
  1087. data/lib/ddtrace/opentracer/carrier.rb +0 -7
  1088. data/lib/ddtrace/opentracer/distributed_headers.rb +0 -56
  1089. data/lib/ddtrace/opentracer/global_tracer.rb +0 -16
  1090. data/lib/ddtrace/opentracer/propagator.rb +0 -23
  1091. data/lib/ddtrace/opentracer/rack_propagator.rb +0 -61
  1092. data/lib/ddtrace/opentracer/scope.rb +0 -16
  1093. data/lib/ddtrace/opentracer/scope_manager.rb +0 -7
  1094. data/lib/ddtrace/opentracer/span.rb +0 -95
  1095. data/lib/ddtrace/opentracer/span_context.rb +0 -15
  1096. data/lib/ddtrace/opentracer/span_context_factory.rb +0 -24
  1097. data/lib/ddtrace/opentracer/text_map_propagator.rb +0 -76
  1098. data/lib/ddtrace/opentracer/thread_local_scope.rb +0 -32
  1099. data/lib/ddtrace/opentracer/thread_local_scope_manager.rb +0 -41
  1100. data/lib/ddtrace/opentracer/tracer.rb +0 -209
  1101. data/lib/ddtrace/opentracer.rb +0 -22
  1102. data/lib/ddtrace/patcher.rb +0 -69
  1103. data/lib/ddtrace/pin.rb +0 -86
  1104. data/lib/ddtrace/pipeline/span_filter.rb +0 -39
  1105. data/lib/ddtrace/pipeline/span_processor.rb +0 -21
  1106. data/lib/ddtrace/pipeline.rb +0 -47
  1107. data/lib/ddtrace/profiling/backtrace_location.rb +0 -33
  1108. data/lib/ddtrace/profiling/buffer.rb +0 -42
  1109. data/lib/ddtrace/profiling/collectors/stack.rb +0 -297
  1110. data/lib/ddtrace/profiling/encoding/profile.rb +0 -46
  1111. data/lib/ddtrace/profiling/event.rb +0 -14
  1112. data/lib/ddtrace/profiling/events/stack.rb +0 -81
  1113. data/lib/ddtrace/profiling/exporter.rb +0 -24
  1114. data/lib/ddtrace/profiling/ext/forking.rb +0 -98
  1115. data/lib/ddtrace/profiling/flush.rb +0 -44
  1116. data/lib/ddtrace/profiling/native_extension.rb +0 -40
  1117. data/lib/ddtrace/profiling/pprof/builder.rb +0 -126
  1118. data/lib/ddtrace/profiling/pprof/converter.rb +0 -103
  1119. data/lib/ddtrace/profiling/pprof/message_set.rb +0 -15
  1120. data/lib/ddtrace/profiling/pprof/payload.rb +0 -19
  1121. data/lib/ddtrace/profiling/pprof/pprof_pb.rb +0 -82
  1122. data/lib/ddtrace/profiling/pprof/stack_sample.rb +0 -140
  1123. data/lib/ddtrace/profiling/pprof/string_table.rb +0 -11
  1124. data/lib/ddtrace/profiling/pprof/template.rb +0 -119
  1125. data/lib/ddtrace/profiling/profiler.rb +0 -31
  1126. data/lib/ddtrace/profiling/recorder.rb +0 -96
  1127. data/lib/ddtrace/profiling/scheduler.rb +0 -150
  1128. data/lib/ddtrace/profiling/tasks/setup.rb +0 -90
  1129. data/lib/ddtrace/profiling/trace_identifiers/ddtrace.rb +0 -42
  1130. data/lib/ddtrace/profiling/trace_identifiers/helper.rb +0 -46
  1131. data/lib/ddtrace/profiling/transport/client.rb +0 -15
  1132. data/lib/ddtrace/profiling/transport/http/api/endpoint.rb +0 -94
  1133. data/lib/ddtrace/profiling/transport/http/api/instance.rb +0 -37
  1134. data/lib/ddtrace/profiling/transport/http/api/spec.rb +0 -41
  1135. data/lib/ddtrace/profiling/transport/http/api.rb +0 -44
  1136. data/lib/ddtrace/profiling/transport/http/builder.rb +0 -29
  1137. data/lib/ddtrace/profiling/transport/http/client.rb +0 -34
  1138. data/lib/ddtrace/profiling/transport/http/response.rb +0 -22
  1139. data/lib/ddtrace/profiling/transport/http.rb +0 -111
  1140. data/lib/ddtrace/profiling/transport/io/client.rb +0 -28
  1141. data/lib/ddtrace/profiling/transport/io/response.rb +0 -17
  1142. data/lib/ddtrace/profiling/transport/io.rb +0 -31
  1143. data/lib/ddtrace/profiling/transport/parcel.rb +0 -18
  1144. data/lib/ddtrace/profiling/transport/request.rb +0 -16
  1145. data/lib/ddtrace/profiling/transport/response.rb +0 -9
  1146. data/lib/ddtrace/profiling.rb +0 -149
  1147. data/lib/ddtrace/propagation/grpc_propagator.rb +0 -75
  1148. data/lib/ddtrace/propagation/http_propagator.rb +0 -91
  1149. data/lib/ddtrace/quantization/hash.rb +0 -104
  1150. data/lib/ddtrace/quantization/http.rb +0 -90
  1151. data/lib/ddtrace/runtime/metrics.rb +0 -135
  1152. data/lib/ddtrace/sampler.rb +0 -303
  1153. data/lib/ddtrace/sampling/matcher.rb +0 -58
  1154. data/lib/ddtrace/sampling/rate_limiter.rb +0 -177
  1155. data/lib/ddtrace/sampling/rule.rb +0 -62
  1156. data/lib/ddtrace/sampling/rule_sampler.rb +0 -133
  1157. data/lib/ddtrace/sampling.rb +0 -3
  1158. data/lib/ddtrace/span.rb +0 -445
  1159. data/lib/ddtrace/sync_writer.rb +0 -69
  1160. data/lib/ddtrace/tasks/exec.rb +0 -47
  1161. data/lib/ddtrace/tasks/help.rb +0 -15
  1162. data/lib/ddtrace/tracer.rb +0 -449
  1163. data/lib/ddtrace/utils/compression.rb +0 -28
  1164. data/lib/ddtrace/utils/database.rb +0 -26
  1165. data/lib/ddtrace/utils/forking.rb +0 -53
  1166. data/lib/ddtrace/utils/object_set.rb +0 -40
  1167. data/lib/ddtrace/utils/only_once.rb +0 -41
  1168. data/lib/ddtrace/utils/sequence.rb +0 -18
  1169. data/lib/ddtrace/utils/string_table.rb +0 -46
  1170. data/lib/ddtrace/utils/time.rb +0 -51
  1171. data/lib/ddtrace/utils.rb +0 -80
  1172. data/lib/ddtrace/vendor/active_record/connection_specification.rb +0 -302
  1173. data/lib/ddtrace/vendor/multipart-post/multipart/post/composite_read_io.rb +0 -117
  1174. data/lib/ddtrace/vendor/multipart-post/multipart/post/multipartable.rb +0 -58
  1175. data/lib/ddtrace/vendor/multipart-post/multipart/post/parts.rb +0 -136
  1176. data/lib/ddtrace/vendor/multipart-post/multipart/post/version.rb +0 -10
  1177. data/lib/ddtrace/vendor/multipart-post/multipart/post.rb +0 -9
  1178. data/lib/ddtrace/vendor/multipart-post/multipart.rb +0 -13
  1179. data/lib/ddtrace/vendor/multipart-post/net/http/post/multipart.rb +0 -33
  1180. data/lib/ddtrace/worker.rb +0 -21
  1181. data/lib/ddtrace/workers/async.rb +0 -175
  1182. data/lib/ddtrace/workers/interval_loop.rb +0 -116
  1183. data/lib/ddtrace/workers/polling.rb +0 -56
  1184. data/lib/ddtrace/workers/queue.rb +0 -41
  1185. data/lib/ddtrace/workers/runtime_metrics.rb +0 -65
  1186. data/lib/ddtrace/workers/trace_writer.rb +0 -200
  1187. data/lib/ddtrace/workers.rb +0 -123
  1188. data/lib/ddtrace/writer.rb +0 -200
  1189. /data/lib/{ddtrace → datadog/core}/vendor/multipart-post/LICENSE +0 -0
  1190. /data/lib/{ddtrace → datadog}/profiling/pprof/pprof.proto +0 -0
  1191. /data/lib/{ddtrace/vendor/active_record → datadog/tracing/contrib/active_record/vendor}/MIT-LICENSE +0 -0
  1192. /data/lib/{ddtrace → datadog/tracing}/contrib/redis/vendor/LICENSE +0 -0
@@ -0,0 +1,487 @@
1
+ #include <ruby.h>
2
+ #include <ruby/thread.h>
3
+ #include <pthread.h>
4
+ #include <errno.h>
5
+ #include "helpers.h"
6
+ #include "stack_recorder.h"
7
+ #include "libdatadog_helpers.h"
8
+ #include "ruby_helpers.h"
9
+
10
+ // Used to wrap a ddog_Profile in a Ruby object and expose Ruby-level serialization APIs
11
+ // This file implements the native bits of the Datadog::Profiling::StackRecorder class
12
+
13
+ // ---
14
+ // ## Synchronization mechanism for safe parallel access design notes
15
+ //
16
+ // The state of the StackRecorder is managed using a set of locks to avoid concurrency issues.
17
+ //
18
+ // This is needed because the state is expected to be accessed, in parallel, by two different threads.
19
+ //
20
+ // 1. The thread that is taking a stack sample and that called `record_sample`, let's call it the **sampler thread**.
21
+ // In the current implementation of the profiler, there can only exist one **sampler thread** at a time; if this
22
+ // constraint changes, we should revise the design of the StackRecorder.
23
+ //
24
+ // 2. The thread that serializes and reports profiles, let's call it the **serializer thread**. We enforce that there
25
+ // cannot be more than one thread attempting to serialize profiles at a time.
26
+ //
27
+ // If both the sampler and serializer threads are trying to access the same `ddog_Profile` in parallel, we will
28
+ // have a concurrency issue. Thus, the StackRecorder has an added mechanism to avoid this.
29
+ //
30
+ // As an additional constraint, the **sampler thread** has absolute priority and must never block while
31
+ // recording a sample.
32
+ //
33
+ // ### The solution: Keep two profiles at the same time
34
+ //
35
+ // To solve for the constraints above, the StackRecorder keeps two `ddog_Profile` profile instances inside itself.
36
+ // They are called the `slot_one_profile` and `slot_two_profile`.
37
+ //
38
+ // Each profile is paired with its own mutex. `slot_one_profile` is protected by `slot_one_mutex` and `slot_two_profile`
39
+ // is protected by `slot_two_mutex`.
40
+ //
41
+ // We additionally introduce the concept of **active** and **inactive** profile slots. At any point, the sampler thread
42
+ // can probe the mutexes to discover which of the profiles corresponds to the active slot, and then records samples in it.
43
+ // When the serializer thread is ready to serialize data, it flips the active and inactive slots; it reports the data
44
+ // on the previously-active profile slot, and the sampler thread can continue to record in the previously-inactive
45
+ // profile slot.
46
+ //
47
+ // Thus, the sampler and serializer threads never cross paths, avoiding concurrency issues. The sampler thread writes to
48
+ // the active profile slot, and the serializer thread reads from the inactive profile slot.
49
+ //
50
+ // ### Locking protocol, high-level
51
+ //
52
+ // The active profile slot is the slot for which its corresponding mutex **is unlocked**. That is, if the sampler
53
+ // thread can grab a lock for a profile slot, then that slot is the active one. (Here you see where the constraint
54
+ // stated above that only one sampler thread can exist kicks in -- this part would need to be more complex if multiple
55
+ // sampler threads were in play.)
56
+ //
57
+ // As a counterpart, the inactive profile slot mutex is **kept locked** until such time the serializer
58
+ // thread is ready to work and decides to flip the slots.
59
+ //
60
+ // When a new StackRecorder is initialized, the `slot_one_mutex` is unlocked, and the `slot_two_mutex` is kept locked,
61
+ // that is, a new instance always starts with slot one active.
62
+ //
63
+ // Additionally, an `active_slot` field is kept, containing a `1` or `2`; this is only kept for the serializer thread
64
+ // to use as a simplification, as well as for testing and debugging; the **sampler thread must never use the `active_slot`
65
+ // field**.
66
+ //
67
+ // ### Locking protocol, from the sampler thread side
68
+ //
69
+ // When the sampler thread wants to record a sample, it goes through the following steps to discover which is the
70
+ // active profile slot:
71
+ //
72
+ // 1. `pthread_mutex_trylock(slot_one_mutex)`. If it succeeds to grab the lock, this means the active profile slot is
73
+ // slot one. If it fails, we move to the next step.
74
+ //
75
+ // 2. `pthread_mutex_trylock(slot_two_mutex)`. If it succeeds to grab the lock, this means the active profile slot is
76
+ // slot two. If it fails, we move to the next step.
77
+ //
78
+ // 3. What does it mean for the sampler thread to have observed both `slot_one_mutex` as well as `slot_two_mutex` as
79
+ // being locked? There are two options:
80
+ // a. The sampler thread got really unlucky. When it tried to grab the `slot_one_mutex`, the active profile slot was
81
+ // the second one BUT then the serializer thread flipped the slots, and by the time the sampler thread probed the
82
+ // `slot_two_mutex`, that one was taken. Since the serializer thread is expected only to work once a minute,
83
+ // we retry steps 1. and 2. and should be able to find an active slot.
84
+ // b. Something is incorrect in the StackRecorder state. In this situation, the sampler thread should give up on
85
+ // sampling and enter an error state.
86
+ //
87
+ // Note that in the steps above, and because the sampler thread uses `trylock` to probe the mutexes, that the
88
+ // sampler thread never blocks. It either is able to find an active profile slot in a bounded amount of steps or it
89
+ // enters an error state.
90
+ //
91
+ // This guarantees that sampler performance is never constrained by serializer performance.
92
+ //
93
+ // ### Locking protocol, from the serializer thread side
94
+ //
95
+ // When the serializer thread wants to serialize a profile, it first flips the active and inactive profile slots.
96
+ //
97
+ // The flipping action is described below. Consider previously-inactive and previously-active as the state of the slots
98
+ // before the flipping happens.
99
+ //
100
+ // The flipping steps are the following:
101
+ //
102
+ // 1. Release the mutex for the previously-inactive profile slot. That slot, as seen by the sampler thread, is now
103
+ // active.
104
+ //
105
+ // 2. Grab the mutex for the previously-active profile slot. Note that this can lead to the serializer thread blocking,
106
+ // if the sampler thread is holding this mutex. After the mutex is grabbed, the previously-active slot becomes inactive,
107
+ // as seen by the sampler thread.
108
+ //
109
+ // 3. Update `active_slot`.
110
+ //
111
+ // After flipping the profile slots, the serializer thread is now free to serialize the inactive profile slot. The slot
112
+ // is kept inactive until the next time the serializer thread wants to serialize data.
113
+ //
114
+ // Note there can be a brief period between steps 1 and 2 where the serializer thread holds no lock, which means that
115
+ // the sampler thread can pick either slot. This is OK: if the sampler thread picks the previously-inactive slot, the
116
+ // samples will be reported on the next serialization; if the sampler thread picks the previously-active slot, the
117
+ // samples are still included in the current serialization. Either option is correct.
118
+ //
119
+ // ### Additional notes
120
+ //
121
+ // Q: Can the sampler thread and the serializer thread ever be the same thread? (E.g. sampling in interrupt handler)
122
+ // A: No; the current profiler design requires that sampling happens only on the thread that is holding the Global VM
123
+ // Lock (GVL). The serializer thread flipping occurs after the serializer thread releases the GVL, and thus the
124
+ // serializer thread will not be able to host the sampling process.
125
+ //
126
+ // ---
127
+
128
+ static VALUE ok_symbol = Qnil; // :ok in Ruby
129
+ static VALUE error_symbol = Qnil; // :error in Ruby
130
+
131
+ static ID ruby_time_from_id; // id of :ruby_time_from in Ruby
132
+
133
+ static VALUE stack_recorder_class = Qnil;
134
+
135
+ // Contains native state for each instance
136
+ struct stack_recorder_state {
137
+ pthread_mutex_t slot_one_mutex;
138
+ ddog_Profile *slot_one_profile;
139
+
140
+ pthread_mutex_t slot_two_mutex;
141
+ ddog_Profile *slot_two_profile;
142
+
143
+ short active_slot; // MUST NEVER BE ACCESSED FROM record_sample; this is NOT for the sampler thread to use.
144
+ };
145
+
146
+ // Used to return a pair of values from sampler_lock_active_profile()
147
+ struct active_slot_pair {
148
+ pthread_mutex_t *mutex;
149
+ ddog_Profile *profile;
150
+ };
151
+
152
+ struct call_serialize_without_gvl_arguments {
153
+ // Set by caller
154
+ struct stack_recorder_state *state;
155
+ ddog_Timespec finish_timestamp;
156
+
157
+ // Set by callee
158
+ ddog_Profile *profile;
159
+ ddog_SerializeResult result;
160
+
161
+ // Set by both
162
+ bool serialize_ran;
163
+ };
164
+
165
+ static VALUE _native_new(VALUE klass);
166
+ static void initialize_slot_concurrency_control(struct stack_recorder_state *state);
167
+ static void stack_recorder_typed_data_free(void *data);
168
+ static VALUE _native_serialize(VALUE self, VALUE recorder_instance);
169
+ static VALUE ruby_time_from(ddog_Timespec ddprof_time);
170
+ static void *call_serialize_without_gvl(void *call_args);
171
+ static struct active_slot_pair sampler_lock_active_profile();
172
+ static void sampler_unlock_active_profile(struct active_slot_pair active_slot);
173
+ static ddog_Profile *serializer_flip_active_and_inactive_slots(struct stack_recorder_state *state);
174
+ static VALUE _native_active_slot(DDTRACE_UNUSED VALUE _self, VALUE recorder_instance);
175
+ static VALUE _native_is_slot_one_mutex_locked(DDTRACE_UNUSED VALUE _self, VALUE recorder_instance);
176
+ static VALUE _native_is_slot_two_mutex_locked(DDTRACE_UNUSED VALUE _self, VALUE recorder_instance);
177
+ static VALUE test_slot_mutex_state(VALUE recorder_instance, int slot);
178
+ static ddog_Timespec time_now(void);
179
+ static VALUE _native_reset_after_fork(DDTRACE_UNUSED VALUE self, VALUE recorder_instance);
180
+ static void serializer_set_start_timestamp_for_next_profile(struct stack_recorder_state *state, ddog_Timespec timestamp);
181
+ static VALUE _native_record_endpoint(DDTRACE_UNUSED VALUE _self, VALUE recorder_instance, VALUE local_root_span_id, VALUE endpoint);
182
+
183
+ void stack_recorder_init(VALUE profiling_module) {
184
+ stack_recorder_class = rb_define_class_under(profiling_module, "StackRecorder", rb_cObject);
185
+ // Hosts methods used for testing the native code using RSpec
186
+ VALUE testing_module = rb_define_module_under(stack_recorder_class, "Testing");
187
+
188
+ // Instances of the StackRecorder class are "TypedData" objects.
189
+ // "TypedData" objects are special objects in the Ruby VM that can wrap C structs.
190
+ // In this case, it wraps the stack_recorder_state.
191
+ //
192
+ // Because Ruby doesn't know how to initialize native-level structs, we MUST override the allocation function for objects
193
+ // of this class so that we can manage this part. Not overriding or disabling the allocation function is a common
194
+ // gotcha for "TypedData" objects that can very easily lead to VM crashes, see for instance
195
+ // https://bugs.ruby-lang.org/issues/18007 for a discussion around this.
196
+ rb_define_alloc_func(stack_recorder_class, _native_new);
197
+
198
+ rb_define_singleton_method(stack_recorder_class, "_native_serialize", _native_serialize, 1);
199
+ rb_define_singleton_method(stack_recorder_class, "_native_reset_after_fork", _native_reset_after_fork, 1);
200
+ rb_define_singleton_method(testing_module, "_native_active_slot", _native_active_slot, 1);
201
+ rb_define_singleton_method(testing_module, "_native_slot_one_mutex_locked?", _native_is_slot_one_mutex_locked, 1);
202
+ rb_define_singleton_method(testing_module, "_native_slot_two_mutex_locked?", _native_is_slot_two_mutex_locked, 1);
203
+ rb_define_singleton_method(testing_module, "_native_record_endpoint", _native_record_endpoint, 3);
204
+
205
+ ok_symbol = ID2SYM(rb_intern_const("ok"));
206
+ error_symbol = ID2SYM(rb_intern_const("error"));
207
+ ruby_time_from_id = rb_intern_const("ruby_time_from");
208
+ }
209
+
210
+ // This structure is used to define a Ruby object that stores a pointer to a ddog_Profile instance
211
+ // See also https://github.com/ruby/ruby/blob/master/doc/extension.rdoc for how this works
212
+ static const rb_data_type_t stack_recorder_typed_data = {
213
+ .wrap_struct_name = "Datadog::Profiling::StackRecorder",
214
+ .function = {
215
+ .dfree = stack_recorder_typed_data_free,
216
+ .dsize = NULL, // We don't track profile memory usage (although it'd be cool if we did!)
217
+ // No need to provide dmark nor dcompact because we don't directly reference Ruby VALUEs from inside this object
218
+ },
219
+ .flags = RUBY_TYPED_FREE_IMMEDIATELY
220
+ };
221
+
222
+ static VALUE _native_new(VALUE klass) {
223
+ struct stack_recorder_state *state = ruby_xcalloc(1, sizeof(struct stack_recorder_state));
224
+
225
+ ddog_Slice_value_type sample_types = {.ptr = enabled_value_types, .len = ENABLED_VALUE_TYPES_COUNT};
226
+
227
+ initialize_slot_concurrency_control(state);
228
+
229
+ // Note: Don't raise exceptions after this point, since it'll lead to libdatadog memory leaking!
230
+
231
+ state->slot_one_profile = ddog_Profile_new(sample_types, NULL /* period is optional */, NULL /* start_time is optional */);
232
+ state->slot_two_profile = ddog_Profile_new(sample_types, NULL /* period is optional */, NULL /* start_time is optional */);
233
+
234
+ return TypedData_Wrap_Struct(klass, &stack_recorder_typed_data, state);
235
+ }
236
+
237
+ static void initialize_slot_concurrency_control(struct stack_recorder_state *state) {
238
+ state->slot_one_mutex = (pthread_mutex_t) PTHREAD_MUTEX_INITIALIZER;
239
+ state->slot_two_mutex = (pthread_mutex_t) PTHREAD_MUTEX_INITIALIZER;
240
+
241
+ // A newly-created StackRecorder starts with slot one being active for samples, so let's lock slot two
242
+ ENFORCE_SUCCESS_GVL(pthread_mutex_lock(&state->slot_two_mutex));
243
+
244
+ state->active_slot = 1;
245
+ }
246
+
247
+ static void stack_recorder_typed_data_free(void *state_ptr) {
248
+ struct stack_recorder_state *state = (struct stack_recorder_state *) state_ptr;
249
+
250
+ pthread_mutex_destroy(&state->slot_one_mutex);
251
+ ddog_Profile_free(state->slot_one_profile);
252
+
253
+ pthread_mutex_destroy(&state->slot_two_mutex);
254
+ ddog_Profile_free(state->slot_two_profile);
255
+
256
+ ruby_xfree(state);
257
+ }
258
+
259
+ static VALUE _native_serialize(DDTRACE_UNUSED VALUE _self, VALUE recorder_instance) {
260
+ struct stack_recorder_state *state;
261
+ TypedData_Get_Struct(recorder_instance, struct stack_recorder_state, &stack_recorder_typed_data, state);
262
+
263
+ ddog_Timespec finish_timestamp = time_now();
264
+ // Need to do this while still holding on to the Global VM Lock; see comments on method for why
265
+ serializer_set_start_timestamp_for_next_profile(state, finish_timestamp);
266
+
267
+ // We'll release the Global VM Lock while we're calling serialize, so that the Ruby VM can continue to work while this
268
+ // is pending
269
+ struct call_serialize_without_gvl_arguments args = {.state = state, .finish_timestamp = finish_timestamp, .serialize_ran = false};
270
+
271
+ while (!args.serialize_ran) {
272
+ // Give the Ruby VM an opportunity to process any pending interruptions (including raising exceptions).
273
+ // Note that it's OK to do this BEFORE call_serialize_without_gvl runs BUT NOT AFTER because afterwards
274
+ // there's heap-allocated memory that MUST be cleaned before raising any exception.
275
+ //
276
+ // Note that we run this in a loop because `rb_thread_call_without_gvl2` may return multiple times due to
277
+ // pending interrupts until it actually runs our code.
278
+ process_pending_interruptions(Qnil);
279
+
280
+ // We use rb_thread_call_without_gvl2 here because unlike the regular _gvl variant, gvl2 does not process
281
+ // interruptions and thus does not raise exceptions after running our code.
282
+ rb_thread_call_without_gvl2(call_serialize_without_gvl, &args, NULL /* No interruption function needed in this case */, NULL /* Not needed */);
283
+ }
284
+
285
+ ddog_SerializeResult serialized_profile = args.result;
286
+
287
+ if (serialized_profile.tag == DDOG_SERIALIZE_RESULT_ERR) {
288
+ VALUE err_details = ruby_string_from_vec_u8(serialized_profile.err);
289
+ ddog_SerializeResult_drop(serialized_profile);
290
+ return rb_ary_new_from_args(2, error_symbol, err_details);
291
+ }
292
+
293
+ VALUE encoded_pprof = ruby_string_from_vec_u8(serialized_profile.ok.buffer);
294
+
295
+ ddog_Timespec ddprof_start = serialized_profile.ok.start;
296
+ ddog_Timespec ddprof_finish = serialized_profile.ok.end;
297
+
298
+ // Clean up libdatadog object to avoid leaking in case ruby_time_from raises an exception
299
+ ddog_SerializeResult_drop(serialized_profile);
300
+
301
+ VALUE start = ruby_time_from(ddprof_start);
302
+ VALUE finish = ruby_time_from(ddprof_finish);
303
+
304
+ if (!ddog_Profile_reset(args.profile, NULL /* start_time is optional */ )) {
305
+ return rb_ary_new_from_args(2, error_symbol, rb_str_new_cstr("Failed to reset profile"));
306
+ }
307
+
308
+ return rb_ary_new_from_args(2, ok_symbol, rb_ary_new_from_args(3, start, finish, encoded_pprof));
309
+ }
310
+
311
+ static VALUE ruby_time_from(ddog_Timespec ddprof_time) {
312
+ #ifndef NO_RB_TIME_TIMESPEC_NEW // Modern Rubies
313
+ const int utc = INT_MAX - 1; // From Ruby sources
314
+ struct timespec time = {.tv_sec = ddprof_time.seconds, .tv_nsec = ddprof_time.nanoseconds};
315
+ return rb_time_timespec_new(&time, utc);
316
+ #else // Ruby < 2.3
317
+ return rb_funcall(stack_recorder_class, ruby_time_from_id, 2, LONG2NUM(ddprof_time.seconds), UINT2NUM(ddprof_time.nanoseconds));
318
+ #endif
319
+ }
320
+
321
+ void record_sample(VALUE recorder_instance, ddog_Sample sample) {
322
+ struct stack_recorder_state *state;
323
+ TypedData_Get_Struct(recorder_instance, struct stack_recorder_state, &stack_recorder_typed_data, state);
324
+
325
+ struct active_slot_pair active_slot = sampler_lock_active_profile(state);
326
+
327
+ ddog_Profile_add(active_slot.profile, sample);
328
+
329
+ sampler_unlock_active_profile(active_slot);
330
+ }
331
+
332
+ void record_endpoint(VALUE recorder_instance, ddog_CharSlice local_root_span_id, ddog_CharSlice endpoint) {
333
+ struct stack_recorder_state *state;
334
+ TypedData_Get_Struct(recorder_instance, struct stack_recorder_state, &stack_recorder_typed_data, state);
335
+
336
+ struct active_slot_pair active_slot = sampler_lock_active_profile(state);
337
+
338
+ ddog_Profile_set_endpoint(active_slot.profile, local_root_span_id, endpoint);
339
+
340
+ sampler_unlock_active_profile(active_slot);
341
+ }
342
+
343
+ static void *call_serialize_without_gvl(void *call_args) {
344
+ struct call_serialize_without_gvl_arguments *args = (struct call_serialize_without_gvl_arguments *) call_args;
345
+
346
+ args->profile = serializer_flip_active_and_inactive_slots(args->state);
347
+ args->result = ddog_Profile_serialize(args->profile, &args->finish_timestamp, NULL /* duration_nanos is optional */);
348
+ args->serialize_ran = true;
349
+
350
+ return NULL; // Unused
351
+ }
352
+
353
+ VALUE enforce_recorder_instance(VALUE object) {
354
+ Check_TypedStruct(object, &stack_recorder_typed_data);
355
+ return object;
356
+ }
357
+
358
+ static struct active_slot_pair sampler_lock_active_profile(struct stack_recorder_state *state) {
359
+ int error;
360
+
361
+ for (int attempts = 0; attempts < 2; attempts++) {
362
+ error = pthread_mutex_trylock(&state->slot_one_mutex);
363
+ if (error && error != EBUSY) ENFORCE_SUCCESS_GVL(error);
364
+
365
+ // Slot one is active
366
+ if (!error) return (struct active_slot_pair) {.mutex = &state->slot_one_mutex, .profile = state->slot_one_profile};
367
+
368
+ // If we got here, slot one was not active, let's try slot two
369
+
370
+ error = pthread_mutex_trylock(&state->slot_two_mutex);
371
+ if (error && error != EBUSY) ENFORCE_SUCCESS_GVL(error);
372
+
373
+ // Slot two is active
374
+ if (!error) return (struct active_slot_pair) {.mutex = &state->slot_two_mutex, .profile = state->slot_two_profile};
375
+ }
376
+
377
+ // We already tried both multiple times, and we did not succeed. This is not expected to happen. Let's stop sampling.
378
+ rb_raise(rb_eRuntimeError, "Failed to grab either mutex in sampler_lock_active_profile");
379
+ }
380
+
381
+ static void sampler_unlock_active_profile(struct active_slot_pair active_slot) {
382
+ ENFORCE_SUCCESS_GVL(pthread_mutex_unlock(active_slot.mutex));
383
+ }
384
+
385
+ static ddog_Profile *serializer_flip_active_and_inactive_slots(struct stack_recorder_state *state) {
386
+ int previously_active_slot = state->active_slot;
387
+
388
+ if (previously_active_slot != 1 && previously_active_slot != 2) {
389
+ grab_gvl_and_raise(rb_eRuntimeError, "Unexpected active_slot state %d in serializer_flip_active_and_inactive_slots", previously_active_slot);
390
+ }
391
+
392
+ pthread_mutex_t *previously_active = (previously_active_slot == 1) ? &state->slot_one_mutex : &state->slot_two_mutex;
393
+ pthread_mutex_t *previously_inactive = (previously_active_slot == 1) ? &state->slot_two_mutex : &state->slot_one_mutex;
394
+
395
+ // Release the lock, thus making this slot active
396
+ ENFORCE_SUCCESS_NO_GVL(pthread_mutex_unlock(previously_inactive));
397
+
398
+ // Grab the lock, thus making this slot inactive
399
+ ENFORCE_SUCCESS_NO_GVL(pthread_mutex_lock(previously_active));
400
+
401
+ // Update active_slot
402
+ state->active_slot = (previously_active_slot == 1) ? 2 : 1;
403
+
404
+ // Return profile for previously active slot (now inactive)
405
+ return (previously_active_slot == 1) ? state->slot_one_profile : state->slot_two_profile;
406
+ }
407
+
408
+ // This method exists only to enable testing Datadog::Profiling::StackRecorder behavior using RSpec.
409
+ // It SHOULD NOT be used for other purposes.
410
+ static VALUE _native_active_slot(DDTRACE_UNUSED VALUE _self, VALUE recorder_instance) {
411
+ struct stack_recorder_state *state;
412
+ TypedData_Get_Struct(recorder_instance, struct stack_recorder_state, &stack_recorder_typed_data, state);
413
+
414
+ return INT2NUM(state->active_slot);
415
+ }
416
+
417
+ // This method exists only to enable testing Datadog::Profiling::StackRecorder behavior using RSpec.
418
+ // It SHOULD NOT be used for other purposes.
419
+ static VALUE _native_is_slot_one_mutex_locked(DDTRACE_UNUSED VALUE _self, VALUE recorder_instance) { return test_slot_mutex_state(recorder_instance, 1); }
420
+
421
+ // This method exists only to enable testing Datadog::Profiling::StackRecorder behavior using RSpec.
422
+ // It SHOULD NOT be used for other purposes.
423
+ static VALUE _native_is_slot_two_mutex_locked(DDTRACE_UNUSED VALUE _self, VALUE recorder_instance) { return test_slot_mutex_state(recorder_instance, 2); }
424
+
425
+ static VALUE test_slot_mutex_state(VALUE recorder_instance, int slot) {
426
+ struct stack_recorder_state *state;
427
+ TypedData_Get_Struct(recorder_instance, struct stack_recorder_state, &stack_recorder_typed_data, state);
428
+
429
+ pthread_mutex_t *slot_mutex = (slot == 1) ? &state->slot_one_mutex : &state->slot_two_mutex;
430
+
431
+ // Like Heisenberg's uncertainty principle, we can't observe without affecting...
432
+ int error = pthread_mutex_trylock(slot_mutex);
433
+
434
+ if (error == 0) {
435
+ // Mutex was unlocked
436
+ ENFORCE_SUCCESS_GVL(pthread_mutex_unlock(slot_mutex));
437
+ return Qfalse;
438
+ } else if (error == EBUSY) {
439
+ // Mutex was locked
440
+ return Qtrue;
441
+ } else {
442
+ ENFORCE_SUCCESS_GVL(error);
443
+ rb_raise(rb_eRuntimeError, "Failed to raise exception in test_slot_mutex_state; this should never happen");
444
+ }
445
+ }
446
+
447
+ // Note that this is using CLOCK_REALTIME (e.g. actual time since unix epoch) and not the CLOCK_MONOTONIC as we use in
448
+ // monotonic_wall_time_now_ns (used in other parts of the codebase)
449
+ static ddog_Timespec time_now(void) {
450
+ struct timespec current_time;
451
+
452
+ if (clock_gettime(CLOCK_REALTIME, &current_time) != 0) ENFORCE_SUCCESS_GVL(errno);
453
+
454
+ return (ddog_Timespec) {.seconds = current_time.tv_sec, .nanoseconds = (uint32_t) current_time.tv_nsec};
455
+ }
456
+
457
+ // After the Ruby VM forks, this method gets called in the child process to clean up any leftover state from the parent.
458
+ //
459
+ // Assumption: This method gets called BEFORE restarting profiling -- e.g. there are no components attempting to
460
+ // trigger samples at the same time.
461
+ static VALUE _native_reset_after_fork(DDTRACE_UNUSED VALUE self, VALUE recorder_instance) {
462
+ struct stack_recorder_state *state;
463
+ TypedData_Get_Struct(recorder_instance, struct stack_recorder_state, &stack_recorder_typed_data, state);
464
+
465
+ // In case the fork happened halfway through `serializer_flip_active_and_inactive_slots` execution and the
466
+ // resulting state is inconsistent, we make sure to reset it back to the initial state.
467
+ initialize_slot_concurrency_control(state);
468
+
469
+ ddog_Profile_reset(state->slot_one_profile, /* start_time: */ NULL);
470
+ ddog_Profile_reset(state->slot_two_profile, /* start_time: */ NULL);
471
+
472
+ return Qtrue;
473
+ }
474
+
475
+ // Assumption 1: This method is called with the GVL being held, because `ddog_Profile_reset` mutates the profile and should
476
+ // not be interrupted part-way through by a VM fork.
477
+ static void serializer_set_start_timestamp_for_next_profile(struct stack_recorder_state *state, ddog_Timespec timestamp) {
478
+ // Before making this profile active, we reset it so that it uses the correct timestamp for its start
479
+ ddog_Profile *next_profile = (state->active_slot == 1) ? state->slot_two_profile : state->slot_one_profile;
480
+
481
+ if (!ddog_Profile_reset(next_profile, &timestamp)) rb_raise(rb_eRuntimeError, "Failed to reset profile");
482
+ }
483
+
484
+ static VALUE _native_record_endpoint(DDTRACE_UNUSED VALUE _self, VALUE recorder_instance, VALUE local_root_span_id, VALUE endpoint) {
485
+ record_endpoint(recorder_instance, char_slice_from_ruby_string(local_root_span_id), char_slice_from_ruby_string(endpoint));
486
+ return Qtrue;
487
+ }
@@ -0,0 +1,39 @@
1
+ #pragma once
2
+
3
+ #include <datadog/profiling.h>
4
+
5
+ // Note: Please DO NOT use `VALUE_STRING` anywhere else, instead use `DDOG_CHARSLICE_C`.
6
+ // `VALUE_STRING` is only needed because older versions of gcc (4.9.2, used in our Ruby 2.2 CI test images)
7
+ // tripped when compiling `enabled_value_types` using `-std=gnu99` due to the extra cast that is included in
8
+ // `DDOG_CHARSLICE_C` with the following error:
9
+ //
10
+ // ```
11
+ // compiling ../../../../ext/ddtrace_profiling_native_extension/stack_recorder.c
12
+ // ../../../../ext/ddtrace_profiling_native_extension/stack_recorder.c:23:1: error: initializer element is not constant
13
+ // static const ddog_ValueType enabled_value_types[] = {CPU_TIME_VALUE, CPU_SAMPLES_VALUE, WALL_TIME_VALUE};
14
+ // ^
15
+ // ```
16
+ #define VALUE_STRING(string) {.ptr = "" string, .len = sizeof(string) - 1}
17
+
18
+ #define CPU_TIME_VALUE {.type_ = VALUE_STRING("cpu-time"), .unit = VALUE_STRING("nanoseconds")}
19
+ #define CPU_SAMPLES_VALUE {.type_ = VALUE_STRING("cpu-samples"), .unit = VALUE_STRING("count")}
20
+ #define WALL_TIME_VALUE {.type_ = VALUE_STRING("wall-time"), .unit = VALUE_STRING("nanoseconds")}
21
+ #define ALLOC_SIZE_VALUE {.type_ = VALUE_STRING("alloc-size"), .unit = VALUE_STRING("bytes")}
22
+ #define ALLOC_SAMPLES_VALUE {.type_ = VALUE_STRING("alloc-samples"), .unit = VALUE_STRING("count")}
23
+ #define HEAP_LIVE_SIZE_VALUE {.type_ = VALUE_STRING("heap-live-size"), .unit = VALUE_STRING("bytes")}
24
+ #define HEAP_LIVE_SAMPLES_VALUE {.type_ = VALUE_STRING("heap-live-samples"), .unit = VALUE_STRING("count")}
25
+
26
+ static const ddog_ValueType enabled_value_types[] = {
27
+ #define CPU_TIME_VALUE_POS 0
28
+ CPU_TIME_VALUE,
29
+ #define CPU_SAMPLES_VALUE_POS 1
30
+ CPU_SAMPLES_VALUE,
31
+ #define WALL_TIME_VALUE_POS 2
32
+ WALL_TIME_VALUE
33
+ };
34
+
35
+ #define ENABLED_VALUE_TYPES_COUNT (sizeof(enabled_value_types) / sizeof(ddog_ValueType))
36
+
37
+ void record_sample(VALUE recorder_instance, ddog_Sample sample);
38
+ void record_endpoint(VALUE recorder_instance, ddog_CharSlice local_root_span_id, ddog_CharSlice endpoint);
39
+ VALUE enforce_recorder_instance(VALUE object);
@@ -0,0 +1,17 @@
1
+ #include <errno.h>
2
+ #include <time.h>
3
+
4
+ #include "ruby_helpers.h"
5
+ #include "time_helpers.h"
6
+
7
+ // Safety: This function is assumed never to raise exceptions by callers when raise_on_failure == false
8
+ long monotonic_wall_time_now_ns(bool raise_on_failure) {
9
+ struct timespec current_monotonic;
10
+
11
+ if (clock_gettime(CLOCK_MONOTONIC, &current_monotonic) != 0) {
12
+ if (raise_on_failure) ENFORCE_SUCCESS_GVL(errno);
13
+ return 0;
14
+ }
15
+
16
+ return current_monotonic.tv_nsec + SECONDS_AS_NS(current_monotonic.tv_sec);
17
+ }
@@ -0,0 +1,10 @@
1
+ #pragma once
2
+
3
+ #define SECONDS_AS_NS(value) (value * 1000 * 1000 * 1000L)
4
+ #define MILLIS_AS_NS(value) (value * 1000 * 1000L)
5
+
6
+ #define RAISE_ON_FAILURE true
7
+ #define DO_NOT_RAISE_ON_FAILURE false
8
+
9
+ // Safety: This function is assumed never to raise exceptions by callers when raise_on_failure == false
10
+ long monotonic_wall_time_now_ns(bool raise_on_failure);
@@ -0,0 +1,99 @@
1
+ <!-- Sorry, you’ve been blocked -->
2
+ <!DOCTYPE html>
3
+ <html lang="en">
4
+
5
+ <head>
6
+ <meta charset="UTF-8">
7
+ <meta name="viewport" content="width=device-width,initial-scale=1">
8
+ <title>You've been blocked</title>
9
+ <style>
10
+ a,
11
+ body,
12
+ div,
13
+ html,
14
+ span {
15
+ margin: 0;
16
+ padding: 0;
17
+ border: 0;
18
+ font-size: 100%;
19
+ font: inherit;
20
+ vertical-align: baseline
21
+ }
22
+
23
+ body {
24
+ background: -webkit-radial-gradient(26% 19%, circle, #fff, #f4f7f9);
25
+ background: radial-gradient(circle at 26% 19%, #fff, #f4f7f9);
26
+ display: -webkit-box;
27
+ display: -ms-flexbox;
28
+ display: flex;
29
+ -webkit-box-pack: center;
30
+ -ms-flex-pack: center;
31
+ justify-content: center;
32
+ -webkit-box-align: center;
33
+ -ms-flex-align: center;
34
+ align-items: center;
35
+ -ms-flex-line-pack: center;
36
+ align-content: center;
37
+ width: 100%;
38
+ min-height: 100vh;
39
+ line-height: 1;
40
+ flex-direction: column
41
+ }
42
+
43
+ p {
44
+ display: block
45
+ }
46
+
47
+
48
+ main {
49
+ text-align: center;
50
+ flex: 1;
51
+ display: -webkit-box;
52
+ display: -ms-flexbox;
53
+ display: flex;
54
+ -webkit-box-pack: center;
55
+ -ms-flex-pack: center;
56
+ justify-content: center;
57
+ -webkit-box-align: center;
58
+ -ms-flex-align: center;
59
+ align-items: center;
60
+ -ms-flex-line-pack: center;
61
+ align-content: center;
62
+ flex-direction: column
63
+ }
64
+
65
+ p {
66
+ font-size: 18px;
67
+ line-height: normal;
68
+ color: #646464;
69
+ font-family: sans-serif;
70
+ font-weight: 400
71
+ }
72
+
73
+ a {
74
+ color: #4842b7
75
+ }
76
+
77
+ footer {
78
+ width: 100%;
79
+ text-align: center
80
+ }
81
+
82
+ footer p {
83
+ font-size: 16px
84
+ }
85
+ </style>
86
+ </head>
87
+
88
+ <body>
89
+ <main>
90
+ <p>Sorry, you cannot access this page. Please contact the customer service team.</p>
91
+ </main>
92
+ <footer>
93
+ <p>Security provided by <a
94
+ href="https://www.datadoghq.com/product/security-platform/application-security-monitoring/"
95
+ target="_blank">Datadog</a></p>
96
+ </footer>
97
+ </body>
98
+
99
+ </html>
@@ -0,0 +1 @@
1
+ {"errors": [{"title": "You've been blocked", "detail": "Sorry, you cannot access this page. Please contact the customer service team. Security provided by Datadog."}]}
@@ -0,0 +1,5 @@
1
+ You've been blocked
2
+
3
+ Sorry, you cannot access this page. Please contact the customer service team.
4
+
5
+ Security provided by Datadog.
@@ -0,0 +1,7 @@
1
+ Vendored WAF rules originate from https://github.com/datadog/appsec-event-rules
2
+
3
+ One should check rule compatibility with libddwaf, which is the end consumer of
4
+ these rules.
5
+
6
+ There might be rules that look to be irrelevant to Ruby as they may still help
7
+ identify bad actors.