ddtrace 0.35.2 → 1.1.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 (1018) hide show
  1. checksums.yaml +4 -4
  2. data/.editorconfig +22 -0
  3. data/.gitignore +16 -17
  4. data/CHANGELOG.md +1969 -293
  5. data/CONTRIBUTING.md +3 -7
  6. data/LICENSE-3rdparty.csv +4 -0
  7. data/README.md +5 -0
  8. data/bin/ddtracerb +15 -0
  9. data/ddtrace.gemspec +34 -32
  10. data/docs/0.x-trace.png +0 -0
  11. data/docs/1.0-trace.png +0 -0
  12. data/docs/AutoInstrumentation.md +36 -0
  13. data/docs/Deprecation.md +8 -0
  14. data/docs/DevelopmentGuide.md +73 -9
  15. data/docs/GettingStarted.md +989 -496
  16. data/docs/ProfilingDevelopment.md +110 -0
  17. data/docs/PublicApi.md +14 -0
  18. data/docs/UpgradeGuide.md +736 -0
  19. data/ext/ddtrace_profiling_loader/ddtrace_profiling_loader.c +118 -0
  20. data/ext/ddtrace_profiling_loader/extconf.rb +53 -0
  21. data/ext/ddtrace_profiling_native_extension/NativeExtensionDesign.md +112 -0
  22. data/ext/ddtrace_profiling_native_extension/clock_id.h +4 -0
  23. data/ext/ddtrace_profiling_native_extension/clock_id_from_pthread.c +44 -0
  24. data/ext/ddtrace_profiling_native_extension/clock_id_noop.c +14 -0
  25. data/ext/ddtrace_profiling_native_extension/collectors_stack.c +278 -0
  26. data/ext/ddtrace_profiling_native_extension/extconf.rb +176 -0
  27. data/ext/ddtrace_profiling_native_extension/libddprof_helpers.h +13 -0
  28. data/ext/ddtrace_profiling_native_extension/native_extension_helpers.rb +186 -0
  29. data/ext/ddtrace_profiling_native_extension/private_vm_api_access.c +607 -0
  30. data/ext/ddtrace_profiling_native_extension/private_vm_api_access.h +33 -0
  31. data/ext/ddtrace_profiling_native_extension/profiling.c +31 -0
  32. data/ext/ddtrace_profiling_native_extension/stack_recorder.c +139 -0
  33. data/ext/ddtrace_profiling_native_extension/stack_recorder.h +28 -0
  34. data/lib/datadog/appsec/assets/blocked.html +4 -0
  35. data/lib/datadog/appsec/assets/waf_rules/README.md +7 -0
  36. data/lib/datadog/appsec/assets/waf_rules/recommended.json +5638 -0
  37. data/lib/datadog/appsec/assets/waf_rules/risky.json +1499 -0
  38. data/lib/datadog/appsec/assets/waf_rules/strict.json +1298 -0
  39. data/lib/datadog/appsec/assets.rb +38 -0
  40. data/lib/datadog/appsec/autoload.rb +16 -0
  41. data/lib/datadog/appsec/configuration/settings.rb +194 -0
  42. data/lib/datadog/appsec/configuration.rb +80 -0
  43. data/lib/datadog/appsec/contrib/auto_instrument.rb +29 -0
  44. data/lib/datadog/appsec/contrib/configuration/settings.rb +20 -0
  45. data/lib/datadog/appsec/contrib/integration.rb +37 -0
  46. data/lib/datadog/appsec/contrib/patcher.rb +12 -0
  47. data/lib/datadog/appsec/contrib/rack/configuration/settings.rb +22 -0
  48. data/lib/datadog/appsec/contrib/rack/ext.rb +15 -0
  49. data/lib/datadog/appsec/contrib/rack/gateway/watcher.rb +169 -0
  50. data/lib/datadog/appsec/contrib/rack/integration.rb +49 -0
  51. data/lib/datadog/appsec/contrib/rack/patcher.rb +32 -0
  52. data/lib/datadog/appsec/contrib/rack/reactive/request.rb +87 -0
  53. data/lib/datadog/appsec/contrib/rack/reactive/request_body.rb +64 -0
  54. data/lib/datadog/appsec/contrib/rack/reactive/response.rb +64 -0
  55. data/lib/datadog/appsec/contrib/rack/request.rb +58 -0
  56. data/lib/datadog/appsec/contrib/rack/request_body_middleware.rb +41 -0
  57. data/lib/datadog/appsec/contrib/rack/request_middleware.rb +112 -0
  58. data/lib/datadog/appsec/contrib/rack/response.rb +24 -0
  59. data/lib/datadog/appsec/contrib/rails/configuration/settings.rb +22 -0
  60. data/lib/datadog/appsec/contrib/rails/ext.rb +15 -0
  61. data/lib/datadog/appsec/contrib/rails/framework.rb +30 -0
  62. data/lib/datadog/appsec/contrib/rails/gateway/watcher.rb +81 -0
  63. data/lib/datadog/appsec/contrib/rails/integration.rb +48 -0
  64. data/lib/datadog/appsec/contrib/rails/patcher.rb +158 -0
  65. data/lib/datadog/appsec/contrib/rails/reactive/action.rb +68 -0
  66. data/lib/datadog/appsec/contrib/rails/request.rb +33 -0
  67. data/lib/datadog/appsec/contrib/rails/request_middleware.rb +20 -0
  68. data/lib/datadog/appsec/contrib/sinatra/configuration/settings.rb +22 -0
  69. data/lib/datadog/appsec/contrib/sinatra/ext.rb +15 -0
  70. data/lib/datadog/appsec/contrib/sinatra/framework.rb +34 -0
  71. data/lib/datadog/appsec/contrib/sinatra/gateway/watcher.rb +124 -0
  72. data/lib/datadog/appsec/contrib/sinatra/integration.rb +48 -0
  73. data/lib/datadog/appsec/contrib/sinatra/patcher.rb +144 -0
  74. data/lib/datadog/appsec/contrib/sinatra/reactive/routed.rb +63 -0
  75. data/lib/datadog/appsec/contrib/sinatra/request_middleware.rb +20 -0
  76. data/lib/datadog/appsec/event.rb +121 -0
  77. data/lib/datadog/appsec/extensions.rb +118 -0
  78. data/lib/datadog/appsec/instrumentation/gateway.rb +44 -0
  79. data/lib/datadog/appsec/processor.rb +164 -0
  80. data/lib/datadog/appsec/rate_limiter.rb +60 -0
  81. data/lib/datadog/appsec/reactive/address_hash.rb +18 -0
  82. data/lib/datadog/appsec/reactive/engine.rb +44 -0
  83. data/lib/datadog/appsec/reactive/operation.rb +51 -0
  84. data/lib/datadog/appsec/reactive/subscriber.rb +18 -0
  85. data/lib/datadog/appsec.rb +23 -0
  86. data/lib/datadog/ci/configuration/components.rb +32 -0
  87. data/lib/datadog/ci/configuration/settings.rb +53 -0
  88. data/lib/datadog/ci/contrib/cucumber/configuration/settings.rb +33 -0
  89. data/lib/datadog/ci/contrib/cucumber/ext.rb +22 -0
  90. data/lib/datadog/ci/contrib/cucumber/formatter.rb +94 -0
  91. data/lib/datadog/ci/contrib/cucumber/instrumentation.rb +28 -0
  92. data/lib/datadog/ci/contrib/cucumber/integration.rb +49 -0
  93. data/lib/datadog/ci/contrib/cucumber/patcher.rb +27 -0
  94. data/lib/datadog/ci/contrib/rspec/configuration/settings.rb +33 -0
  95. data/lib/datadog/ci/contrib/rspec/example.rb +70 -0
  96. data/lib/datadog/ci/contrib/rspec/ext.rb +21 -0
  97. data/lib/datadog/ci/contrib/rspec/integration.rb +50 -0
  98. data/lib/datadog/ci/contrib/rspec/patcher.rb +27 -0
  99. data/lib/datadog/ci/ext/app_types.rb +11 -0
  100. data/lib/datadog/ci/ext/environment.rb +503 -0
  101. data/lib/datadog/ci/ext/settings.rb +12 -0
  102. data/lib/datadog/ci/ext/test.rb +37 -0
  103. data/lib/datadog/ci/extensions.rb +19 -0
  104. data/lib/datadog/ci/flush.rb +38 -0
  105. data/lib/datadog/ci/test.rb +83 -0
  106. data/lib/datadog/ci.rb +20 -0
  107. data/lib/datadog/core/buffer/cruby.rb +55 -0
  108. data/lib/datadog/core/buffer/random.rb +134 -0
  109. data/lib/datadog/core/buffer/thread_safe.rb +58 -0
  110. data/lib/datadog/core/chunker.rb +35 -0
  111. data/lib/datadog/core/configuration/agent_settings_resolver.rb +365 -0
  112. data/lib/datadog/core/configuration/base.rb +89 -0
  113. data/lib/datadog/core/configuration/components.rb +411 -0
  114. data/lib/datadog/core/configuration/dependency_resolver.rb +28 -0
  115. data/lib/datadog/core/configuration/option.rb +69 -0
  116. data/lib/datadog/core/configuration/option_definition.rb +126 -0
  117. data/lib/datadog/core/configuration/option_definition_set.rb +22 -0
  118. data/lib/datadog/core/configuration/option_set.rb +10 -0
  119. data/lib/datadog/core/configuration/options.rb +118 -0
  120. data/lib/datadog/core/configuration/settings.rb +618 -0
  121. data/lib/datadog/core/configuration.rb +286 -0
  122. data/lib/datadog/core/diagnostics/environment_logger.rb +283 -0
  123. data/lib/datadog/core/diagnostics/ext.rb +41 -0
  124. data/lib/datadog/core/diagnostics/health.rb +37 -0
  125. data/lib/datadog/core/encoding.rb +76 -0
  126. data/lib/datadog/core/environment/cgroup.rb +55 -0
  127. data/lib/datadog/core/environment/class_count.rb +21 -0
  128. data/lib/datadog/core/environment/container.rb +93 -0
  129. data/lib/datadog/core/environment/ext.rb +46 -0
  130. data/lib/datadog/core/environment/gc.rb +20 -0
  131. data/lib/datadog/core/environment/identity.rb +58 -0
  132. data/lib/datadog/core/environment/socket.rb +24 -0
  133. data/lib/datadog/core/environment/thread_count.rb +20 -0
  134. data/lib/datadog/core/environment/variable_helpers.rb +68 -0
  135. data/lib/datadog/core/environment/vm_cache.rb +47 -0
  136. data/lib/datadog/core/error.rb +101 -0
  137. data/lib/datadog/core/extensions.rb +16 -0
  138. data/lib/datadog/core/git/ext.rb +35 -0
  139. data/lib/datadog/core/logger.rb +46 -0
  140. data/lib/datadog/core/logging/ext.rb +11 -0
  141. data/lib/datadog/core/metrics/client.rb +198 -0
  142. data/lib/datadog/core/metrics/ext.rb +20 -0
  143. data/lib/datadog/core/metrics/helpers.rb +25 -0
  144. data/lib/datadog/core/metrics/logging.rb +44 -0
  145. data/lib/datadog/core/metrics/metric.rb +14 -0
  146. data/lib/datadog/core/metrics/options.rb +50 -0
  147. data/lib/datadog/core/pin.rb +75 -0
  148. data/lib/datadog/core/runtime/ext.rb +28 -0
  149. data/lib/datadog/core/runtime/metrics.rb +126 -0
  150. data/lib/datadog/core/utils/compression.rb +32 -0
  151. data/lib/datadog/core/utils/forking.rb +63 -0
  152. data/lib/datadog/core/utils/object_set.rb +43 -0
  153. data/lib/datadog/core/utils/only_once.rb +44 -0
  154. data/lib/datadog/core/utils/safe_dup.rb +27 -0
  155. data/lib/datadog/core/utils/sequence.rb +21 -0
  156. data/lib/datadog/core/utils/string_table.rb +49 -0
  157. data/lib/datadog/core/utils/time.rb +54 -0
  158. data/lib/datadog/core/utils.rb +115 -0
  159. data/lib/datadog/core/vendor/multipart-post/LICENSE +11 -0
  160. data/lib/datadog/core/vendor/multipart-post/multipart/post/composite_read_io.rb +120 -0
  161. data/lib/datadog/core/vendor/multipart-post/multipart/post/multipartable.rb +61 -0
  162. data/lib/datadog/core/vendor/multipart-post/multipart/post/parts.rb +139 -0
  163. data/lib/datadog/core/vendor/multipart-post/multipart/post/version.rb +13 -0
  164. data/lib/datadog/core/vendor/multipart-post/multipart/post.rb +12 -0
  165. data/lib/datadog/core/vendor/multipart-post/multipart.rb +16 -0
  166. data/lib/datadog/core/vendor/multipart-post/net/http/post/multipart.rb +36 -0
  167. data/lib/datadog/core/worker.rb +24 -0
  168. data/lib/datadog/core/workers/async.rb +182 -0
  169. data/lib/datadog/core/workers/interval_loop.rb +119 -0
  170. data/lib/datadog/core/workers/polling.rb +59 -0
  171. data/lib/datadog/core/workers/queue.rb +44 -0
  172. data/lib/datadog/core/workers/runtime_metrics.rb +62 -0
  173. data/lib/datadog/core.rb +80 -0
  174. data/lib/datadog/kit/enable_core_dumps.rb +50 -0
  175. data/lib/datadog/kit/identity.rb +63 -0
  176. data/lib/datadog/kit.rb +11 -0
  177. data/lib/datadog/opentracer/binary_propagator.rb +26 -0
  178. data/lib/datadog/opentracer/carrier.rb +9 -0
  179. data/lib/datadog/opentracer/distributed_headers.rb +58 -0
  180. data/lib/datadog/opentracer/global_tracer.rb +17 -0
  181. data/lib/datadog/opentracer/propagator.rb +26 -0
  182. data/lib/datadog/opentracer/rack_propagator.rb +72 -0
  183. data/lib/datadog/opentracer/scope.rb +18 -0
  184. data/lib/datadog/opentracer/scope_manager.rb +9 -0
  185. data/lib/datadog/opentracer/span.rb +101 -0
  186. data/lib/datadog/opentracer/span_context.rb +19 -0
  187. data/lib/datadog/opentracer/span_context_factory.rb +27 -0
  188. data/lib/datadog/opentracer/text_map_propagator.rb +87 -0
  189. data/lib/datadog/opentracer/thread_local_scope.rb +34 -0
  190. data/lib/datadog/opentracer/thread_local_scope_manager.rb +43 -0
  191. data/lib/datadog/opentracer/tracer.rb +212 -0
  192. data/lib/datadog/opentracer.rb +24 -0
  193. data/lib/datadog/profiling/backtrace_location.rb +34 -0
  194. data/lib/datadog/profiling/buffer.rb +43 -0
  195. data/lib/datadog/profiling/collectors/code_provenance.rb +114 -0
  196. data/lib/datadog/profiling/collectors/old_stack.rb +298 -0
  197. data/lib/datadog/profiling/collectors/stack.rb +16 -0
  198. data/lib/datadog/profiling/encoding/profile.rb +47 -0
  199. data/lib/datadog/profiling/event.rb +15 -0
  200. data/lib/datadog/profiling/events/stack.rb +82 -0
  201. data/lib/datadog/profiling/exporter.rb +25 -0
  202. data/lib/datadog/profiling/ext/forking.rb +99 -0
  203. data/lib/datadog/profiling/ext.rb +57 -0
  204. data/lib/datadog/profiling/flush.rb +69 -0
  205. data/lib/datadog/profiling/load_native_extension.rb +22 -0
  206. data/lib/datadog/profiling/native_extension.rb +41 -0
  207. data/lib/datadog/profiling/pprof/builder.rb +127 -0
  208. data/lib/datadog/profiling/pprof/converter.rb +104 -0
  209. data/lib/datadog/profiling/pprof/message_set.rb +16 -0
  210. data/lib/datadog/profiling/pprof/payload.rb +20 -0
  211. data/lib/datadog/profiling/pprof/pprof.proto +212 -0
  212. data/lib/datadog/profiling/pprof/pprof_pb.rb +83 -0
  213. data/lib/datadog/profiling/pprof/stack_sample.rb +141 -0
  214. data/lib/datadog/profiling/pprof/string_table.rb +12 -0
  215. data/lib/datadog/profiling/pprof/template.rb +120 -0
  216. data/lib/datadog/profiling/preload.rb +5 -0
  217. data/lib/datadog/profiling/profiler.rb +34 -0
  218. data/lib/datadog/profiling/recorder.rb +117 -0
  219. data/lib/datadog/profiling/scheduler.rb +151 -0
  220. data/lib/datadog/profiling/stack_recorder.rb +33 -0
  221. data/lib/datadog/profiling/tag_builder.rb +48 -0
  222. data/lib/datadog/profiling/tasks/exec.rb +50 -0
  223. data/lib/datadog/profiling/tasks/help.rb +18 -0
  224. data/lib/datadog/profiling/tasks/setup.rb +93 -0
  225. data/lib/datadog/profiling/trace_identifiers/ddtrace.rb +45 -0
  226. data/lib/datadog/profiling/trace_identifiers/helper.rb +47 -0
  227. data/lib/datadog/profiling/transport/client.rb +16 -0
  228. data/lib/datadog/profiling/transport/http/api/endpoint.rb +107 -0
  229. data/lib/datadog/profiling/transport/http/api/instance.rb +38 -0
  230. data/lib/datadog/profiling/transport/http/api/spec.rb +42 -0
  231. data/lib/datadog/profiling/transport/http/api.rb +45 -0
  232. data/lib/datadog/profiling/transport/http/builder.rb +30 -0
  233. data/lib/datadog/profiling/transport/http/client.rb +35 -0
  234. data/lib/datadog/profiling/transport/http/response.rb +23 -0
  235. data/lib/datadog/profiling/transport/http.rb +112 -0
  236. data/lib/datadog/profiling/transport/io/client.rb +29 -0
  237. data/lib/datadog/profiling/transport/io/response.rb +18 -0
  238. data/lib/datadog/profiling/transport/io.rb +32 -0
  239. data/lib/datadog/profiling/transport/parcel.rb +19 -0
  240. data/lib/datadog/profiling/transport/request.rb +17 -0
  241. data/lib/datadog/profiling/transport/response.rb +10 -0
  242. data/lib/datadog/profiling.rb +170 -0
  243. data/lib/datadog/tracing/analytics.rb +25 -0
  244. data/lib/datadog/tracing/buffer.rb +132 -0
  245. data/lib/datadog/tracing/configuration/ext.rb +51 -0
  246. data/lib/datadog/tracing/context.rb +68 -0
  247. data/lib/datadog/tracing/context_provider.rb +66 -0
  248. data/lib/datadog/tracing/contrib/action_cable/configuration/settings.rb +35 -0
  249. data/lib/datadog/tracing/contrib/action_cable/event.rb +72 -0
  250. data/lib/datadog/tracing/contrib/action_cable/events/broadcast.rb +58 -0
  251. data/lib/datadog/tracing/contrib/action_cable/events/perform_action.rb +63 -0
  252. data/lib/datadog/tracing/contrib/action_cable/events/transmit.rb +59 -0
  253. data/lib/datadog/tracing/contrib/action_cable/events.rb +37 -0
  254. data/lib/datadog/tracing/contrib/action_cable/ext.rb +32 -0
  255. data/lib/datadog/tracing/contrib/action_cable/instrumentation.rb +91 -0
  256. data/lib/datadog/tracing/contrib/action_cable/integration.rb +50 -0
  257. data/lib/datadog/tracing/contrib/action_cable/patcher.rb +31 -0
  258. data/lib/datadog/tracing/contrib/action_mailer/configuration/settings.rb +36 -0
  259. data/lib/datadog/tracing/contrib/action_mailer/event.rb +52 -0
  260. data/lib/datadog/tracing/contrib/action_mailer/events/deliver.rb +60 -0
  261. data/lib/datadog/tracing/contrib/action_mailer/events/process.rb +47 -0
  262. data/lib/datadog/tracing/contrib/action_mailer/events.rb +34 -0
  263. data/lib/datadog/tracing/contrib/action_mailer/ext.rb +33 -0
  264. data/lib/datadog/tracing/contrib/action_mailer/integration.rb +50 -0
  265. data/lib/datadog/tracing/contrib/action_mailer/patcher.rb +29 -0
  266. data/lib/datadog/tracing/contrib/action_pack/action_controller/instrumentation.rb +156 -0
  267. data/lib/datadog/tracing/contrib/action_pack/action_controller/patcher.rb +29 -0
  268. data/lib/datadog/tracing/contrib/action_pack/configuration/settings.rb +36 -0
  269. data/lib/datadog/tracing/contrib/action_pack/ext.rb +22 -0
  270. data/lib/datadog/tracing/contrib/action_pack/integration.rb +50 -0
  271. data/lib/datadog/tracing/contrib/action_pack/patcher.rb +27 -0
  272. data/lib/datadog/tracing/contrib/action_pack/utils.rb +40 -0
  273. data/lib/datadog/tracing/contrib/action_view/configuration/settings.rb +36 -0
  274. data/lib/datadog/tracing/contrib/action_view/event.rb +35 -0
  275. data/lib/datadog/tracing/contrib/action_view/events/render_partial.rb +54 -0
  276. data/lib/datadog/tracing/contrib/action_view/events/render_template.rb +57 -0
  277. data/lib/datadog/tracing/contrib/action_view/events.rb +34 -0
  278. data/lib/datadog/tracing/contrib/action_view/ext.rb +24 -0
  279. data/lib/datadog/tracing/contrib/action_view/instrumentation/partial_renderer.rb +78 -0
  280. data/lib/datadog/tracing/contrib/action_view/instrumentation/template_renderer.rb +91 -0
  281. data/lib/datadog/tracing/contrib/action_view/integration.rb +57 -0
  282. data/lib/datadog/tracing/contrib/action_view/patcher.rb +47 -0
  283. data/lib/datadog/tracing/contrib/action_view/utils.rb +36 -0
  284. data/lib/datadog/tracing/contrib/active_job/configuration/settings.rb +37 -0
  285. data/lib/datadog/tracing/contrib/active_job/event.rb +58 -0
  286. data/lib/datadog/tracing/contrib/active_job/events/discard.rb +50 -0
  287. data/lib/datadog/tracing/contrib/active_job/events/enqueue.rb +49 -0
  288. data/lib/datadog/tracing/contrib/active_job/events/enqueue_at.rb +49 -0
  289. data/lib/datadog/tracing/contrib/active_job/events/enqueue_retry.rb +51 -0
  290. data/lib/datadog/tracing/contrib/active_job/events/perform.rb +49 -0
  291. data/lib/datadog/tracing/contrib/active_job/events/retry_stopped.rb +50 -0
  292. data/lib/datadog/tracing/contrib/active_job/events.rb +42 -0
  293. data/lib/datadog/tracing/contrib/active_job/ext.rb +39 -0
  294. data/lib/datadog/tracing/contrib/active_job/integration.rb +50 -0
  295. data/lib/datadog/tracing/contrib/active_job/log_injection.rb +26 -0
  296. data/lib/datadog/tracing/contrib/active_job/patcher.rb +36 -0
  297. data/lib/datadog/tracing/contrib/active_model_serializers/configuration/settings.rb +33 -0
  298. data/lib/datadog/tracing/contrib/active_model_serializers/event.rb +69 -0
  299. data/lib/datadog/tracing/contrib/active_model_serializers/events/render.rb +45 -0
  300. data/lib/datadog/tracing/contrib/active_model_serializers/events/serialize.rb +47 -0
  301. data/lib/datadog/tracing/contrib/active_model_serializers/events.rb +34 -0
  302. data/lib/datadog/tracing/contrib/active_model_serializers/ext.rb +24 -0
  303. data/lib/datadog/tracing/contrib/active_model_serializers/integration.rb +45 -0
  304. data/lib/datadog/tracing/contrib/active_model_serializers/patcher.rb +33 -0
  305. data/lib/datadog/tracing/contrib/active_record/configuration/makara_resolver.rb +36 -0
  306. data/lib/datadog/tracing/contrib/active_record/configuration/resolver.rb +138 -0
  307. data/lib/datadog/tracing/contrib/active_record/configuration/settings.rb +39 -0
  308. data/lib/datadog/tracing/contrib/active_record/event.rb +30 -0
  309. data/lib/datadog/tracing/contrib/active_record/events/instantiation.rb +58 -0
  310. data/lib/datadog/tracing/contrib/active_record/events/sql.rb +78 -0
  311. data/lib/datadog/tracing/contrib/active_record/events.rb +34 -0
  312. data/lib/datadog/tracing/contrib/active_record/ext.rb +29 -0
  313. data/lib/datadog/tracing/contrib/active_record/integration.rb +56 -0
  314. data/lib/datadog/tracing/contrib/active_record/patcher.rb +27 -0
  315. data/lib/datadog/tracing/contrib/active_record/utils.rb +128 -0
  316. data/lib/datadog/tracing/contrib/active_record/vendor/MIT-LICENSE +20 -0
  317. data/lib/datadog/tracing/contrib/active_record/vendor/connection_specification.rb +307 -0
  318. data/lib/datadog/tracing/contrib/active_support/cache/instrumentation.rb +270 -0
  319. data/lib/datadog/tracing/contrib/active_support/cache/patcher.rb +73 -0
  320. data/lib/datadog/tracing/contrib/active_support/cache/redis.rb +47 -0
  321. data/lib/datadog/tracing/contrib/active_support/configuration/settings.rb +35 -0
  322. data/lib/datadog/tracing/contrib/active_support/ext.rb +31 -0
  323. data/lib/datadog/tracing/contrib/active_support/integration.rb +51 -0
  324. data/lib/datadog/tracing/contrib/active_support/notifications/event.rb +71 -0
  325. data/lib/datadog/tracing/contrib/active_support/notifications/subscriber.rb +71 -0
  326. data/lib/datadog/tracing/contrib/active_support/notifications/subscription.rb +164 -0
  327. data/lib/datadog/tracing/contrib/active_support/patcher.rb +27 -0
  328. data/lib/datadog/tracing/contrib/analytics.rb +29 -0
  329. data/lib/datadog/tracing/contrib/auto_instrument.rb +53 -0
  330. data/lib/datadog/tracing/contrib/aws/configuration/settings.rb +35 -0
  331. data/lib/datadog/tracing/contrib/aws/ext.rb +27 -0
  332. data/lib/datadog/tracing/contrib/aws/instrumentation.rb +95 -0
  333. data/lib/datadog/tracing/contrib/aws/integration.rb +47 -0
  334. data/lib/datadog/tracing/contrib/aws/parsed_context.rb +60 -0
  335. data/lib/datadog/tracing/contrib/aws/patcher.rb +57 -0
  336. data/lib/datadog/tracing/contrib/aws/services.rb +123 -0
  337. data/lib/datadog/tracing/contrib/concurrent_ruby/configuration/settings.rb +23 -0
  338. data/lib/datadog/tracing/contrib/concurrent_ruby/context_composite_executor_service.rb +53 -0
  339. data/lib/datadog/tracing/contrib/concurrent_ruby/ext.rb +16 -0
  340. data/lib/datadog/tracing/contrib/concurrent_ruby/future_patch.rb +27 -0
  341. data/lib/datadog/tracing/contrib/concurrent_ruby/integration.rb +43 -0
  342. data/lib/datadog/tracing/contrib/concurrent_ruby/patcher.rb +33 -0
  343. data/lib/datadog/tracing/contrib/configurable.rb +102 -0
  344. data/lib/datadog/tracing/contrib/configuration/resolver.rb +85 -0
  345. data/lib/datadog/tracing/contrib/configuration/resolvers/pattern_resolver.rb +43 -0
  346. data/lib/datadog/tracing/contrib/configuration/settings.rb +43 -0
  347. data/lib/datadog/tracing/contrib/dalli/configuration/settings.rb +35 -0
  348. data/lib/datadog/tracing/contrib/dalli/ext.rb +24 -0
  349. data/lib/datadog/tracing/contrib/dalli/instrumentation.rb +58 -0
  350. data/lib/datadog/tracing/contrib/dalli/integration.rb +52 -0
  351. data/lib/datadog/tracing/contrib/dalli/patcher.rb +28 -0
  352. data/lib/datadog/tracing/contrib/dalli/quantize.rb +26 -0
  353. data/lib/datadog/tracing/contrib/delayed_job/configuration/settings.rb +38 -0
  354. data/lib/datadog/tracing/contrib/delayed_job/ext.rb +26 -0
  355. data/lib/datadog/tracing/contrib/delayed_job/integration.rb +43 -0
  356. data/lib/datadog/tracing/contrib/delayed_job/patcher.rb +31 -0
  357. data/lib/datadog/tracing/contrib/delayed_job/plugin.rb +101 -0
  358. data/lib/datadog/tracing/contrib/elasticsearch/configuration/settings.rb +36 -0
  359. data/lib/datadog/tracing/contrib/elasticsearch/ext.rb +26 -0
  360. data/lib/datadog/tracing/contrib/elasticsearch/integration.rb +50 -0
  361. data/lib/datadog/tracing/contrib/elasticsearch/patcher.rb +151 -0
  362. data/lib/datadog/tracing/contrib/elasticsearch/quantize.rb +89 -0
  363. data/lib/datadog/tracing/contrib/ethon/configuration/settings.rb +37 -0
  364. data/lib/datadog/tracing/contrib/ethon/easy_patch.rb +177 -0
  365. data/lib/datadog/tracing/contrib/ethon/ext.rb +24 -0
  366. data/lib/datadog/tracing/contrib/ethon/integration.rb +48 -0
  367. data/lib/datadog/tracing/contrib/ethon/multi_patch.rb +96 -0
  368. data/lib/datadog/tracing/contrib/ethon/patcher.rb +31 -0
  369. data/lib/datadog/tracing/contrib/excon/configuration/settings.rb +38 -0
  370. data/lib/datadog/tracing/contrib/excon/ext.rb +21 -0
  371. data/lib/datadog/tracing/contrib/excon/integration.rb +48 -0
  372. data/lib/datadog/tracing/contrib/excon/middleware.rb +170 -0
  373. data/lib/datadog/tracing/contrib/excon/patcher.rb +31 -0
  374. data/lib/datadog/tracing/contrib/extensions.rb +197 -0
  375. data/lib/datadog/tracing/contrib/faraday/configuration/settings.rb +42 -0
  376. data/lib/datadog/tracing/contrib/faraday/connection.rb +22 -0
  377. data/lib/datadog/tracing/contrib/faraday/ext.rb +21 -0
  378. data/lib/datadog/tracing/contrib/faraday/integration.rb +48 -0
  379. data/lib/datadog/tracing/contrib/faraday/middleware.rb +93 -0
  380. data/lib/datadog/tracing/contrib/faraday/patcher.rb +56 -0
  381. data/lib/datadog/tracing/contrib/faraday/rack_builder.rb +22 -0
  382. data/lib/datadog/tracing/contrib/grape/configuration/settings.rb +42 -0
  383. data/lib/datadog/tracing/contrib/grape/endpoint.rb +253 -0
  384. data/lib/datadog/tracing/contrib/grape/ext.rb +28 -0
  385. data/lib/datadog/tracing/contrib/grape/instrumentation.rb +37 -0
  386. data/lib/datadog/tracing/contrib/grape/integration.rb +44 -0
  387. data/lib/datadog/tracing/contrib/grape/patcher.rb +33 -0
  388. data/lib/datadog/tracing/contrib/graphql/configuration/settings.rb +36 -0
  389. data/lib/datadog/tracing/contrib/graphql/ext.rb +19 -0
  390. data/lib/datadog/tracing/contrib/graphql/integration.rb +44 -0
  391. data/lib/datadog/tracing/contrib/graphql/patcher.rb +91 -0
  392. data/lib/datadog/tracing/contrib/grpc/configuration/settings.rb +37 -0
  393. data/lib/datadog/tracing/contrib/grpc/datadog_interceptor/client.rb +84 -0
  394. data/lib/datadog/tracing/contrib/grpc/datadog_interceptor/server.rb +90 -0
  395. data/lib/datadog/tracing/contrib/grpc/datadog_interceptor.rb +104 -0
  396. data/lib/datadog/tracing/contrib/grpc/ext.rb +23 -0
  397. data/lib/datadog/tracing/contrib/grpc/integration.rb +43 -0
  398. data/lib/datadog/tracing/contrib/grpc/intercept_with_datadog.rb +53 -0
  399. data/lib/datadog/tracing/contrib/grpc/patcher.rb +37 -0
  400. data/lib/datadog/tracing/contrib/http/circuit_breaker.rb +44 -0
  401. data/lib/datadog/tracing/contrib/http/configuration/settings.rb +37 -0
  402. data/lib/datadog/tracing/contrib/http/ext.rb +21 -0
  403. data/lib/datadog/tracing/contrib/http/instrumentation.rb +139 -0
  404. data/lib/datadog/tracing/contrib/http/integration.rb +49 -0
  405. data/lib/datadog/tracing/contrib/http/patcher.rb +30 -0
  406. data/lib/datadog/tracing/contrib/http_annotation_helper.rb +17 -0
  407. data/lib/datadog/tracing/contrib/httpclient/configuration/settings.rb +37 -0
  408. data/lib/datadog/tracing/contrib/httpclient/ext.rb +21 -0
  409. data/lib/datadog/tracing/contrib/httpclient/instrumentation.rb +117 -0
  410. data/lib/datadog/tracing/contrib/httpclient/integration.rb +48 -0
  411. data/lib/datadog/tracing/contrib/httpclient/patcher.rb +42 -0
  412. data/lib/datadog/tracing/contrib/httprb/configuration/settings.rb +37 -0
  413. data/lib/datadog/tracing/contrib/httprb/ext.rb +21 -0
  414. data/lib/datadog/tracing/contrib/httprb/instrumentation.rb +128 -0
  415. data/lib/datadog/tracing/contrib/httprb/integration.rb +48 -0
  416. data/lib/datadog/tracing/contrib/httprb/patcher.rb +42 -0
  417. data/lib/datadog/tracing/contrib/integration.rb +78 -0
  418. data/lib/datadog/tracing/contrib/kafka/configuration/settings.rb +35 -0
  419. data/lib/datadog/tracing/contrib/kafka/consumer_event.rb +18 -0
  420. data/lib/datadog/tracing/contrib/kafka/consumer_group_event.rb +18 -0
  421. data/lib/datadog/tracing/contrib/kafka/event.rb +52 -0
  422. data/lib/datadog/tracing/contrib/kafka/events/connection/request.rb +42 -0
  423. data/lib/datadog/tracing/contrib/kafka/events/consumer/process_batch.rb +49 -0
  424. data/lib/datadog/tracing/contrib/kafka/events/consumer/process_message.rb +47 -0
  425. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/heartbeat.rb +47 -0
  426. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/join_group.rb +37 -0
  427. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/leave_group.rb +37 -0
  428. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/sync_group.rb +37 -0
  429. data/lib/datadog/tracing/contrib/kafka/events/produce_operation/send_messages.rb +40 -0
  430. data/lib/datadog/tracing/contrib/kafka/events/producer/deliver_messages.rb +43 -0
  431. data/lib/datadog/tracing/contrib/kafka/events.rb +48 -0
  432. data/lib/datadog/tracing/contrib/kafka/ext.rb +52 -0
  433. data/lib/datadog/tracing/contrib/kafka/integration.rb +44 -0
  434. data/lib/datadog/tracing/contrib/kafka/patcher.rb +29 -0
  435. data/lib/datadog/tracing/contrib/lograge/configuration/settings.rb +23 -0
  436. data/lib/datadog/tracing/contrib/lograge/ext.rb +15 -0
  437. data/lib/datadog/tracing/contrib/lograge/instrumentation.rb +47 -0
  438. data/lib/datadog/tracing/contrib/lograge/integration.rb +50 -0
  439. data/lib/datadog/tracing/contrib/lograge/patcher.rb +29 -0
  440. data/lib/datadog/tracing/contrib/mongodb/configuration/settings.rb +38 -0
  441. data/lib/datadog/tracing/contrib/mongodb/ext.rb +27 -0
  442. data/lib/datadog/tracing/contrib/mongodb/instrumentation.rb +47 -0
  443. data/lib/datadog/tracing/contrib/mongodb/integration.rb +48 -0
  444. data/lib/datadog/tracing/contrib/mongodb/parsers.rb +49 -0
  445. data/lib/datadog/tracing/contrib/mongodb/patcher.rb +34 -0
  446. data/lib/datadog/tracing/contrib/mongodb/subscribers.rb +121 -0
  447. data/lib/datadog/tracing/contrib/mysql2/configuration/settings.rb +35 -0
  448. data/lib/datadog/tracing/contrib/mysql2/ext.rb +22 -0
  449. data/lib/datadog/tracing/contrib/mysql2/instrumentation.rb +62 -0
  450. data/lib/datadog/tracing/contrib/mysql2/integration.rb +43 -0
  451. data/lib/datadog/tracing/contrib/mysql2/patcher.rb +31 -0
  452. data/lib/datadog/tracing/contrib/patchable.rb +109 -0
  453. data/lib/datadog/tracing/contrib/patcher.rb +74 -0
  454. data/lib/datadog/tracing/contrib/presto/configuration/settings.rb +35 -0
  455. data/lib/datadog/tracing/contrib/presto/ext.rb +32 -0
  456. data/lib/datadog/tracing/contrib/presto/instrumentation.rb +125 -0
  457. data/lib/datadog/tracing/contrib/presto/integration.rb +43 -0
  458. data/lib/datadog/tracing/contrib/presto/patcher.rb +37 -0
  459. data/lib/datadog/tracing/contrib/qless/configuration/settings.rb +40 -0
  460. data/lib/datadog/tracing/contrib/qless/ext.rb +26 -0
  461. data/lib/datadog/tracing/contrib/qless/integration.rb +43 -0
  462. data/lib/datadog/tracing/contrib/qless/patcher.rb +38 -0
  463. data/lib/datadog/tracing/contrib/qless/qless_job.rb +75 -0
  464. data/lib/datadog/tracing/contrib/qless/tracer_cleaner.rb +32 -0
  465. data/lib/datadog/tracing/contrib/que/configuration/settings.rb +49 -0
  466. data/lib/datadog/tracing/contrib/que/ext.rb +34 -0
  467. data/lib/datadog/tracing/contrib/que/integration.rb +46 -0
  468. data/lib/datadog/tracing/contrib/que/patcher.rb +28 -0
  469. data/lib/datadog/tracing/contrib/que/tracer.rb +61 -0
  470. data/lib/datadog/tracing/contrib/racecar/configuration/settings.rb +35 -0
  471. data/lib/datadog/tracing/contrib/racecar/event.rb +79 -0
  472. data/lib/datadog/tracing/contrib/racecar/events/batch.rb +35 -0
  473. data/lib/datadog/tracing/contrib/racecar/events/consume.rb +35 -0
  474. data/lib/datadog/tracing/contrib/racecar/events/message.rb +35 -0
  475. data/lib/datadog/tracing/contrib/racecar/events.rb +36 -0
  476. data/lib/datadog/tracing/contrib/racecar/ext.rb +31 -0
  477. data/lib/datadog/tracing/contrib/racecar/integration.rb +44 -0
  478. data/lib/datadog/tracing/contrib/racecar/patcher.rb +29 -0
  479. data/lib/datadog/tracing/contrib/rack/configuration/settings.rb +51 -0
  480. data/lib/datadog/tracing/contrib/rack/ext.rb +25 -0
  481. data/lib/datadog/tracing/contrib/rack/integration.rb +50 -0
  482. data/lib/datadog/tracing/contrib/rack/middlewares.rb +255 -0
  483. data/lib/datadog/tracing/contrib/rack/patcher.rb +109 -0
  484. data/lib/datadog/tracing/contrib/rack/request_queue.rb +48 -0
  485. data/lib/datadog/tracing/contrib/rails/auto_instrument_railtie.rb +12 -0
  486. data/lib/datadog/tracing/contrib/rails/configuration/settings.rb +71 -0
  487. data/lib/datadog/tracing/contrib/rails/ext.rb +19 -0
  488. data/lib/datadog/tracing/contrib/rails/framework.rb +152 -0
  489. data/lib/datadog/tracing/contrib/rails/integration.rb +49 -0
  490. data/lib/datadog/tracing/contrib/rails/log_injection.rb +34 -0
  491. data/lib/datadog/tracing/contrib/rails/middlewares.rb +47 -0
  492. data/lib/datadog/tracing/contrib/rails/patcher.rb +121 -0
  493. data/lib/datadog/tracing/contrib/rails/railtie.rb +19 -0
  494. data/lib/datadog/tracing/contrib/rails/utils.rb +28 -0
  495. data/lib/datadog/tracing/contrib/rake/configuration/settings.rb +36 -0
  496. data/lib/datadog/tracing/contrib/rake/ext.rb +26 -0
  497. data/lib/datadog/tracing/contrib/rake/instrumentation.rb +98 -0
  498. data/lib/datadog/tracing/contrib/rake/integration.rb +43 -0
  499. data/lib/datadog/tracing/contrib/rake/patcher.rb +34 -0
  500. data/lib/datadog/tracing/contrib/redis/configuration/resolver.rb +49 -0
  501. data/lib/datadog/tracing/contrib/redis/configuration/settings.rb +40 -0
  502. data/lib/datadog/tracing/contrib/redis/ext.rb +26 -0
  503. data/lib/datadog/tracing/contrib/redis/instrumentation.rb +78 -0
  504. data/lib/datadog/tracing/contrib/redis/integration.rb +47 -0
  505. data/lib/datadog/tracing/contrib/redis/patcher.rb +35 -0
  506. data/lib/datadog/tracing/contrib/redis/quantize.rb +79 -0
  507. data/lib/datadog/tracing/contrib/redis/tags.rb +54 -0
  508. data/lib/datadog/tracing/contrib/redis/vendor/LICENSE +20 -0
  509. data/lib/datadog/tracing/contrib/redis/vendor/resolver.rb +162 -0
  510. data/lib/datadog/tracing/contrib/registerable.rb +50 -0
  511. data/lib/datadog/tracing/contrib/registry.rb +52 -0
  512. data/lib/datadog/tracing/contrib/resque/configuration/settings.rb +37 -0
  513. data/lib/datadog/tracing/contrib/resque/ext.rb +21 -0
  514. data/lib/datadog/tracing/contrib/resque/integration.rb +48 -0
  515. data/lib/datadog/tracing/contrib/resque/patcher.rb +29 -0
  516. data/lib/datadog/tracing/contrib/resque/resque_job.rb +103 -0
  517. data/lib/datadog/tracing/contrib/rest_client/configuration/settings.rb +36 -0
  518. data/lib/datadog/tracing/contrib/rest_client/ext.rb +21 -0
  519. data/lib/datadog/tracing/contrib/rest_client/integration.rb +43 -0
  520. data/lib/datadog/tracing/contrib/rest_client/patcher.rb +29 -0
  521. data/lib/datadog/tracing/contrib/rest_client/request_patch.rb +105 -0
  522. data/lib/datadog/tracing/contrib/semantic_logger/configuration/settings.rb +23 -0
  523. data/lib/datadog/tracing/contrib/semantic_logger/ext.rb +15 -0
  524. data/lib/datadog/tracing/contrib/semantic_logger/instrumentation.rb +51 -0
  525. data/lib/datadog/tracing/contrib/semantic_logger/integration.rb +52 -0
  526. data/lib/datadog/tracing/contrib/semantic_logger/patcher.rb +29 -0
  527. data/lib/datadog/tracing/contrib/sequel/configuration/settings.rb +33 -0
  528. data/lib/datadog/tracing/contrib/sequel/database.rb +60 -0
  529. data/lib/datadog/tracing/contrib/sequel/dataset.rb +65 -0
  530. data/lib/datadog/tracing/contrib/sequel/ext.rb +22 -0
  531. data/lib/datadog/tracing/contrib/sequel/integration.rb +43 -0
  532. data/lib/datadog/tracing/contrib/sequel/patcher.rb +37 -0
  533. data/lib/datadog/tracing/contrib/sequel/utils.rb +87 -0
  534. data/lib/datadog/tracing/contrib/shoryuken/configuration/settings.rb +38 -0
  535. data/lib/datadog/tracing/contrib/shoryuken/ext.rb +25 -0
  536. data/lib/datadog/tracing/contrib/shoryuken/integration.rb +44 -0
  537. data/lib/datadog/tracing/contrib/shoryuken/patcher.rb +28 -0
  538. data/lib/datadog/tracing/contrib/shoryuken/tracer.rb +61 -0
  539. data/lib/datadog/tracing/contrib/sidekiq/client_tracer.rb +53 -0
  540. data/lib/datadog/tracing/contrib/sidekiq/configuration/settings.rb +44 -0
  541. data/lib/datadog/tracing/contrib/sidekiq/ext.rb +38 -0
  542. data/lib/datadog/tracing/contrib/sidekiq/integration.rb +53 -0
  543. data/lib/datadog/tracing/contrib/sidekiq/patcher.rb +71 -0
  544. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/heartbeat.rb +34 -0
  545. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/job_fetch.rb +34 -0
  546. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/scheduled_push.rb +33 -0
  547. data/lib/datadog/tracing/contrib/sidekiq/server_tracer.rb +98 -0
  548. data/lib/datadog/tracing/contrib/sidekiq/tracing.rb +44 -0
  549. data/lib/datadog/tracing/contrib/sinatra/configuration/settings.rb +43 -0
  550. data/lib/datadog/tracing/contrib/sinatra/env.rb +66 -0
  551. data/lib/datadog/tracing/contrib/sinatra/ext.rb +32 -0
  552. data/lib/datadog/tracing/contrib/sinatra/framework.rb +118 -0
  553. data/lib/datadog/tracing/contrib/sinatra/headers.rb +35 -0
  554. data/lib/datadog/tracing/contrib/sinatra/integration.rb +43 -0
  555. data/lib/datadog/tracing/contrib/sinatra/patcher.rb +76 -0
  556. data/lib/datadog/tracing/contrib/sinatra/tracer.rb +159 -0
  557. data/lib/datadog/tracing/contrib/sinatra/tracer_middleware.rb +123 -0
  558. data/lib/datadog/tracing/contrib/sneakers/configuration/settings.rb +38 -0
  559. data/lib/datadog/tracing/contrib/sneakers/ext.rb +26 -0
  560. data/lib/datadog/tracing/contrib/sneakers/integration.rb +46 -0
  561. data/lib/datadog/tracing/contrib/sneakers/patcher.rb +29 -0
  562. data/lib/datadog/tracing/contrib/sneakers/tracer.rb +58 -0
  563. data/lib/datadog/tracing/contrib/status_code_matcher.rb +75 -0
  564. data/lib/datadog/tracing/contrib/sucker_punch/configuration/settings.rb +35 -0
  565. data/lib/datadog/tracing/contrib/sucker_punch/exception_handler.rb +28 -0
  566. data/lib/datadog/tracing/contrib/sucker_punch/ext.rb +27 -0
  567. data/lib/datadog/tracing/contrib/sucker_punch/instrumentation.rb +105 -0
  568. data/lib/datadog/tracing/contrib/sucker_punch/integration.rb +43 -0
  569. data/lib/datadog/tracing/contrib/sucker_punch/patcher.rb +37 -0
  570. data/lib/datadog/tracing/contrib/utils/database.rb +31 -0
  571. data/lib/datadog/tracing/contrib/utils/quantization/hash.rb +111 -0
  572. data/lib/datadog/tracing/contrib/utils/quantization/http.rb +99 -0
  573. data/lib/datadog/tracing/contrib.rb +76 -0
  574. data/lib/datadog/tracing/correlation.rb +100 -0
  575. data/lib/datadog/tracing/distributed/headers/b3.rb +55 -0
  576. data/lib/datadog/tracing/distributed/headers/b3_single.rb +67 -0
  577. data/lib/datadog/tracing/distributed/headers/datadog.rb +52 -0
  578. data/lib/datadog/tracing/distributed/headers/ext.rb +31 -0
  579. data/lib/datadog/tracing/distributed/helpers.rb +44 -0
  580. data/lib/datadog/tracing/distributed/parser.rb +70 -0
  581. data/lib/datadog/tracing/event.rb +78 -0
  582. data/lib/datadog/tracing/flush.rb +74 -0
  583. data/lib/datadog/tracing/metadata/analytics.rb +26 -0
  584. data/lib/datadog/tracing/metadata/errors.rb +24 -0
  585. data/lib/datadog/tracing/metadata/ext.rb +151 -0
  586. data/lib/datadog/tracing/metadata/tagging.rb +110 -0
  587. data/lib/datadog/tracing/metadata.rb +20 -0
  588. data/lib/datadog/tracing/pipeline/span_filter.rb +42 -0
  589. data/lib/datadog/tracing/pipeline/span_processor.rb +39 -0
  590. data/lib/datadog/tracing/pipeline.rb +65 -0
  591. data/lib/datadog/tracing/propagation/grpc.rb +88 -0
  592. data/lib/datadog/tracing/propagation/http.rb +109 -0
  593. data/lib/datadog/tracing/runtime/metrics.rb +19 -0
  594. data/lib/datadog/tracing/sampling/all_sampler.rb +25 -0
  595. data/lib/datadog/tracing/sampling/ext.rb +27 -0
  596. data/lib/datadog/tracing/sampling/matcher.rb +68 -0
  597. data/lib/datadog/tracing/sampling/priority_sampler.rb +112 -0
  598. data/lib/datadog/tracing/sampling/rate_by_key_sampler.rb +97 -0
  599. data/lib/datadog/tracing/sampling/rate_by_service_sampler.rb +41 -0
  600. data/lib/datadog/tracing/sampling/rate_limiter.rb +185 -0
  601. data/lib/datadog/tracing/sampling/rate_sampler.rb +55 -0
  602. data/lib/datadog/tracing/sampling/rule.rb +76 -0
  603. data/lib/datadog/tracing/sampling/rule_sampler.rb +131 -0
  604. data/lib/datadog/tracing/sampling/sampler.rb +44 -0
  605. data/lib/datadog/tracing/span.rb +212 -0
  606. data/lib/datadog/tracing/span_operation.rb +520 -0
  607. data/lib/datadog/tracing/sync_writer.rb +69 -0
  608. data/lib/datadog/tracing/trace_digest.rb +60 -0
  609. data/lib/datadog/tracing/trace_operation.rb +431 -0
  610. data/lib/datadog/tracing/trace_segment.rb +207 -0
  611. data/lib/datadog/tracing/tracer.rb +505 -0
  612. data/lib/datadog/tracing/workers/trace_writer.rb +195 -0
  613. data/lib/datadog/tracing/workers.rb +125 -0
  614. data/lib/datadog/tracing/writer.rb +180 -0
  615. data/lib/datadog/tracing.rb +142 -0
  616. data/lib/ddtrace/auto_instrument.rb +9 -0
  617. data/lib/ddtrace/auto_instrument_base.rb +8 -0
  618. data/lib/ddtrace/profiling/preload.rb +4 -0
  619. data/lib/ddtrace/transport/ext.rb +35 -0
  620. data/lib/ddtrace/transport/http/adapters/net.rb +57 -12
  621. data/lib/ddtrace/transport/http/adapters/registry.rb +3 -0
  622. data/lib/ddtrace/transport/http/adapters/test.rb +12 -2
  623. data/lib/ddtrace/transport/http/adapters/unix_socket.rb +30 -15
  624. data/lib/ddtrace/transport/http/api/endpoint.rb +2 -0
  625. data/lib/ddtrace/transport/http/api/fallbacks.rb +2 -0
  626. data/lib/ddtrace/transport/http/api/instance.rb +2 -0
  627. data/lib/ddtrace/transport/http/api/map.rb +2 -0
  628. data/lib/ddtrace/transport/http/api/spec.rb +2 -0
  629. data/lib/ddtrace/transport/http/api.rb +6 -11
  630. data/lib/ddtrace/transport/http/builder.rb +22 -7
  631. data/lib/ddtrace/transport/http/client.rb +5 -1
  632. data/lib/ddtrace/transport/http/env.rb +10 -0
  633. data/lib/ddtrace/transport/http/response.rb +36 -4
  634. data/lib/ddtrace/transport/http/statistics.rb +18 -3
  635. data/lib/ddtrace/transport/http/traces.rb +9 -6
  636. data/lib/ddtrace/transport/http.rb +66 -39
  637. data/lib/ddtrace/transport/io/client.rb +20 -9
  638. data/lib/ddtrace/transport/io/response.rb +3 -3
  639. data/lib/ddtrace/transport/io/traces.rb +12 -2
  640. data/lib/ddtrace/transport/io.rb +5 -3
  641. data/lib/ddtrace/transport/parcel.rb +9 -0
  642. data/lib/ddtrace/transport/request.rb +2 -0
  643. data/lib/ddtrace/transport/response.rb +13 -0
  644. data/lib/ddtrace/transport/serializable_trace.rb +118 -0
  645. data/lib/ddtrace/transport/statistics.rb +7 -4
  646. data/lib/ddtrace/transport/trace_formatter.rb +187 -0
  647. data/lib/ddtrace/transport/traces.rb +43 -10
  648. data/lib/ddtrace/version.rb +20 -5
  649. data/lib/ddtrace.rb +10 -71
  650. metadata +643 -603
  651. data/.circleci/config.yml +0 -490
  652. data/.circleci/images/primary/Dockerfile-2.0.0 +0 -73
  653. data/.circleci/images/primary/Dockerfile-2.1.10 +0 -73
  654. data/.circleci/images/primary/Dockerfile-2.2.10 +0 -73
  655. data/.circleci/images/primary/Dockerfile-2.3.8 +0 -75
  656. data/.circleci/images/primary/Dockerfile-2.4.6 +0 -73
  657. data/.circleci/images/primary/Dockerfile-2.5.6 +0 -73
  658. data/.circleci/images/primary/Dockerfile-2.6.4 +0 -73
  659. data/.circleci/images/primary/Dockerfile-2.7.0 +0 -73
  660. data/.circleci/images/primary/Dockerfile-jruby-9.2 +0 -77
  661. data/.dockerignore +0 -1
  662. data/.env +0 -26
  663. data/.github/CODEOWNERS +0 -1
  664. data/.rspec +0 -1
  665. data/.rubocop.yml +0 -81
  666. data/.yardopts +0 -5
  667. data/Appraisals +0 -944
  668. data/Gemfile +0 -7
  669. data/Rakefile +0 -731
  670. data/benchmarks/postgres_database.yml +0 -9
  671. data/benchmarks/sidekiq_test.rb +0 -154
  672. data/docker-compose.yml +0 -335
  673. data/lib/ddtrace/analytics.rb +0 -36
  674. data/lib/ddtrace/augmentation/method_wrapper.rb +0 -20
  675. data/lib/ddtrace/augmentation/method_wrapping.rb +0 -38
  676. data/lib/ddtrace/augmentation/shim.rb +0 -102
  677. data/lib/ddtrace/augmentation.rb +0 -13
  678. data/lib/ddtrace/buffer.rb +0 -119
  679. data/lib/ddtrace/chunker.rb +0 -34
  680. data/lib/ddtrace/configuration/base.rb +0 -84
  681. data/lib/ddtrace/configuration/components.rb +0 -154
  682. data/lib/ddtrace/configuration/dependency_resolver.rb +0 -24
  683. data/lib/ddtrace/configuration/option.rb +0 -64
  684. data/lib/ddtrace/configuration/option_definition.rb +0 -123
  685. data/lib/ddtrace/configuration/option_definition_set.rb +0 -18
  686. data/lib/ddtrace/configuration/option_set.rb +0 -6
  687. data/lib/ddtrace/configuration/options.rb +0 -112
  688. data/lib/ddtrace/configuration/pin_setup.rb +0 -30
  689. data/lib/ddtrace/configuration/settings.rb +0 -255
  690. data/lib/ddtrace/configuration.rb +0 -53
  691. data/lib/ddtrace/context.rb +0 -305
  692. data/lib/ddtrace/context_flush.rb +0 -69
  693. data/lib/ddtrace/context_provider.rb +0 -50
  694. data/lib/ddtrace/contrib/action_cable/configuration/settings.rb +0 -25
  695. data/lib/ddtrace/contrib/action_cable/event.rb +0 -65
  696. data/lib/ddtrace/contrib/action_cable/events/broadcast.rb +0 -49
  697. data/lib/ddtrace/contrib/action_cable/events/perform_action.rb +0 -55
  698. data/lib/ddtrace/contrib/action_cable/events/transmit.rb +0 -50
  699. data/lib/ddtrace/contrib/action_cable/events.rb +0 -33
  700. data/lib/ddtrace/contrib/action_cable/ext.rb +0 -23
  701. data/lib/ddtrace/contrib/action_cable/instrumentation.rb +0 -31
  702. data/lib/ddtrace/contrib/action_cable/integration.rb +0 -38
  703. data/lib/ddtrace/contrib/action_cable/patcher.rb +0 -27
  704. data/lib/ddtrace/contrib/action_pack/action_controller/instrumentation.rb +0 -148
  705. data/lib/ddtrace/contrib/action_pack/action_controller/patcher.rb +0 -25
  706. data/lib/ddtrace/contrib/action_pack/configuration/settings.rb +0 -27
  707. data/lib/ddtrace/contrib/action_pack/ext.rb +0 -16
  708. data/lib/ddtrace/contrib/action_pack/integration.rb +0 -38
  709. data/lib/ddtrace/contrib/action_pack/patcher.rb +0 -23
  710. data/lib/ddtrace/contrib/action_pack/utils.rb +0 -36
  711. data/lib/ddtrace/contrib/action_view/configuration/settings.rb +0 -26
  712. data/lib/ddtrace/contrib/action_view/event.rb +0 -39
  713. data/lib/ddtrace/contrib/action_view/events/render_partial.rb +0 -45
  714. data/lib/ddtrace/contrib/action_view/events/render_template.rb +0 -48
  715. data/lib/ddtrace/contrib/action_view/events.rb +0 -30
  716. data/lib/ddtrace/contrib/action_view/ext.rb +0 -17
  717. data/lib/ddtrace/contrib/action_view/instrumentation/partial_renderer.rb +0 -74
  718. data/lib/ddtrace/contrib/action_view/instrumentation/template_renderer.rb +0 -167
  719. data/lib/ddtrace/contrib/action_view/integration.rb +0 -45
  720. data/lib/ddtrace/contrib/action_view/patcher.rb +0 -47
  721. data/lib/ddtrace/contrib/action_view/utils.rb +0 -32
  722. data/lib/ddtrace/contrib/active_model_serializers/configuration/settings.rb +0 -25
  723. data/lib/ddtrace/contrib/active_model_serializers/event.rb +0 -68
  724. data/lib/ddtrace/contrib/active_model_serializers/events/render.rb +0 -32
  725. data/lib/ddtrace/contrib/active_model_serializers/events/serialize.rb +0 -35
  726. data/lib/ddtrace/contrib/active_model_serializers/events.rb +0 -30
  727. data/lib/ddtrace/contrib/active_model_serializers/ext.rb +0 -17
  728. data/lib/ddtrace/contrib/active_model_serializers/integration.rb +0 -40
  729. data/lib/ddtrace/contrib/active_model_serializers/patcher.rb +0 -29
  730. data/lib/ddtrace/contrib/active_record/configuration/resolver.rb +0 -45
  731. data/lib/ddtrace/contrib/active_record/configuration/settings.rb +0 -30
  732. data/lib/ddtrace/contrib/active_record/event.rb +0 -30
  733. data/lib/ddtrace/contrib/active_record/events/instantiation.rb +0 -60
  734. data/lib/ddtrace/contrib/active_record/events/sql.rb +0 -64
  735. data/lib/ddtrace/contrib/active_record/events.rb +0 -30
  736. data/lib/ddtrace/contrib/active_record/ext.rb +0 -21
  737. data/lib/ddtrace/contrib/active_record/integration.rb +0 -46
  738. data/lib/ddtrace/contrib/active_record/patcher.rb +0 -23
  739. data/lib/ddtrace/contrib/active_record/utils.rb +0 -76
  740. data/lib/ddtrace/contrib/active_support/cache/instrumentation.rb +0 -157
  741. data/lib/ddtrace/contrib/active_support/cache/patcher.rb +0 -48
  742. data/lib/ddtrace/contrib/active_support/cache/redis.rb +0 -47
  743. data/lib/ddtrace/contrib/active_support/configuration/settings.rb +0 -25
  744. data/lib/ddtrace/contrib/active_support/ext.rb +0 -21
  745. data/lib/ddtrace/contrib/active_support/integration.rb +0 -40
  746. data/lib/ddtrace/contrib/active_support/notifications/event.rb +0 -62
  747. data/lib/ddtrace/contrib/active_support/notifications/subscriber.rb +0 -66
  748. data/lib/ddtrace/contrib/active_support/notifications/subscription.rb +0 -159
  749. data/lib/ddtrace/contrib/active_support/patcher.rb +0 -23
  750. data/lib/ddtrace/contrib/analytics.rb +0 -24
  751. data/lib/ddtrace/contrib/aws/configuration/settings.rb +0 -25
  752. data/lib/ddtrace/contrib/aws/ext.rb +0 -20
  753. data/lib/ddtrace/contrib/aws/instrumentation.rb +0 -56
  754. data/lib/ddtrace/contrib/aws/integration.rb +0 -42
  755. data/lib/ddtrace/contrib/aws/parsed_context.rb +0 -56
  756. data/lib/ddtrace/contrib/aws/patcher.rb +0 -49
  757. data/lib/ddtrace/contrib/aws/services.rb +0 -115
  758. data/lib/ddtrace/contrib/concurrent_ruby/configuration/settings.rb +0 -15
  759. data/lib/ddtrace/contrib/concurrent_ruby/context_composite_executor_service.rb +0 -35
  760. data/lib/ddtrace/contrib/concurrent_ruby/ext.rb +0 -11
  761. data/lib/ddtrace/contrib/concurrent_ruby/future_patch.rb +0 -23
  762. data/lib/ddtrace/contrib/concurrent_ruby/integration.rb +0 -38
  763. data/lib/ddtrace/contrib/concurrent_ruby/patcher.rb +0 -28
  764. data/lib/ddtrace/contrib/configurable.rb +0 -76
  765. data/lib/ddtrace/contrib/configuration/resolver.rb +0 -16
  766. data/lib/ddtrace/contrib/configuration/resolvers/pattern_resolver.rb +0 -39
  767. data/lib/ddtrace/contrib/configuration/settings.rb +0 -35
  768. data/lib/ddtrace/contrib/dalli/configuration/settings.rb +0 -25
  769. data/lib/ddtrace/contrib/dalli/ext.rb +0 -17
  770. data/lib/ddtrace/contrib/dalli/instrumentation.rb +0 -50
  771. data/lib/ddtrace/contrib/dalli/integration.rb +0 -38
  772. data/lib/ddtrace/contrib/dalli/patcher.rb +0 -67
  773. data/lib/ddtrace/contrib/dalli/quantize.rb +0 -22
  774. data/lib/ddtrace/contrib/delayed_job/configuration/settings.rb +0 -25
  775. data/lib/ddtrace/contrib/delayed_job/ext.rb +0 -18
  776. data/lib/ddtrace/contrib/delayed_job/integration.rb +0 -38
  777. data/lib/ddtrace/contrib/delayed_job/patcher.rb +0 -28
  778. data/lib/ddtrace/contrib/delayed_job/plugin.rb +0 -61
  779. data/lib/ddtrace/contrib/elasticsearch/configuration/settings.rb +0 -26
  780. data/lib/ddtrace/contrib/elasticsearch/ext.rb +0 -19
  781. data/lib/ddtrace/contrib/elasticsearch/integration.rb +0 -39
  782. data/lib/ddtrace/contrib/elasticsearch/patcher.rb +0 -118
  783. data/lib/ddtrace/contrib/elasticsearch/quantize.rb +0 -80
  784. data/lib/ddtrace/contrib/ethon/configuration/settings.rb +0 -27
  785. data/lib/ddtrace/contrib/ethon/easy_patch.rb +0 -148
  786. data/lib/ddtrace/contrib/ethon/ext.rb +0 -15
  787. data/lib/ddtrace/contrib/ethon/integration.rb +0 -43
  788. data/lib/ddtrace/contrib/ethon/multi_patch.rb +0 -80
  789. data/lib/ddtrace/contrib/ethon/patcher.rb +0 -25
  790. data/lib/ddtrace/contrib/excon/configuration/settings.rb +0 -28
  791. data/lib/ddtrace/contrib/excon/ext.rb +0 -14
  792. data/lib/ddtrace/contrib/excon/integration.rb +0 -43
  793. data/lib/ddtrace/contrib/excon/middleware.rb +0 -157
  794. data/lib/ddtrace/contrib/excon/patcher.rb +0 -27
  795. data/lib/ddtrace/contrib/extensions.rb +0 -59
  796. data/lib/ddtrace/contrib/faraday/configuration/settings.rb +0 -33
  797. data/lib/ddtrace/contrib/faraday/connection.rb +0 -18
  798. data/lib/ddtrace/contrib/faraday/ext.rb +0 -14
  799. data/lib/ddtrace/contrib/faraday/integration.rb +0 -43
  800. data/lib/ddtrace/contrib/faraday/middleware.rb +0 -81
  801. data/lib/ddtrace/contrib/faraday/patcher.rb +0 -81
  802. data/lib/ddtrace/contrib/faraday/rack_builder.rb +0 -18
  803. data/lib/ddtrace/contrib/grape/configuration/settings.rb +0 -27
  804. data/lib/ddtrace/contrib/grape/endpoint.rb +0 -208
  805. data/lib/ddtrace/contrib/grape/ext.rb +0 -19
  806. data/lib/ddtrace/contrib/grape/instrumentation.rb +0 -33
  807. data/lib/ddtrace/contrib/grape/integration.rb +0 -39
  808. data/lib/ddtrace/contrib/grape/patcher.rb +0 -73
  809. data/lib/ddtrace/contrib/graphql/configuration/settings.rb +0 -27
  810. data/lib/ddtrace/contrib/graphql/ext.rb +0 -13
  811. data/lib/ddtrace/contrib/graphql/integration.rb +0 -39
  812. data/lib/ddtrace/contrib/graphql/patcher.rb +0 -57
  813. data/lib/ddtrace/contrib/grpc/configuration/settings.rb +0 -25
  814. data/lib/ddtrace/contrib/grpc/datadog_interceptor/client.rb +0 -56
  815. data/lib/ddtrace/contrib/grpc/datadog_interceptor/server.rb +0 -76
  816. data/lib/ddtrace/contrib/grpc/datadog_interceptor.rb +0 -74
  817. data/lib/ddtrace/contrib/grpc/ext.rb +0 -15
  818. data/lib/ddtrace/contrib/grpc/integration.rb +0 -38
  819. data/lib/ddtrace/contrib/grpc/intercept_with_datadog.rb +0 -49
  820. data/lib/ddtrace/contrib/grpc/patcher.rb +0 -72
  821. data/lib/ddtrace/contrib/http/circuit_breaker.rb +0 -39
  822. data/lib/ddtrace/contrib/http/configuration/settings.rb +0 -27
  823. data/lib/ddtrace/contrib/http/ext.rb +0 -14
  824. data/lib/ddtrace/contrib/http/instrumentation.rb +0 -170
  825. data/lib/ddtrace/contrib/http/integration.rb +0 -45
  826. data/lib/ddtrace/contrib/http/patcher.rb +0 -26
  827. data/lib/ddtrace/contrib/http_annotation_helper.rb +0 -10
  828. data/lib/ddtrace/contrib/integration.rb +0 -16
  829. data/lib/ddtrace/contrib/mongodb/configuration/settings.rb +0 -28
  830. data/lib/ddtrace/contrib/mongodb/ext.rb +0 -20
  831. data/lib/ddtrace/contrib/mongodb/instrumentation.rb +0 -68
  832. data/lib/ddtrace/contrib/mongodb/integration.rb +0 -38
  833. data/lib/ddtrace/contrib/mongodb/parsers.rb +0 -68
  834. data/lib/ddtrace/contrib/mongodb/patcher.rb +0 -31
  835. data/lib/ddtrace/contrib/mongodb/subscribers.rb +0 -108
  836. data/lib/ddtrace/contrib/mysql2/configuration/settings.rb +0 -25
  837. data/lib/ddtrace/contrib/mysql2/ext.rb +0 -15
  838. data/lib/ddtrace/contrib/mysql2/instrumentation.rb +0 -60
  839. data/lib/ddtrace/contrib/mysql2/integration.rb +0 -38
  840. data/lib/ddtrace/contrib/mysql2/patcher.rb +0 -27
  841. data/lib/ddtrace/contrib/patchable.rb +0 -59
  842. data/lib/ddtrace/contrib/patcher.rb +0 -56
  843. data/lib/ddtrace/contrib/presto/configuration/settings.rb +0 -25
  844. data/lib/ddtrace/contrib/presto/ext.rb +0 -25
  845. data/lib/ddtrace/contrib/presto/instrumentation.rb +0 -107
  846. data/lib/ddtrace/contrib/presto/integration.rb +0 -38
  847. data/lib/ddtrace/contrib/presto/patcher.rb +0 -30
  848. data/lib/ddtrace/contrib/racecar/configuration/settings.rb +0 -25
  849. data/lib/ddtrace/contrib/racecar/event.rb +0 -71
  850. data/lib/ddtrace/contrib/racecar/events/batch.rb +0 -27
  851. data/lib/ddtrace/contrib/racecar/events/message.rb +0 -27
  852. data/lib/ddtrace/contrib/racecar/events.rb +0 -30
  853. data/lib/ddtrace/contrib/racecar/ext.rb +0 -21
  854. data/lib/ddtrace/contrib/racecar/integration.rb +0 -39
  855. data/lib/ddtrace/contrib/racecar/patcher.rb +0 -26
  856. data/lib/ddtrace/contrib/rack/configuration/settings.rb +0 -41
  857. data/lib/ddtrace/contrib/rack/ext.rb +0 -18
  858. data/lib/ddtrace/contrib/rack/integration.rb +0 -38
  859. data/lib/ddtrace/contrib/rack/middlewares.rb +0 -287
  860. data/lib/ddtrace/contrib/rack/patcher.rb +0 -107
  861. data/lib/ddtrace/contrib/rack/request_queue.rb +0 -39
  862. data/lib/ddtrace/contrib/rails/configuration/settings.rb +0 -94
  863. data/lib/ddtrace/contrib/rails/ext.rb +0 -13
  864. data/lib/ddtrace/contrib/rails/framework.rb +0 -118
  865. data/lib/ddtrace/contrib/rails/integration.rb +0 -44
  866. data/lib/ddtrace/contrib/rails/middlewares.rb +0 -38
  867. data/lib/ddtrace/contrib/rails/patcher.rb +0 -74
  868. data/lib/ddtrace/contrib/rails/railtie.rb +0 -17
  869. data/lib/ddtrace/contrib/rails/utils.rb +0 -20
  870. data/lib/ddtrace/contrib/rake/configuration/settings.rb +0 -27
  871. data/lib/ddtrace/contrib/rake/ext.rb +0 -18
  872. data/lib/ddtrace/contrib/rake/instrumentation.rb +0 -88
  873. data/lib/ddtrace/contrib/rake/integration.rb +0 -38
  874. data/lib/ddtrace/contrib/rake/patcher.rb +0 -30
  875. data/lib/ddtrace/contrib/redis/configuration/resolver.rb +0 -36
  876. data/lib/ddtrace/contrib/redis/configuration/settings.rb +0 -25
  877. data/lib/ddtrace/contrib/redis/ext.rb +0 -18
  878. data/lib/ddtrace/contrib/redis/integration.rb +0 -42
  879. data/lib/ddtrace/contrib/redis/patcher.rb +0 -97
  880. data/lib/ddtrace/contrib/redis/quantize.rb +0 -47
  881. data/lib/ddtrace/contrib/redis/tags.rb +0 -38
  882. data/lib/ddtrace/contrib/redis/vendor/resolver.rb +0 -159
  883. data/lib/ddtrace/contrib/registerable.rb +0 -33
  884. data/lib/ddtrace/contrib/registry.rb +0 -42
  885. data/lib/ddtrace/contrib/resque/configuration/settings.rb +0 -26
  886. data/lib/ddtrace/contrib/resque/ext.rb +0 -14
  887. data/lib/ddtrace/contrib/resque/integration.rb +0 -47
  888. data/lib/ddtrace/contrib/resque/patcher.rb +0 -29
  889. data/lib/ddtrace/contrib/resque/resque_job.rb +0 -80
  890. data/lib/ddtrace/contrib/rest_client/configuration/settings.rb +0 -26
  891. data/lib/ddtrace/contrib/rest_client/ext.rb +0 -14
  892. data/lib/ddtrace/contrib/rest_client/integration.rb +0 -38
  893. data/lib/ddtrace/contrib/rest_client/patcher.rb +0 -23
  894. data/lib/ddtrace/contrib/rest_client/request_patch.rb +0 -89
  895. data/lib/ddtrace/contrib/sequel/configuration/settings.rb +0 -23
  896. data/lib/ddtrace/contrib/sequel/database.rb +0 -61
  897. data/lib/ddtrace/contrib/sequel/dataset.rb +0 -62
  898. data/lib/ddtrace/contrib/sequel/ext.rb +0 -15
  899. data/lib/ddtrace/contrib/sequel/integration.rb +0 -38
  900. data/lib/ddtrace/contrib/sequel/patcher.rb +0 -33
  901. data/lib/ddtrace/contrib/sequel/utils.rb +0 -46
  902. data/lib/ddtrace/contrib/shoryuken/configuration/settings.rb +0 -24
  903. data/lib/ddtrace/contrib/shoryuken/ext.rb +0 -18
  904. data/lib/ddtrace/contrib/shoryuken/integration.rb +0 -39
  905. data/lib/ddtrace/contrib/shoryuken/patcher.rb +0 -24
  906. data/lib/ddtrace/contrib/shoryuken/tracer.rb +0 -49
  907. data/lib/ddtrace/contrib/sidekiq/client_tracer.rb +0 -43
  908. data/lib/ddtrace/contrib/sidekiq/configuration/settings.rb +0 -31
  909. data/lib/ddtrace/contrib/sidekiq/ext.rb +0 -23
  910. data/lib/ddtrace/contrib/sidekiq/integration.rb +0 -38
  911. data/lib/ddtrace/contrib/sidekiq/patcher.rb +0 -34
  912. data/lib/ddtrace/contrib/sidekiq/server_tracer.rb +0 -66
  913. data/lib/ddtrace/contrib/sidekiq/tracing.rb +0 -45
  914. data/lib/ddtrace/contrib/sinatra/configuration/settings.rb +0 -34
  915. data/lib/ddtrace/contrib/sinatra/env.rb +0 -58
  916. data/lib/ddtrace/contrib/sinatra/ext.rb +0 -24
  917. data/lib/ddtrace/contrib/sinatra/headers.rb +0 -31
  918. data/lib/ddtrace/contrib/sinatra/integration.rb +0 -38
  919. data/lib/ddtrace/contrib/sinatra/patcher.rb +0 -28
  920. data/lib/ddtrace/contrib/sinatra/tracer.rb +0 -150
  921. data/lib/ddtrace/contrib/sinatra/tracer_middleware.rb +0 -78
  922. data/lib/ddtrace/contrib/sucker_punch/configuration/settings.rb +0 -25
  923. data/lib/ddtrace/contrib/sucker_punch/exception_handler.rb +0 -26
  924. data/lib/ddtrace/contrib/sucker_punch/ext.rb +0 -18
  925. data/lib/ddtrace/contrib/sucker_punch/instrumentation.rb +0 -84
  926. data/lib/ddtrace/contrib/sucker_punch/integration.rb +0 -38
  927. data/lib/ddtrace/contrib/sucker_punch/patcher.rb +0 -42
  928. data/lib/ddtrace/correlation.rb +0 -38
  929. data/lib/ddtrace/diagnostics/health.rb +0 -33
  930. data/lib/ddtrace/distributed_tracing/headers/b3.rb +0 -44
  931. data/lib/ddtrace/distributed_tracing/headers/b3_single.rb +0 -56
  932. data/lib/ddtrace/distributed_tracing/headers/datadog.rb +0 -42
  933. data/lib/ddtrace/distributed_tracing/headers/headers.rb +0 -70
  934. data/lib/ddtrace/distributed_tracing/headers/helpers.rb +0 -45
  935. data/lib/ddtrace/encoding.rb +0 -69
  936. data/lib/ddtrace/environment.rb +0 -27
  937. data/lib/ddtrace/error.rb +0 -27
  938. data/lib/ddtrace/event.rb +0 -52
  939. data/lib/ddtrace/ext/analytics.rb +0 -12
  940. data/lib/ddtrace/ext/app_types.rb +0 -11
  941. data/lib/ddtrace/ext/correlation.rb +0 -11
  942. data/lib/ddtrace/ext/diagnostics.rb +0 -33
  943. data/lib/ddtrace/ext/distributed.rb +0 -33
  944. data/lib/ddtrace/ext/environment.rb +0 -14
  945. data/lib/ddtrace/ext/errors.rb +0 -10
  946. data/lib/ddtrace/ext/forced_tracing.rb +0 -25
  947. data/lib/ddtrace/ext/http.rb +0 -46
  948. data/lib/ddtrace/ext/manual_tracing.rb +0 -9
  949. data/lib/ddtrace/ext/metrics.rb +0 -15
  950. data/lib/ddtrace/ext/net.rb +0 -10
  951. data/lib/ddtrace/ext/priority.rb +0 -16
  952. data/lib/ddtrace/ext/runtime.rb +0 -26
  953. data/lib/ddtrace/ext/sampling.rb +0 -16
  954. data/lib/ddtrace/ext/sql.rb +0 -8
  955. data/lib/ddtrace/ext/transport.rb +0 -17
  956. data/lib/ddtrace/forced_tracing.rb +0 -36
  957. data/lib/ddtrace/logger.rb +0 -40
  958. data/lib/ddtrace/metrics.rb +0 -222
  959. data/lib/ddtrace/monkey.rb +0 -58
  960. data/lib/ddtrace/opentelemetry/extensions.rb +0 -13
  961. data/lib/ddtrace/opentelemetry/span.rb +0 -33
  962. data/lib/ddtrace/opentracer/binary_propagator.rb +0 -24
  963. data/lib/ddtrace/opentracer/carrier.rb +0 -6
  964. data/lib/ddtrace/opentracer/distributed_headers.rb +0 -52
  965. data/lib/ddtrace/opentracer/global_tracer.rb +0 -15
  966. data/lib/ddtrace/opentracer/propagator.rb +0 -22
  967. data/lib/ddtrace/opentracer/rack_propagator.rb +0 -60
  968. data/lib/ddtrace/opentracer/scope.rb +0 -15
  969. data/lib/ddtrace/opentracer/scope_manager.rb +0 -6
  970. data/lib/ddtrace/opentracer/span.rb +0 -98
  971. data/lib/ddtrace/opentracer/span_context.rb +0 -14
  972. data/lib/ddtrace/opentracer/span_context_factory.rb +0 -23
  973. data/lib/ddtrace/opentracer/text_map_propagator.rb +0 -75
  974. data/lib/ddtrace/opentracer/thread_local_scope.rb +0 -30
  975. data/lib/ddtrace/opentracer/thread_local_scope_manager.rb +0 -40
  976. data/lib/ddtrace/opentracer/tracer.rb +0 -208
  977. data/lib/ddtrace/opentracer.rb +0 -40
  978. data/lib/ddtrace/patcher.rb +0 -47
  979. data/lib/ddtrace/pin.rb +0 -114
  980. data/lib/ddtrace/pipeline/span_filter.rb +0 -38
  981. data/lib/ddtrace/pipeline/span_processor.rb +0 -20
  982. data/lib/ddtrace/pipeline.rb +0 -46
  983. data/lib/ddtrace/propagation/grpc_propagator.rb +0 -61
  984. data/lib/ddtrace/propagation/http_propagator.rb +0 -75
  985. data/lib/ddtrace/quantization/hash.rb +0 -103
  986. data/lib/ddtrace/quantization/http.rb +0 -86
  987. data/lib/ddtrace/runtime/cgroup.rb +0 -44
  988. data/lib/ddtrace/runtime/class_count.rb +0 -17
  989. data/lib/ddtrace/runtime/container.rb +0 -73
  990. data/lib/ddtrace/runtime/gc.rb +0 -16
  991. data/lib/ddtrace/runtime/identity.rb +0 -41
  992. data/lib/ddtrace/runtime/metrics.rb +0 -96
  993. data/lib/ddtrace/runtime/object_space.rb +0 -19
  994. data/lib/ddtrace/runtime/socket.rb +0 -14
  995. data/lib/ddtrace/runtime/thread_count.rb +0 -16
  996. data/lib/ddtrace/sampler.rb +0 -290
  997. data/lib/ddtrace/sampling/matcher.rb +0 -57
  998. data/lib/ddtrace/sampling/rate_limiter.rb +0 -127
  999. data/lib/ddtrace/sampling/rule.rb +0 -61
  1000. data/lib/ddtrace/sampling/rule_sampler.rb +0 -125
  1001. data/lib/ddtrace/sampling.rb +0 -2
  1002. data/lib/ddtrace/span.rb +0 -297
  1003. data/lib/ddtrace/sync_writer.rb +0 -67
  1004. data/lib/ddtrace/tracer.rb +0 -432
  1005. data/lib/ddtrace/utils/database.rb +0 -25
  1006. data/lib/ddtrace/utils/time.rb +0 -14
  1007. data/lib/ddtrace/utils.rb +0 -65
  1008. data/lib/ddtrace/vendor/active_record/connection_specification.rb +0 -301
  1009. data/lib/ddtrace/worker.rb +0 -20
  1010. data/lib/ddtrace/workers/async.rb +0 -165
  1011. data/lib/ddtrace/workers/loop.rb +0 -105
  1012. data/lib/ddtrace/workers/polling.rb +0 -48
  1013. data/lib/ddtrace/workers/queue.rb +0 -39
  1014. data/lib/ddtrace/workers/runtime_metrics.rb +0 -47
  1015. data/lib/ddtrace/workers/trace_writer.rb +0 -199
  1016. data/lib/ddtrace/workers.rb +0 -117
  1017. data/lib/ddtrace/writer.rb +0 -154
  1018. data/tasks/release_gem.rake +0 -28
@@ -1,301 +0,0 @@
1
- require 'uri'
2
-
3
- # NOTE: This code is copied directly from ActiveRecord.
4
- # Its purpose is to resolve connection information.
5
- # It exists here only because it doesn't exist in Rails 3.2.
6
- # When support for Rails 3.2 is dropped, this can be removed.
7
- module Datadog
8
- module Vendor
9
- module ActiveRecord
10
- # Copy/paste from:
11
- # https://github.com/rails/rails/blob/5-2-stable/activerecord/lib/active_record/connection_handling.rb
12
- module ConnectionHandling
13
- RAILS_ENV = -> { (Rails.env if defined?(Rails) && defined?(Rails.env)) || ENV["RAILS_ENV"].presence || ENV["RACK_ENV"].presence }
14
- end
15
-
16
- # Copy/paste from:
17
- # https://github.com/rails/rails/blob/5-2-stable/activerecord/lib/active_record/connection_adapters/connection_specification.rb
18
- module ConnectionAdapters
19
- class ConnectionSpecification
20
- attr_reader :name, :config, :adapter_method
21
-
22
- def initialize(name, config, adapter_method)
23
- @name, @config, @adapter_method = name, config, adapter_method
24
- end
25
-
26
- def initialize_dup(original)
27
- @config = original.config.dup
28
- end
29
-
30
- def to_hash
31
- @config.merge(name: @name)
32
- end
33
-
34
- # Expands a connection string into a hash.
35
- class ConnectionUrlResolver # :nodoc:
36
- # == Example
37
- #
38
- # url = "postgresql://foo:bar@localhost:9000/foo_test?pool=5&timeout=3000"
39
- # ConnectionUrlResolver.new(url).to_hash
40
- # # => {
41
- # "adapter" => "postgresql",
42
- # "host" => "localhost",
43
- # "port" => 9000,
44
- # "database" => "foo_test",
45
- # "username" => "foo",
46
- # "password" => "bar",
47
- # "pool" => "5",
48
- # "timeout" => "3000"
49
- # }
50
- def initialize(url)
51
- raise "Database URL cannot be empty" if url.blank?
52
- @uri = uri_parser.parse(url)
53
- @adapter = @uri.scheme && @uri.scheme.tr("-", "_")
54
- @adapter = "postgresql" if @adapter == "postgres"
55
-
56
- if @uri.opaque
57
- @uri.opaque, @query = @uri.opaque.split("?", 2)
58
- else
59
- @query = @uri.query
60
- end
61
- end
62
-
63
- # Converts the given URL to a full connection hash.
64
- def to_hash
65
- config = raw_config.reject { |_, value| value.blank? }
66
- config.map { |key, value| config[key] = uri_parser.unescape(value) if value.is_a? String }
67
- config
68
- end
69
-
70
- private
71
-
72
- def uri
73
- @uri
74
- end
75
-
76
- def uri_parser
77
- @uri_parser ||= URI::Parser.new
78
- end
79
-
80
- # Converts the query parameters of the URI into a hash.
81
- #
82
- # "localhost?pool=5&reaping_frequency=2"
83
- # # => { "pool" => "5", "reaping_frequency" => "2" }
84
- #
85
- # returns empty hash if no query present.
86
- #
87
- # "localhost"
88
- # # => {}
89
- def query_hash
90
- Hash[(@query || "").split("&").map { |pair| pair.split("=") }]
91
- end
92
-
93
- def raw_config
94
- if uri.opaque
95
- query_hash.merge(
96
- "adapter" => @adapter,
97
- "database" => uri.opaque)
98
- else
99
- query_hash.merge(
100
- "adapter" => @adapter,
101
- "username" => uri.user,
102
- "password" => uri.password,
103
- "port" => uri.port,
104
- "database" => database_from_path,
105
- "host" => uri.hostname)
106
- end
107
- end
108
-
109
- # Returns name of the database.
110
- def database_from_path
111
- if @adapter == "sqlite3"
112
- # 'sqlite3:/foo' is absolute, because that makes sense. The
113
- # corresponding relative version, 'sqlite3:foo', is handled
114
- # elsewhere, as an "opaque".
115
-
116
- uri.path
117
- else
118
- # Only SQLite uses a filename as the "database" name; for
119
- # anything else, a leading slash would be silly.
120
-
121
- uri.path.sub(%r{^/}, "")
122
- end
123
- end
124
- end
125
-
126
- ##
127
- # Builds a ConnectionSpecification from user input.
128
- class Resolver # :nodoc:
129
- attr_reader :configurations
130
-
131
- # Accepts a hash two layers deep, keys on the first layer represent
132
- # environments such as "production". Keys must be strings.
133
- def initialize(configurations)
134
- @configurations = configurations
135
- end
136
-
137
- # Returns a hash with database connection information.
138
- #
139
- # == Examples
140
- #
141
- # Full hash Configuration.
142
- #
143
- # configurations = { "production" => { "host" => "localhost", "database" => "foo", "adapter" => "sqlite3" } }
144
- # Resolver.new(configurations).resolve(:production)
145
- # # => { "host" => "localhost", "database" => "foo", "adapter" => "sqlite3"}
146
- #
147
- # Initialized with URL configuration strings.
148
- #
149
- # configurations = { "production" => "postgresql://localhost/foo" }
150
- # Resolver.new(configurations).resolve(:production)
151
- # # => { "host" => "localhost", "database" => "foo", "adapter" => "postgresql" }
152
- #
153
- def resolve(config)
154
- if config
155
- resolve_connection config
156
- elsif env = ConnectionHandling::RAILS_ENV.call
157
- resolve_symbol_connection env.to_sym
158
- else
159
- raise AdapterNotSpecified
160
- end
161
- end
162
-
163
- # Expands each key in @configurations hash into fully resolved hash
164
- def resolve_all
165
- config = configurations.dup
166
-
167
- if env = ConnectionHandling::DEFAULT_ENV.call
168
- env_config = config[env] if config[env].is_a?(Hash) && !(config[env].key?("adapter") || config[env].key?("url"))
169
- end
170
-
171
- config.reject! { |k, v| v.is_a?(Hash) && !(v.key?("adapter") || v.key?("url")) }
172
- config.merge! env_config if env_config
173
-
174
- config.each do |key, value|
175
- config[key] = resolve(value) if value
176
- end
177
-
178
- config
179
- end
180
-
181
- # Returns an instance of ConnectionSpecification for a given adapter.
182
- # Accepts a hash one layer deep that contains all connection information.
183
- #
184
- # == Example
185
- #
186
- # config = { "production" => { "host" => "localhost", "database" => "foo", "adapter" => "sqlite3" } }
187
- # spec = Resolver.new(config).spec(:production)
188
- # spec.adapter_method
189
- # # => "sqlite3_connection"
190
- # spec.config
191
- # # => { "host" => "localhost", "database" => "foo", "adapter" => "sqlite3" }
192
- #
193
- def spec(config)
194
- spec = resolve(config).symbolize_keys
195
-
196
- raise(AdapterNotSpecified, "database configuration does not specify adapter") unless spec.key?(:adapter)
197
-
198
- # Require the adapter itself and give useful feedback about
199
- # 1. Missing adapter gems and
200
- # 2. Adapter gems' missing dependencies.
201
- path_to_adapter = "active_record/connection_adapters/#{spec[:adapter]}_adapter"
202
- begin
203
- require path_to_adapter
204
- rescue LoadError => e
205
- # We couldn't require the adapter itself. Raise an exception that
206
- # points out config typos and missing gems.
207
- if e.path == path_to_adapter
208
- # We can assume that a non-builtin adapter was specified, so it's
209
- # either misspelled or missing from Gemfile.
210
- raise e.class, "Could not load the '#{spec[:adapter]}' Active Record adapter. Ensure that the adapter is spelled correctly in config/database.yml and that you've added the necessary adapter gem to your Gemfile.", e.backtrace
211
-
212
- # Bubbled up from the adapter require. Prefix the exception message
213
- # with some guidance about how to address it and reraise.
214
- else
215
- raise e.class, "Error loading the '#{spec[:adapter]}' Active Record adapter. Missing a gem it depends on? #{e.message}", e.backtrace
216
- end
217
- end
218
-
219
- adapter_method = "#{spec[:adapter]}_connection"
220
-
221
- unless ::ActiveRecord::Base.respond_to?(adapter_method)
222
- raise AdapterNotFound, "database configuration specifies nonexistent #{spec.config[:adapter]} adapter"
223
- end
224
-
225
- ConnectionSpecification.new(spec.delete(:name) || "primary", spec, adapter_method)
226
- end
227
-
228
- private
229
-
230
- # Returns fully resolved connection, accepts hash, string or symbol.
231
- # Always returns a hash.
232
- #
233
- # == Examples
234
- #
235
- # Symbol representing current environment.
236
- #
237
- # Resolver.new("production" => {}).resolve_connection(:production)
238
- # # => {}
239
- #
240
- # One layer deep hash of connection values.
241
- #
242
- # Resolver.new({}).resolve_connection("adapter" => "sqlite3")
243
- # # => { "adapter" => "sqlite3" }
244
- #
245
- # Connection URL.
246
- #
247
- # Resolver.new({}).resolve_connection("postgresql://localhost/foo")
248
- # # => { "host" => "localhost", "database" => "foo", "adapter" => "postgresql" }
249
- #
250
- def resolve_connection(spec)
251
- case spec
252
- when Symbol
253
- resolve_symbol_connection spec
254
- when String
255
- resolve_url_connection spec
256
- when Hash
257
- resolve_hash_connection spec
258
- end
259
- end
260
-
261
- # Takes the environment such as +:production+ or +:development+.
262
- # This requires that the @configurations was initialized with a key that
263
- # matches.
264
- #
265
- # Resolver.new("production" => {}).resolve_symbol_connection(:production)
266
- # # => {}
267
- #
268
- def resolve_symbol_connection(spec)
269
- if config = configurations[spec.to_s]
270
- resolve_connection(config).merge("name" => spec.to_s)
271
- else
272
- raise(AdapterNotSpecified, "'#{spec}' database is not configured. Available: #{configurations.keys.inspect}")
273
- end
274
- end
275
-
276
- # Accepts a hash. Expands the "url" key that contains a
277
- # URL database connection to a full connection
278
- # hash and merges with the rest of the hash.
279
- # Connection details inside of the "url" key win any merge conflicts
280
- def resolve_hash_connection(spec)
281
- if spec["url"] && spec["url"] !~ /^jdbc:/
282
- connection_hash = resolve_url_connection(spec.delete("url"))
283
- spec.merge!(connection_hash)
284
- end
285
- spec
286
- end
287
-
288
- # Takes a connection URL.
289
- #
290
- # Resolver.new({}).resolve_url_connection("postgresql://localhost/foo")
291
- # # => { "host" => "localhost", "database" => "foo", "adapter" => "postgresql" }
292
- #
293
- def resolve_url_connection(url)
294
- ConnectionUrlResolver.new(url).to_hash
295
- end
296
- end
297
- end
298
- end
299
- end
300
- end
301
- end
@@ -1,20 +0,0 @@
1
- module Datadog
2
- # Base class for work tasks
3
- class Worker
4
- attr_reader \
5
- :task
6
-
7
- def initialize(&block)
8
- @task = block
9
- end
10
-
11
- def perform(*args)
12
- task.call(*args) unless task.nil?
13
- end
14
-
15
- protected
16
-
17
- attr_writer \
18
- :task
19
- end
20
- end
@@ -1,165 +0,0 @@
1
- require 'ddtrace/logger'
2
-
3
- module Datadog
4
- module Workers
5
- module Async
6
- # Adds threading behavior to workers
7
- # to run tasks asynchronously.
8
- # rubocop:disable Metrics/ModuleLength
9
- module Thread
10
- FORK_POLICY_STOP = :stop
11
- FORK_POLICY_RESTART = :restart
12
- SHUTDOWN_TIMEOUT = 1
13
-
14
- def self.included(base)
15
- base.send(:prepend, PrependedMethods)
16
- end
17
-
18
- # Methods that must be prepended
19
- module PrependedMethods
20
- def perform(*args)
21
- start { self.result = super(*args) } unless started?
22
- end
23
- end
24
-
25
- attr_reader \
26
- :error,
27
- :result
28
-
29
- attr_writer \
30
- :fork_policy
31
-
32
- def join(timeout = nil)
33
- return true unless running?
34
- !worker.join(timeout).nil?
35
- end
36
-
37
- def terminate
38
- return false unless running?
39
- @run_async = false
40
- worker.terminate
41
- true
42
- end
43
-
44
- def run_async?
45
- @run_async = false unless instance_variable_defined?(:@run_async)
46
- @run_async == true
47
- end
48
-
49
- def started?
50
- !(worker.nil? || forked?)
51
- end
52
-
53
- def running?
54
- !worker.nil? && worker.alive?
55
- end
56
-
57
- def error?
58
- @error = nil unless instance_variable_defined?(:@error)
59
- !@error.nil?
60
- end
61
-
62
- def completed?
63
- !worker.nil? && worker.status == false && !error?
64
- end
65
-
66
- def failed?
67
- !worker.nil? && worker.status.nil?
68
- end
69
-
70
- def forked?
71
- !pid.nil? && pid != Process.pid
72
- end
73
-
74
- def fork_policy
75
- @fork_policy ||= FORK_POLICY_STOP
76
- end
77
-
78
- protected
79
-
80
- attr_writer \
81
- :result
82
-
83
- def mutex
84
- @mutex ||= Mutex.new
85
- end
86
-
87
- def after_fork
88
- # Do nothing by default
89
- end
90
-
91
- private
92
-
93
- attr_reader \
94
- :pid
95
-
96
- def mutex_after_fork
97
- @mutex_after_fork ||= Mutex.new
98
- end
99
-
100
- def worker
101
- @worker ||= nil
102
- end
103
-
104
- def start(&block)
105
- mutex.synchronize do
106
- return if running?
107
- if forked?
108
- case fork_policy
109
- when FORK_POLICY_STOP
110
- stop_fork
111
- when FORK_POLICY_RESTART
112
- restart_after_fork(&block)
113
- end
114
- elsif !run_async?
115
- start_worker(&block)
116
- end
117
- end
118
- end
119
-
120
- def start_worker
121
- @run_async = true
122
- @pid = Process.pid
123
- @error = nil
124
- Datadog.logger.debug("Starting thread in the process: #{Process.pid}")
125
-
126
- @worker = ::Thread.new do
127
- begin
128
- yield
129
- # rubocop:disable Lint/RescueException
130
- rescue Exception => e
131
- @error = e
132
- Datadog.logger.debug("Worker thread error. Cause #{e.message} Location: #{e.backtrace.first}")
133
- raise
134
- end
135
- end
136
- end
137
-
138
- def stop_fork
139
- mutex_after_fork.synchronize do
140
- if forked?
141
- # Trigger callback to allow workers to reset themselves accordingly
142
- after_fork
143
-
144
- # Reset and turn off
145
- @pid = Process.pid
146
- @run_async = false
147
- end
148
- end
149
- end
150
-
151
- def restart_after_fork(&block)
152
- mutex_after_fork.synchronize do
153
- if forked?
154
- # Trigger callback to allow workers to reset themselves accordingly
155
- after_fork
156
-
157
- # Start worker
158
- start_worker(&block)
159
- end
160
- end
161
- end
162
- end
163
- end
164
- end
165
- end
@@ -1,105 +0,0 @@
1
- module Datadog
2
- module Workers
3
- # Adds looping behavior to workers, with a sleep
4
- # interval between each loop.
5
- module IntervalLoop
6
- BACK_OFF_RATIO = 1.2
7
- BACK_OFF_MAX = 5
8
- BASE_INTERVAL = 1
9
-
10
- def self.included(base)
11
- base.send(:prepend, PrependedMethods)
12
- end
13
-
14
- # Methods that must be prepended
15
- module PrependedMethods
16
- def perform(*args)
17
- perform_loop { super(*args) }
18
- end
19
- end
20
-
21
- def stop_loop
22
- mutex.synchronize do
23
- return false unless run_loop?
24
- @run_loop = false
25
- shutdown.signal
26
- end
27
-
28
- true
29
- end
30
-
31
- def work_pending?
32
- run_loop?
33
- end
34
-
35
- def run_loop?
36
- @run_loop = false unless instance_variable_defined?(:@run_loop)
37
- @run_loop == true
38
- end
39
-
40
- def loop_base_interval
41
- @loop_base_interval ||= BASE_INTERVAL
42
- end
43
-
44
- def loop_back_off_ratio
45
- @loop_back_off_ratio ||= BACK_OFF_RATIO
46
- end
47
-
48
- def loop_back_off_max
49
- @loop_back_off_max ||= BACK_OFF_MAX
50
- end
51
-
52
- def loop_wait_time
53
- @loop_wait_time ||= loop_base_interval
54
- end
55
-
56
- def loop_back_off?
57
- false
58
- end
59
-
60
- def loop_back_off!(amount = nil)
61
- @loop_wait_time = amount || [loop_wait_time * BACK_OFF_RATIO, BACK_OFF_MAX].min
62
- end
63
-
64
- protected
65
-
66
- attr_writer \
67
- :loop_back_off_max,
68
- :loop_back_off_ratio,
69
- :loop_base_interval
70
-
71
- def mutex
72
- @mutex ||= Mutex.new
73
- end
74
-
75
- private
76
-
77
- def perform_loop
78
- @run_loop = true
79
-
80
- loop do
81
- if work_pending?
82
- # Run the task
83
- yield
84
-
85
- # Reset the wait interval
86
- loop_back_off!(loop_base_interval)
87
- elsif loop_back_off?
88
- # Back off the wait interval a bit
89
- loop_back_off!
90
- end
91
-
92
- # Wait for an interval, unless shutdown has been signaled.
93
- mutex.synchronize do
94
- return unless run_loop? || work_pending?
95
- shutdown.wait(mutex, loop_wait_time) if run_loop?
96
- end
97
- end
98
- end
99
-
100
- def shutdown
101
- @shutdown ||= ConditionVariable.new
102
- end
103
- end
104
- end
105
- end
@@ -1,48 +0,0 @@
1
- require 'ddtrace/workers/async'
2
- require 'ddtrace/workers/loop'
3
-
4
- module Datadog
5
- module Workers
6
- # Adds polling (async looping) behavior to workers
7
- module Polling
8
- SHUTDOWN_TIMEOUT = 1
9
-
10
- def self.included(base)
11
- base.send(:include, Workers::IntervalLoop)
12
- base.send(:include, Workers::Async::Thread)
13
- base.send(:prepend, PrependedMethods)
14
- end
15
-
16
- # Methods that must be prepended
17
- module PrependedMethods
18
- def perform(*args)
19
- super if enabled?
20
- end
21
- end
22
-
23
- def stop(force_stop = false, timeout = SHUTDOWN_TIMEOUT)
24
- if running?
25
- # Attempt graceful stop and wait
26
- stop_loop
27
- graceful = join(timeout)
28
-
29
- # If timeout and force stop...
30
- !graceful && force_stop ? terminate : graceful
31
- else
32
- false
33
- end
34
- end
35
-
36
- def enabled?
37
- @enabled = true unless instance_variable_defined?(:@enabled)
38
- @enabled
39
- end
40
-
41
- # Allow worker to be started
42
- def enabled=(value)
43
- # Coerce to boolean
44
- @enabled = (value == true)
45
- end
46
- end
47
- end
48
- end
@@ -1,39 +0,0 @@
1
- module Datadog
2
- module Workers
3
- # Adds queue behavior to workers, with a buffer
4
- # to which items can be queued then dequeued.
5
- module Queue
6
- def self.included(base)
7
- base.send(:prepend, PrependedMethods)
8
- end
9
-
10
- # Methods that must be prepended
11
- module PrependedMethods
12
- def perform(*args)
13
- super(*dequeue) if work_pending?
14
- end
15
- end
16
-
17
- def buffer
18
- @buffer ||= []
19
- end
20
-
21
- def enqueue(*args)
22
- buffer.push(args)
23
- end
24
-
25
- def dequeue
26
- buffer.shift
27
- end
28
-
29
- def work_pending?
30
- !buffer.empty?
31
- end
32
-
33
- protected
34
-
35
- attr_writer \
36
- :buffer
37
- end
38
- end
39
- end