newrelic_rpm 6.2.0.354 → 6.15.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (310) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +8 -0
  3. data/CHANGELOG.md +646 -6
  4. data/CONTRIBUTING.md +106 -19
  5. data/Gemfile +6 -2
  6. data/Guardfile +18 -1
  7. data/LICENSE +208 -38
  8. data/README.md +81 -85
  9. data/ROADMAP.md +24 -0
  10. data/Rakefile +2 -0
  11. data/THIRD_PARTY_NOTICES.md +213 -0
  12. data/bin/nrdebug +1 -1
  13. data/init.rb +1 -1
  14. data/install.rb +1 -1
  15. data/lib/new_relic/agent/adaptive_sampler.rb +1 -1
  16. data/lib/new_relic/agent/agent.rb +168 -185
  17. data/lib/new_relic/agent/agent_logger.rb +5 -1
  18. data/lib/new_relic/agent/attribute_filter.rb +8 -8
  19. data/lib/new_relic/agent/attribute_processing.rb +1 -1
  20. data/lib/new_relic/agent/attributes.rb +152 -0
  21. data/lib/new_relic/agent/audit_logger.rb +11 -1
  22. data/lib/new_relic/agent/autostart.rb +20 -15
  23. data/lib/new_relic/agent/chained_call.rb +1 -1
  24. data/lib/new_relic/agent/commands/agent_command.rb +1 -1
  25. data/lib/new_relic/agent/commands/agent_command_router.rb +3 -22
  26. data/lib/new_relic/agent/commands/thread_profiler_session.rb +1 -1
  27. data/lib/new_relic/agent/configuration/default_source.rb +234 -51
  28. data/lib/new_relic/agent/configuration/dotted_hash.rb +1 -1
  29. data/lib/new_relic/agent/configuration/environment_source.rb +5 -3
  30. data/lib/new_relic/agent/configuration/event_harvest_config.rb +45 -0
  31. data/lib/new_relic/agent/configuration/high_security_source.rb +2 -1
  32. data/lib/new_relic/agent/configuration/manager.rb +14 -10
  33. data/lib/new_relic/agent/configuration/manual_source.rb +1 -1
  34. data/lib/new_relic/agent/configuration/mask_defaults.rb +1 -1
  35. data/lib/new_relic/agent/configuration/security_policy_source.rb +1 -1
  36. data/lib/new_relic/agent/configuration/server_source.rb +37 -3
  37. data/lib/new_relic/agent/configuration/yaml_source.rb +12 -7
  38. data/lib/new_relic/agent/configuration.rb +1 -1
  39. data/lib/new_relic/agent/connect/request_builder.rb +61 -0
  40. data/lib/new_relic/agent/connect/response_handler.rb +61 -0
  41. data/lib/new_relic/agent/custom_event_aggregator.rb +1 -1
  42. data/lib/new_relic/agent/database/explain_plan_helpers.rb +1 -1
  43. data/lib/new_relic/agent/database/obfuscation_helpers.rb +2 -2
  44. data/lib/new_relic/agent/database/obfuscator.rb +1 -1
  45. data/lib/new_relic/agent/database/postgres_explain_obfuscator.rb +1 -1
  46. data/lib/new_relic/agent/database.rb +2 -3
  47. data/lib/new_relic/agent/database_adapter.rb +33 -0
  48. data/lib/new_relic/agent/datastores/metric_helper.rb +1 -1
  49. data/lib/new_relic/agent/datastores/mongo/event_formatter.rb +3 -3
  50. data/lib/new_relic/agent/datastores/mongo/metric_translator.rb +1 -1
  51. data/lib/new_relic/agent/datastores/mongo/obfuscator.rb +9 -9
  52. data/lib/new_relic/agent/datastores/mongo/statement_formatter.rb +1 -1
  53. data/lib/new_relic/agent/datastores/mongo.rb +2 -2
  54. data/lib/new_relic/agent/datastores/redis.rb +1 -1
  55. data/lib/new_relic/agent/datastores.rb +1 -1
  56. data/lib/new_relic/agent/deprecator.rb +1 -1
  57. data/lib/new_relic/agent/{cross_app_payload.rb → distributed_tracing/cross_app_payload.rb} +3 -2
  58. data/lib/new_relic/agent/{cross_app_tracing.rb → distributed_tracing/cross_app_tracing.rb} +61 -46
  59. data/lib/new_relic/agent/distributed_tracing/distributed_trace_attributes.rb +84 -0
  60. data/lib/new_relic/agent/distributed_tracing/distributed_trace_metrics.rb +75 -0
  61. data/lib/new_relic/agent/{distributed_trace_payload.rb → distributed_tracing/distributed_trace_payload.rb} +25 -102
  62. data/lib/new_relic/agent/distributed_tracing/distributed_trace_transport_type.rb +39 -0
  63. data/lib/new_relic/agent/distributed_tracing/trace_context.rb +246 -0
  64. data/lib/new_relic/agent/distributed_tracing/trace_context_payload.rb +126 -0
  65. data/lib/new_relic/agent/distributed_tracing.rb +156 -7
  66. data/lib/new_relic/agent/encoding_normalizer.rb +1 -1
  67. data/lib/new_relic/agent/error_collector.rb +36 -19
  68. data/lib/new_relic/agent/error_event_aggregator.rb +10 -7
  69. data/lib/new_relic/agent/error_trace_aggregator.rb +2 -1
  70. data/lib/new_relic/agent/event_aggregator.rb +27 -33
  71. data/lib/new_relic/agent/event_buffer.rb +1 -1
  72. data/lib/new_relic/agent/event_listener.rb +1 -1
  73. data/lib/new_relic/agent/event_loop.rb +1 -1
  74. data/lib/new_relic/agent/external.rb +8 -8
  75. data/lib/new_relic/agent/guid_generator.rb +28 -0
  76. data/lib/new_relic/agent/harvester.rb +1 -1
  77. data/lib/new_relic/agent/heap.rb +1 -1
  78. data/lib/new_relic/agent/hostname.rb +9 -3
  79. data/lib/new_relic/agent/http_clients/abstract.rb +82 -0
  80. data/lib/new_relic/agent/http_clients/curb_wrappers.rb +25 -20
  81. data/lib/new_relic/agent/http_clients/excon_wrappers.rb +29 -14
  82. data/lib/new_relic/agent/http_clients/http_rb_wrappers.rb +18 -22
  83. data/lib/new_relic/agent/http_clients/httpclient_wrappers.rb +11 -12
  84. data/lib/new_relic/agent/http_clients/net_http_wrappers.rb +17 -5
  85. data/lib/new_relic/agent/http_clients/typhoeus_wrappers.rb +5 -7
  86. data/lib/new_relic/agent/http_clients/uri_util.rb +12 -11
  87. data/lib/new_relic/agent/instrumentation/action_cable_subscriber.rb +26 -46
  88. data/lib/new_relic/agent/instrumentation/action_controller_subscriber.rb +51 -75
  89. data/lib/new_relic/agent/instrumentation/action_view_subscriber.rb +81 -56
  90. data/lib/new_relic/agent/instrumentation/active_job.rb +1 -1
  91. data/lib/new_relic/agent/instrumentation/active_merchant.rb +1 -1
  92. data/lib/new_relic/agent/instrumentation/active_record.rb +85 -38
  93. data/lib/new_relic/agent/instrumentation/active_record_helper.rb +17 -6
  94. data/lib/new_relic/agent/instrumentation/active_record_notifications.rb +168 -0
  95. data/lib/new_relic/agent/instrumentation/active_record_prepend.rb +35 -11
  96. data/lib/new_relic/agent/instrumentation/active_record_subscriber.rb +46 -48
  97. data/lib/new_relic/agent/instrumentation/active_storage.rb +1 -1
  98. data/lib/new_relic/agent/instrumentation/active_storage_subscriber.rb +12 -8
  99. data/lib/new_relic/agent/instrumentation/acts_as_solr.rb +10 -9
  100. data/lib/new_relic/agent/instrumentation/authlogic.rb +1 -1
  101. data/lib/new_relic/agent/instrumentation/bunny.rb +48 -29
  102. data/lib/new_relic/agent/instrumentation/controller_instrumentation.rb +1 -1
  103. data/lib/new_relic/agent/instrumentation/curb.rb +66 -19
  104. data/lib/new_relic/agent/instrumentation/data_mapper.rb +4 -2
  105. data/lib/new_relic/agent/instrumentation/delayed_job_instrumentation.rb +3 -1
  106. data/lib/new_relic/agent/instrumentation/excon/connection.rb +7 -4
  107. data/lib/new_relic/agent/instrumentation/excon/middleware.rb +3 -2
  108. data/lib/new_relic/agent/instrumentation/excon.rb +2 -2
  109. data/lib/new_relic/agent/instrumentation/grape.rb +8 -14
  110. data/lib/new_relic/agent/instrumentation/http.rb +7 -4
  111. data/lib/new_relic/agent/instrumentation/httpclient.rb +6 -4
  112. data/lib/new_relic/agent/instrumentation/ignore_actions.rb +1 -1
  113. data/lib/new_relic/agent/instrumentation/memcache/dalli.rb +7 -3
  114. data/lib/new_relic/agent/instrumentation/memcache.rb +4 -2
  115. data/lib/new_relic/agent/instrumentation/merb/controller.rb +1 -1
  116. data/lib/new_relic/agent/instrumentation/merb/errors.rb +1 -1
  117. data/lib/new_relic/agent/instrumentation/middleware_proxy.rb +1 -1
  118. data/lib/new_relic/agent/instrumentation/middleware_tracing.rb +9 -7
  119. data/lib/new_relic/agent/instrumentation/mongo.rb +10 -4
  120. data/lib/new_relic/agent/instrumentation/mongodb_command_subscriber.rb +36 -3
  121. data/lib/new_relic/agent/instrumentation/net.rb +48 -28
  122. data/lib/new_relic/agent/instrumentation/net_prepend.rb +40 -0
  123. data/lib/new_relic/agent/instrumentation/notifications_subscriber.rb +100 -0
  124. data/lib/new_relic/agent/instrumentation/padrino.rb +3 -1
  125. data/lib/new_relic/agent/instrumentation/passenger_instrumentation.rb +1 -1
  126. data/lib/new_relic/agent/instrumentation/queue_time.rb +1 -1
  127. data/lib/new_relic/agent/instrumentation/rack.rb +3 -1
  128. data/lib/new_relic/agent/instrumentation/rails/action_controller.rb +1 -1
  129. data/lib/new_relic/agent/instrumentation/rails/action_web_service.rb +1 -1
  130. data/lib/new_relic/agent/instrumentation/rails3/action_controller.rb +1 -1
  131. data/lib/new_relic/agent/instrumentation/rails_middleware.rb +1 -1
  132. data/lib/new_relic/agent/instrumentation/{rails5 → rails_notifications}/action_cable.rb +6 -7
  133. data/lib/new_relic/agent/instrumentation/{rails5 → rails_notifications}/action_controller.rb +4 -4
  134. data/lib/new_relic/agent/instrumentation/{rails5 → rails_notifications}/action_view.rb +4 -4
  135. data/lib/new_relic/agent/instrumentation/rainbows_instrumentation.rb +1 -1
  136. data/lib/new_relic/agent/instrumentation/rake.rb +2 -1
  137. data/lib/new_relic/agent/instrumentation/redis.rb +12 -6
  138. data/lib/new_relic/agent/instrumentation/resque.rb +4 -1
  139. data/lib/new_relic/agent/instrumentation/sequel.rb +1 -1
  140. data/lib/new_relic/agent/instrumentation/sequel_helper.rb +1 -1
  141. data/lib/new_relic/agent/instrumentation/sidekiq.rb +48 -24
  142. data/lib/new_relic/agent/instrumentation/sinatra/ignorer.rb +1 -1
  143. data/lib/new_relic/agent/instrumentation/sinatra/transaction_namer.rb +1 -1
  144. data/lib/new_relic/agent/instrumentation/sinatra.rb +1 -2
  145. data/lib/new_relic/agent/instrumentation/sunspot.rb +1 -1
  146. data/lib/new_relic/agent/instrumentation/typhoeus.rb +24 -7
  147. data/lib/new_relic/agent/instrumentation.rb +1 -1
  148. data/lib/new_relic/agent/internal_agent_error.rb +1 -1
  149. data/lib/new_relic/agent/javascript_instrumentor.rb +2 -2
  150. data/lib/new_relic/agent/log_once.rb +1 -1
  151. data/lib/new_relic/agent/logging.rb +139 -0
  152. data/lib/new_relic/agent/memory_logger.rb +1 -1
  153. data/lib/new_relic/agent/messaging.rb +6 -74
  154. data/lib/new_relic/agent/method_tracer.rb +10 -8
  155. data/lib/new_relic/agent/method_tracer_helpers.rb +3 -3
  156. data/lib/new_relic/agent/monitors/cross_app_monitor.rb +110 -0
  157. data/lib/new_relic/agent/monitors/distributed_tracing_monitor.rb +27 -0
  158. data/lib/new_relic/agent/{inbound_request_monitor.rb → monitors/inbound_request_monitor.rb} +4 -4
  159. data/lib/new_relic/agent/{synthetics_monitor.rb → monitors/synthetics_monitor.rb} +3 -5
  160. data/lib/new_relic/agent/monitors.rb +27 -0
  161. data/lib/new_relic/agent/new_relic_service/encoders.rb +1 -1
  162. data/lib/new_relic/agent/new_relic_service/json_marshaller.rb +1 -1
  163. data/lib/new_relic/agent/new_relic_service/marshaller.rb +1 -1
  164. data/lib/new_relic/agent/new_relic_service/security_policy_settings.rb +1 -1
  165. data/lib/new_relic/agent/new_relic_service.rb +34 -14
  166. data/lib/new_relic/agent/noticible_error.rb +22 -0
  167. data/lib/new_relic/agent/null_logger.rb +1 -1
  168. data/lib/new_relic/agent/obfuscator.rb +1 -1
  169. data/lib/new_relic/agent/parameter_filtering.rb +19 -6
  170. data/lib/new_relic/agent/payload_metric_mapping.rb +1 -1
  171. data/lib/new_relic/agent/pipe_channel_manager.rb +1 -1
  172. data/lib/new_relic/agent/pipe_service.rb +1 -1
  173. data/lib/new_relic/agent/prepend_supportability.rb +1 -1
  174. data/lib/new_relic/agent/priority_sampled_buffer.rb +9 -4
  175. data/lib/new_relic/agent/range_extensions.rb +1 -1
  176. data/lib/new_relic/agent/rules_engine/replacement_rule.rb +1 -1
  177. data/lib/new_relic/agent/rules_engine/segment_terms_rule.rb +1 -1
  178. data/lib/new_relic/agent/rules_engine.rb +1 -1
  179. data/lib/new_relic/agent/sampler.rb +1 -1
  180. data/lib/new_relic/agent/sampler_collection.rb +1 -1
  181. data/lib/new_relic/agent/samplers/cpu_sampler.rb +1 -1
  182. data/lib/new_relic/agent/samplers/delayed_job_sampler.rb +1 -1
  183. data/lib/new_relic/agent/samplers/memory_sampler.rb +2 -2
  184. data/lib/new_relic/agent/samplers/object_sampler.rb +1 -1
  185. data/lib/new_relic/agent/samplers/vm_sampler.rb +1 -1
  186. data/lib/new_relic/agent/span_event_aggregator.rb +3 -5
  187. data/lib/new_relic/agent/span_event_primitive.rb +108 -54
  188. data/lib/new_relic/agent/sql_sampler.rb +6 -6
  189. data/lib/new_relic/agent/stats.rb +1 -1
  190. data/lib/new_relic/agent/stats_engine/gc_profiler.rb +2 -2
  191. data/lib/new_relic/agent/stats_engine/stats_hash.rb +1 -1
  192. data/lib/new_relic/agent/stats_engine.rb +1 -1
  193. data/lib/new_relic/agent/supported_versions.rb +3 -3
  194. data/lib/new_relic/agent/synthetics_event_aggregator.rb +1 -1
  195. data/lib/new_relic/agent/system_info.rb +13 -4
  196. data/lib/new_relic/agent/threading/agent_thread.rb +1 -1
  197. data/lib/new_relic/agent/threading/backtrace_node.rb +1 -1
  198. data/lib/new_relic/agent/threading/backtrace_service.rb +4 -4
  199. data/lib/new_relic/agent/threading/thread_profile.rb +10 -24
  200. data/lib/new_relic/agent/timestamp_sampled_buffer.rb +1 -1
  201. data/lib/new_relic/agent/tracer.rb +66 -19
  202. data/lib/new_relic/agent/transaction/abstract_segment.rb +32 -5
  203. data/lib/new_relic/agent/transaction/datastore_segment.rb +1 -1
  204. data/lib/new_relic/agent/transaction/distributed_tracer.rb +177 -0
  205. data/lib/new_relic/agent/transaction/distributed_tracing.rb +58 -147
  206. data/lib/new_relic/agent/transaction/external_request_segment.rb +32 -39
  207. data/lib/new_relic/agent/transaction/message_broker_segment.rb +5 -12
  208. data/lib/new_relic/agent/transaction/request_attributes.rb +1 -1
  209. data/lib/new_relic/agent/transaction/segment.rb +28 -2
  210. data/lib/new_relic/agent/transaction/slowest_sample_buffer.rb +1 -1
  211. data/lib/new_relic/agent/transaction/synthetics_sample_buffer.rb +1 -1
  212. data/lib/new_relic/agent/transaction/trace.rb +6 -13
  213. data/lib/new_relic/agent/transaction/trace_builder.rb +1 -2
  214. data/lib/new_relic/agent/transaction/trace_context.rb +168 -0
  215. data/lib/new_relic/agent/transaction/trace_node.rb +11 -9
  216. data/lib/new_relic/agent/transaction/tracing.rb +1 -1
  217. data/lib/new_relic/agent/transaction/transaction_sample_buffer.rb +1 -1
  218. data/lib/new_relic/agent/transaction.rb +104 -84
  219. data/lib/new_relic/agent/transaction_error_primitive.rb +11 -16
  220. data/lib/new_relic/agent/transaction_event_aggregator.rb +1 -1
  221. data/lib/new_relic/agent/transaction_event_primitive.rb +29 -40
  222. data/lib/new_relic/agent/transaction_event_recorder.rb +4 -4
  223. data/lib/new_relic/agent/transaction_metrics.rb +1 -1
  224. data/lib/new_relic/agent/transaction_sampler.rb +2 -6
  225. data/lib/new_relic/agent/transaction_time_aggregator.rb +1 -1
  226. data/lib/new_relic/agent/utilization/aws.rb +1 -1
  227. data/lib/new_relic/agent/utilization/azure.rb +1 -1
  228. data/lib/new_relic/agent/utilization/gcp.rb +1 -1
  229. data/lib/new_relic/agent/utilization/pcf.rb +1 -1
  230. data/lib/new_relic/agent/utilization/vendor.rb +1 -1
  231. data/lib/new_relic/agent/utilization_data.rb +1 -1
  232. data/lib/new_relic/agent/vm/jruby_vm.rb +1 -1
  233. data/lib/new_relic/agent/vm/monotonic_gc_profiler.rb +1 -1
  234. data/lib/new_relic/agent/vm/mri_vm.rb +7 -5
  235. data/lib/new_relic/agent/vm/snapshot.rb +1 -1
  236. data/lib/new_relic/agent/vm.rb +1 -1
  237. data/lib/new_relic/agent/worker_loop.rb +1 -1
  238. data/lib/new_relic/agent.rb +98 -8
  239. data/lib/new_relic/cli/command.rb +1 -1
  240. data/lib/new_relic/cli/commands/deployments.rb +2 -3
  241. data/lib/new_relic/cli/commands/install.rb +4 -3
  242. data/lib/new_relic/coerce.rb +32 -7
  243. data/lib/new_relic/collection_helper.rb +1 -1
  244. data/lib/new_relic/constants.rb +42 -0
  245. data/lib/new_relic/control/class_methods.rb +8 -2
  246. data/lib/new_relic/control/frameworks/external.rb +1 -1
  247. data/lib/new_relic/control/frameworks/merb.rb +1 -1
  248. data/lib/new_relic/control/frameworks/rails.rb +1 -1
  249. data/lib/new_relic/control/frameworks/rails3.rb +1 -1
  250. data/lib/new_relic/control/frameworks/rails4.rb +1 -1
  251. data/lib/new_relic/control/frameworks/{rails5.rb → rails_notifications.rb} +2 -2
  252. data/lib/new_relic/control/frameworks/ruby.rb +1 -1
  253. data/lib/new_relic/control/frameworks/sinatra.rb +1 -1
  254. data/lib/new_relic/control/frameworks.rb +1 -1
  255. data/lib/new_relic/control/instance_methods.rb +11 -2
  256. data/lib/new_relic/control/instrumentation.rb +1 -1
  257. data/lib/new_relic/control/server_methods.rb +1 -1
  258. data/lib/new_relic/control.rb +1 -1
  259. data/lib/new_relic/delayed_job_injection.rb +1 -1
  260. data/lib/new_relic/dependency_detection.rb +9 -5
  261. data/lib/new_relic/environment_report.rb +2 -4
  262. data/lib/new_relic/helper.rb +1 -1
  263. data/lib/new_relic/language_support.rb +1 -1
  264. data/lib/new_relic/latest_changes.rb +2 -2
  265. data/lib/new_relic/local_environment.rb +1 -1
  266. data/lib/new_relic/metric_data.rb +1 -1
  267. data/lib/new_relic/metric_spec.rb +1 -1
  268. data/lib/new_relic/noticed_error.rb +39 -18
  269. data/lib/new_relic/rack/agent_hooks.rb +1 -1
  270. data/lib/new_relic/rack/agent_middleware.rb +1 -1
  271. data/lib/new_relic/rack/browser_monitoring.rb +16 -9
  272. data/lib/new_relic/rack.rb +1 -1
  273. data/lib/new_relic/recipes/capistrano3.rb +1 -1
  274. data/lib/new_relic/recipes/capistrano_legacy.rb +1 -1
  275. data/lib/new_relic/recipes.rb +1 -1
  276. data/lib/new_relic/supportability_helper.rb +17 -1
  277. data/lib/new_relic/version.rb +2 -2
  278. data/lib/newrelic_rpm.rb +1 -1
  279. data/lib/sequel/extensions/newrelic_instrumentation.rb +1 -1
  280. data/lib/sequel/plugins/newrelic_instrumentation.rb +1 -1
  281. data/lib/tasks/all.rb +1 -1
  282. data/lib/tasks/config.rake +1 -2
  283. data/lib/tasks/multiverse.rb +35 -1
  284. data/lib/tasks/newrelic.rb +1 -1
  285. data/lib/tasks/tests.rake +6 -1
  286. data/newrelic_rpm.gemspec +22 -10
  287. data/recipes/newrelic.rb +1 -1
  288. data/test/agent_helper.rb +356 -76
  289. metadata +116 -52
  290. data/.travis.yml +0 -153
  291. data/lib/new_relic/agent/commands/xray_session.rb +0 -55
  292. data/lib/new_relic/agent/commands/xray_session_collection.rb +0 -161
  293. data/lib/new_relic/agent/cross_app_monitor.rb +0 -110
  294. data/lib/new_relic/agent/distributed_trace_monitor.rb +0 -40
  295. data/lib/new_relic/agent/http_clients/abstract_request.rb +0 -31
  296. data/lib/new_relic/agent/instrumentation/active_record_4.rb +0 -42
  297. data/lib/new_relic/agent/instrumentation/active_record_5.rb +0 -41
  298. data/lib/new_relic/agent/instrumentation/evented_subscriber.rb +0 -104
  299. data/lib/new_relic/agent/instrumentation/rails4/action_controller.rb +0 -32
  300. data/lib/new_relic/agent/instrumentation/rails4/action_view.rb +0 -27
  301. data/lib/new_relic/agent/transaction/attributes.rb +0 -154
  302. data/lib/new_relic/agent/transaction/xray_sample_buffer.rb +0 -64
  303. data/lib/new_relic/build.rb +0 -2
  304. data/lib/new_relic/control/frameworks/rails6.rb +0 -14
  305. data/lib/new_relic/metrics.rb +0 -13
  306. data/lib/tasks/versions.html.erb +0 -28
  307. data/lib/tasks/versions.postface.html +0 -8
  308. data/lib/tasks/versions.preface.html +0 -9
  309. data/lib/tasks/versions.rake +0 -65
  310. data/lib/tasks/versions.txt.erb +0 -14
@@ -1,6 +1,7 @@
1
1
  # encoding: utf-8
2
2
  # This file is distributed under New Relic's license terms.
3
- # See https://github.com/newrelic/rpm/blob/master/LICENSE for complete details.
3
+ # See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details.
4
+ # frozen_string_literal: true
4
5
 
5
6
  require 'new_relic/agent/transaction/segment'
6
7
  require 'new_relic/agent/http_clients/uri_util'
@@ -14,17 +15,24 @@ module NewRelic
14
15
  #
15
16
  # @api public
16
17
  class ExternalRequestSegment < Segment
17
- attr_reader :library, :uri, :procedure
18
+ NR_SYNTHETICS_HEADER = 'X-NewRelic-Synthetics'
19
+ APP_DATA_KEY = 'NewRelicAppData'
18
20
 
19
- NR_SYNTHETICS_HEADER = 'X-NewRelic-Synthetics'.freeze
21
+ EXTERNAL_ALL = "External/all"
22
+ EXTERNAL_ALL_WEB = "External/allWeb"
23
+ EXTERNAL_ALL_OTHER = "External/allOther"
24
+ MISSING_STATUS_CODE = "MissingHTTPStatusCode"
20
25
 
26
+ attr_reader :library, :uri, :procedure
27
+ attr_reader :http_status_code
21
28
 
22
29
  def initialize library, uri, procedure, start_time = nil # :nodoc:
23
30
  @library = library
24
- @uri = HTTPClients::URIUtil.parse_and_normalize_url(uri)
31
+ @uri = HTTPClients::URIUtil.obfuscated_uri(uri)
25
32
  @procedure = procedure
26
33
  @host_header = nil
27
34
  @app_data = nil
35
+ @http_status_code = nil
28
36
  super(nil, nil, start_time)
29
37
  end
30
38
 
@@ -52,8 +60,7 @@ module NewRelic
52
60
 
53
61
  return unless record_metrics?
54
62
 
55
- insert_cross_app_header request
56
- insert_distributed_trace_header request
63
+ transaction.distributed_tracer.insert_headers request
57
64
  rescue => e
58
65
  NewRelic::Agent.logger.error "Error in add_request_headers", e
59
66
  end
@@ -99,10 +106,6 @@ module NewRelic
99
106
  @app_data && @app_data[1]
100
107
  end
101
108
 
102
- EXTERNAL_TRANSACTION_PREFIX = 'ExternalTransaction/'.freeze
103
- SLASH = '/'.freeze
104
- APP_DATA_KEY = 'NewRelicAppData'.freeze
105
-
106
109
  # Obtain an obfuscated +String+ suitable for delivery across public networks that identifies this application
107
110
  # and transaction to another application which is also running a New Relic agent. This +String+ can be processed
108
111
  # by +process_request_metadata+ on the receiving application.
@@ -124,14 +127,14 @@ module NewRelic
124
127
  NewRelicTransaction: [
125
128
  transaction.guid,
126
129
  false,
127
- transaction.cat_trip_id,
128
- transaction.cat_path_hash
130
+ transaction.distributed_tracer.cat_trip_id,
131
+ transaction.distributed_tracer.cat_path_hash
129
132
  ]
130
133
  }
131
134
 
132
135
  # flag cross app in the state so transaction knows to add bits to paylaod
133
136
  #
134
- transaction.is_cross_app_caller = true
137
+ transaction.distributed_tracer.is_cross_app_caller = true
135
138
 
136
139
  # add Synthetics header if we have it
137
140
  #
@@ -179,14 +182,29 @@ module NewRelic
179
182
  super
180
183
  end
181
184
 
185
+ def process_response_headers response # :nodoc:
186
+ set_http_status_code response
187
+ read_response_headers response
188
+ end
189
+
182
190
  private
183
191
 
192
+ # Only sets the http_status_code if response.status_code is non-empty value
193
+ def set_http_status_code response
194
+ if response.respond_to? :status_code
195
+ @http_status_code = response.status_code if response.has_status_code?
196
+ else
197
+ NewRelic::Agent.logger.warn "Cannot extract HTTP Status Code from response #{response.class.to_s}"
198
+ NewRelic::Agent.record_metric "#{name}/#{MISSING_STATUS_CODE}", 1
199
+ end
200
+ end
201
+
184
202
  def insert_synthetics_header request, header
185
203
  request[NR_SYNTHETICS_HEADER] = header
186
204
  end
187
205
 
188
206
  def segment_complete
189
- params[:uri] = HTTPClients::URIUtil.filter_uri(uri)
207
+ params[:uri] = uri.to_s
190
208
  if cross_app_request?
191
209
  params[:transaction_guid] = transaction_guid
192
210
  end
@@ -200,27 +218,6 @@ module NewRelic
200
218
  end
201
219
  end
202
220
 
203
- def insert_cross_app_header request
204
- return unless CrossAppTracing.cross_app_enabled?
205
-
206
- transaction.is_cross_app_caller = true
207
- txn_guid = transaction.guid
208
- trip_id = transaction && transaction.cat_trip_id
209
- path_hash = transaction && transaction.cat_path_hash
210
-
211
- CrossAppTracing.insert_request_headers request, txn_guid, trip_id, path_hash
212
- end
213
-
214
- NEWRELIC_TRACE_HEADER = "newrelic".freeze
215
-
216
- def insert_distributed_trace_header request
217
- return unless Agent.config[:'distributed_tracing.enabled']
218
- payload = transaction.create_distributed_trace_payload
219
- request[NEWRELIC_TRACE_HEADER] = payload.http_safe if payload
220
- end
221
-
222
- EXTERNAL_ALL = "External/all".freeze
223
-
224
221
  def add_unscoped_metrics
225
222
  @unscoped_metrics = [ EXTERNAL_ALL,
226
223
  "External/#{host}/all",
@@ -232,9 +229,6 @@ module NewRelic
232
229
  end
233
230
  end
234
231
 
235
- EXTERNAL_ALL_WEB = "External/allWeb".freeze
236
- EXTERNAL_ALL_OTHER = "External/allOther".freeze
237
-
238
232
  def suffixed_rollup_metric
239
233
  if Transaction.recording_web_transaction?
240
234
  EXTERNAL_ALL_WEB
@@ -258,7 +252,6 @@ module NewRelic
258
252
  def record_span_event
259
253
  aggregator = ::NewRelic::Agent.agent.span_event_aggregator
260
254
  priority = transaction.priority
261
-
262
255
  aggregator.record(priority: priority) do
263
256
  SpanEventPrimitive.for_external_request_segment(self)
264
257
  end
@@ -1,9 +1,9 @@
1
1
  # encoding: utf-8
2
2
  # This file is distributed under New Relic's license terms.
3
- # See https://github.com/newrelic/rpm/blob/master/LICENSE for complete details.
3
+ # See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details.
4
4
 
5
5
  require 'new_relic/agent/transaction/segment'
6
- require 'new_relic/agent/cross_app_tracing'
6
+ require 'new_relic/agent/distributed_tracing/cross_app_tracing'
7
7
 
8
8
  module NewRelic
9
9
  module Agent
@@ -89,18 +89,11 @@ module NewRelic
89
89
  @name
90
90
  end
91
91
 
92
- NEWRELIC_TRACE_KEY = "newrelic".freeze
93
-
94
- def insert_distributed_trace_header
95
- return unless Agent.config[:'distributed_tracing.enabled']
96
- payload = transaction.create_distributed_trace_payload
97
- headers[NEWRELIC_TRACE_KEY] = payload.http_safe if payload
98
- end
99
-
100
92
  def transaction_assigned
101
93
  if headers && transaction && action == :produce && record_metrics?
102
- insert_distributed_trace_header
103
- transaction.add_message_cat_headers headers if CrossAppTracing.cross_app_enabled?
94
+ transaction.distributed_tracer.insert_distributed_trace_header headers
95
+ transaction.distributed_tracer.insert_cat_headers headers
96
+ transaction.distributed_tracer.log_request_headers headers
104
97
  end
105
98
  rescue => e
106
99
  NewRelic::Agent.logger.error "Error during message header processing", e
@@ -1,6 +1,6 @@
1
1
  # encoding: utf-8
2
2
  # This file is distributed under New Relic's license terms.
3
- # See https://github.com/newrelic/rpm/blob/master/LICENSE for complete details.
3
+ # See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details.
4
4
 
5
5
  require 'new_relic/agent/http_clients/uri_util'
6
6
 
@@ -1,9 +1,10 @@
1
1
  # encoding: utf-8
2
2
  # This file is distributed under New Relic's license terms.
3
- # See https://github.com/newrelic/rpm/blob/master/LICENSE for complete details.
3
+ # See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details.
4
4
 
5
5
  require 'new_relic/agent/transaction/abstract_segment'
6
6
  require 'new_relic/agent/span_event_primitive'
7
+ require 'new_relic/agent/attributes'
7
8
 
8
9
  module NewRelic
9
10
  module Agent
@@ -12,13 +13,38 @@ module NewRelic
12
13
  # unscoped_metrics can be nil, a string, or array. we do this to save
13
14
  # object allocations. if allocations weren't important then we would
14
15
  # initialize it as an array that would be empty, have one item, or many items.
15
- attr_reader :unscoped_metrics
16
+ attr_reader :unscoped_metrics, :custom_transaction_attributes
16
17
 
17
18
  def initialize name=nil, unscoped_metrics=nil, start_time=nil
18
19
  @unscoped_metrics = unscoped_metrics
19
20
  super name, start_time
20
21
  end
21
22
 
23
+ def attributes
24
+ @attributes ||= Attributes.new(NewRelic::Agent.instance.attribute_filter)
25
+ end
26
+
27
+ def add_agent_attribute(key, value, default_destinations=AttributeFilter::DST_SPAN_EVENTS)
28
+ attributes.add_agent_attribute(key, value, default_destinations)
29
+ end
30
+
31
+ def self.merge_untrusted_agent_attributes(attributes, prefix, default_destinations)
32
+ if segment = NewRelic::Agent::Tracer.current_segment
33
+ segment.merge_untrusted_agent_attributes(attributes, prefix, default_destinations)
34
+ else
35
+ NewRelic::Agent.logger.debug "Attempted to merge untrusted attributes without segment"
36
+ end
37
+ end
38
+
39
+ def merge_untrusted_agent_attributes(agent_attributes, prefix, default_destinations)
40
+ return if agent_attributes.nil?
41
+ attributes.merge_untrusted_agent_attributes(agent_attributes, prefix, default_destinations)
42
+ end
43
+
44
+ def add_custom_attributes(p)
45
+ attributes.merge_custom_attributes(p)
46
+ end
47
+
22
48
  private
23
49
 
24
50
  def record_metrics
@@ -1,6 +1,6 @@
1
1
  # encoding: utf-8
2
2
  # This file is distributed under New Relic's license terms.
3
- # See https://github.com/newrelic/rpm/blob/master/LICENSE for complete details.
3
+ # See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details.
4
4
 
5
5
  require 'new_relic/agent/transaction/transaction_sample_buffer'
6
6
 
@@ -1,6 +1,6 @@
1
1
  # encoding: utf-8
2
2
  # This file is distributed under New Relic's license terms.
3
- # See https://github.com/newrelic/rpm/blob/master/LICENSE for complete details.
3
+ # See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details.
4
4
 
5
5
  require 'new_relic/agent/transaction/transaction_sample_buffer'
6
6
 
@@ -1,6 +1,6 @@
1
1
  # encoding: utf-8
2
2
  # This file is distributed under New Relic's license terms.
3
- # See https://github.com/newrelic/rpm/blob/master/LICENSE for complete details.
3
+ # See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details.
4
4
 
5
5
  require 'new_relic/agent/transaction/trace_node'
6
6
 
@@ -11,7 +11,7 @@ module NewRelic
11
11
  class FinishedTraceError < StandardError; end
12
12
 
13
13
  attr_reader :start_time, :root_node
14
- attr_accessor :transaction_name, :guid, :xray_session_id, :attributes,
14
+ attr_accessor :transaction_name, :guid, :attributes,
15
15
  :node_count, :finished, :threshold, :profile
16
16
 
17
17
  ROOT = "ROOT".freeze
@@ -40,11 +40,6 @@ module NewRelic
40
40
  self.root_node.duration
41
41
  end
42
42
 
43
- def forced?
44
- return true if NewRelic::Coerce.int_or_nil(xray_session_id)
45
- false
46
- end
47
-
48
43
  def synthetics_resource_id
49
44
  intrinsic_attributes = attributes.intrinsic_attributes_for(NewRelic::Agent::AttributeFilter::DST_TRANSACTION_TRACER)
50
45
  intrinsic_attributes[:synthetics_resource_id]
@@ -126,13 +121,11 @@ module NewRelic
126
121
  }
127
122
  end
128
123
 
129
- EMPTY_HASH = {}.freeze
130
-
131
124
  def trace_tree attributes_hash
132
125
  [
133
126
  NewRelic::Coerce.float(self.start_time),
134
- EMPTY_HASH,
135
- EMPTY_HASH,
127
+ NewRelic::EMPTY_HASH,
128
+ NewRelic::EMPTY_HASH,
136
129
  self.root_node.to_array,
137
130
  attributes_hash
138
131
  ]
@@ -148,8 +141,8 @@ module NewRelic
148
141
  encoder.encode(trace_tree(attributes_hash)),
149
142
  NewRelic::Coerce.string(self.guid),
150
143
  nil,
151
- forced?,
152
- NewRelic::Coerce.int_or_nil(xray_session_id),
144
+ false, # forced?,
145
+ nil, # NewRelic::Coerce.int_or_nil(xray_session_id),
153
146
  NewRelic::Coerce.string(self.synthetics_resource_id)
154
147
  ]
155
148
  end
@@ -1,6 +1,6 @@
1
1
  # encoding: utf-8
2
2
  # This file is distributed under New Relic's license terms.
3
- # See https://github.com/newrelic/rpm/blob/master/LICENSE for complete details.
3
+ # See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details.
4
4
 
5
5
  require 'new_relic/helper'
6
6
  require 'new_relic/agent/transaction/trace'
@@ -48,7 +48,6 @@ module NewRelic
48
48
  trace.guid = transaction.guid
49
49
  trace.attributes = transaction.attributes
50
50
  trace.threshold = transaction.threshold
51
- trace.xray_session_id = transaction.xray_session_id
52
51
  trace.finished = true
53
52
  end
54
53
  end
@@ -0,0 +1,168 @@
1
+ # encoding: utf-8
2
+ # This file is distributed under New Relic's license terms.
3
+ # See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details.
4
+ # frozen_string_literal: true
5
+
6
+ module NewRelic
7
+ module Agent
8
+ class Transaction
9
+ module TraceContext
10
+ include NewRelic::Coerce
11
+
12
+ module AccountHelpers
13
+ extend self
14
+
15
+ def trace_state_entry_key
16
+ @trace_state_entry_key ||= if Agent.config[:trusted_account_key]
17
+ "#{Agent.config[:trusted_account_key]}@nr".freeze
18
+ elsif Agent.config[:account_id]
19
+ "#{Agent.config[:account_id]}@nr".freeze
20
+ end
21
+ end
22
+ end
23
+
24
+ SUPPORTABILITY_PREFIX = "Supportability/TraceContext"
25
+ CREATE_PREFIX = "#{SUPPORTABILITY_PREFIX}/Create"
26
+ ACCEPT_PREFIX = "#{SUPPORTABILITY_PREFIX}/Accept"
27
+ TRACESTATE_PREFIX = "#{SUPPORTABILITY_PREFIX}/TraceState"
28
+
29
+ CREATE_SUCCESS_METRIC = "#{CREATE_PREFIX}/Success"
30
+ CREATE_EXCEPTION_METRIC = "#{CREATE_PREFIX}/Exception"
31
+
32
+ ACCEPT_SUCCESS_METRIC = "#{ACCEPT_PREFIX}/Success"
33
+ ACCEPT_EXCEPTION_METRIC = "#{ACCEPT_PREFIX}/Exception"
34
+ IGNORE_MULTIPLE_ACCEPT_METRIC = "#{ACCEPT_PREFIX}/Ignored/Multiple"
35
+ IGNORE_ACCEPT_AFTER_CREATE_METRIC = "#{ACCEPT_PREFIX}/Ignored/CreateBeforeAccept"
36
+
37
+ NO_NR_ENTRY_TRACESTATE_METRIC = "#{TRACESTATE_PREFIX}/NoNrEntry"
38
+ INVALID_TRACESTATE_PAYLOAD_METRIC = "#{TRACESTATE_PREFIX}/InvalidNrEntry"
39
+
40
+ attr_accessor :trace_context_header_data
41
+ attr_reader :trace_state_payload
42
+
43
+ def trace_parent_header_present? request
44
+ request[NewRelic::HTTP_TRACEPARENT_KEY]
45
+ end
46
+
47
+ def accept_trace_context_incoming_request request
48
+ header_data = NewRelic::Agent::DistributedTracing::TraceContext.parse(
49
+ format: NewRelic::FORMAT_RACK,
50
+ carrier: request,
51
+ trace_state_entry_key: AccountHelpers.trace_state_entry_key,
52
+ )
53
+ return if header_data.nil?
54
+
55
+ accept_trace_context header_data
56
+ end
57
+ private :accept_trace_context_incoming_request
58
+
59
+ def insert_trace_context_header header, format=NewRelic::FORMAT_NON_RACK
60
+ return unless Agent.config[:'distributed_tracing.enabled']
61
+
62
+ NewRelic::Agent::DistributedTracing::TraceContext.insert \
63
+ format: format,
64
+ carrier: header,
65
+ trace_id: transaction.trace_id.rjust(32, '0').downcase,
66
+ parent_id: transaction.current_segment.guid,
67
+ trace_flags: transaction.sampled? ? 0x1 : 0x0,
68
+ trace_state: create_trace_state
69
+
70
+ @trace_context_inserted = true
71
+
72
+ NewRelic::Agent.increment_metric CREATE_SUCCESS_METRIC
73
+ true
74
+ rescue Exception => e
75
+ NewRelic::Agent.increment_metric CREATE_EXCEPTION_METRIC
76
+ NewRelic::Agent.logger.warn "Failed to create trace context payload", e
77
+ false
78
+ end
79
+
80
+ def create_trace_state
81
+ entry_key = AccountHelpers.trace_state_entry_key.dup
82
+ payload = create_trace_state_payload
83
+
84
+ if payload
85
+ entry = NewRelic::Agent::DistributedTracing::TraceContext.create_trace_state_entry \
86
+ entry_key,
87
+ payload.to_s
88
+ else
89
+ entry = NewRelic::EMPTY_STR
90
+ end
91
+
92
+ trace_context_header_data ? trace_context_header_data.trace_state(entry) : entry
93
+ end
94
+
95
+ def create_trace_state_payload
96
+ unless Agent.config[:'distributed_tracing.enabled']
97
+ NewRelic::Agent.logger.warn "Not configured to create WC3 trace context payload"
98
+ return
99
+ end
100
+
101
+
102
+ span_guid = Agent.config[:'span_events.enabled'] ? transaction.current_segment.guid : nil
103
+ transaction_guid = Agent.config[:'analytics_events.enabled'] ? transaction.guid : nil
104
+
105
+ TraceContextPayload.create \
106
+ parent_account_id: Agent.config[:account_id],
107
+ parent_app_id: Agent.config[:primary_application_id],
108
+ transaction_id: transaction_guid,
109
+ sampled: transaction.sampled?,
110
+ priority: float!(transaction.priority, NewRelic::PRIORITY_PRECISION),
111
+ id: span_guid
112
+ end
113
+
114
+ def assign_trace_state_payload
115
+ payload = @trace_context_header_data.trace_state_payload
116
+ unless payload
117
+ NewRelic::Agent.increment_metric NO_NR_ENTRY_TRACESTATE_METRIC
118
+ return false
119
+ end
120
+ unless payload.valid?
121
+ NewRelic::Agent.increment_metric INVALID_TRACESTATE_PAYLOAD_METRIC
122
+ return false
123
+ end
124
+ @trace_state_payload = payload
125
+ end
126
+
127
+ def accept_trace_context header_data
128
+ return if ignore_trace_context?
129
+
130
+ @trace_context_header_data = header_data
131
+ transaction.trace_id = header_data.trace_id
132
+ transaction.parent_span_id = header_data.parent_id
133
+
134
+ return false unless payload = assign_trace_state_payload
135
+
136
+ transaction.distributed_tracer.parent_transaction_id = payload.transaction_id
137
+
138
+ unless payload.sampled.nil?
139
+ transaction.sampled = payload.sampled
140
+ transaction.priority = payload.priority if payload.priority
141
+ end
142
+ NewRelic::Agent.increment_metric ACCEPT_SUCCESS_METRIC
143
+ true
144
+ rescue => e
145
+ NewRelic::Agent.increment_metric ACCEPT_EXCEPTION_METRIC
146
+ NewRelic::Agent.logger.warn "Failed to accept trace context payload", e
147
+ false
148
+ end
149
+
150
+ def ignore_trace_context?
151
+ if trace_context_header_data
152
+ NewRelic::Agent.increment_metric IGNORE_MULTIPLE_ACCEPT_METRIC
153
+ return true
154
+ elsif trace_context_inserted?
155
+ NewRelic::Agent.increment_metric IGNORE_ACCEPT_AFTER_CREATE_METRIC
156
+ return true
157
+ end
158
+ false
159
+ end
160
+
161
+ def trace_context_inserted?
162
+ @trace_context_inserted ||= false
163
+ end
164
+
165
+ end
166
+ end
167
+ end
168
+ end