newrelic_rpm 5.7.0.350 → 9.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (476) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +15 -1
  3. data/.rubocop.yml +1919 -0
  4. data/.rubocop_todo.yml +100 -0
  5. data/.simplecov +15 -0
  6. data/.snyk +11 -0
  7. data/.yardopts +2 -0
  8. data/Brewfile +12 -0
  9. data/CHANGELOG.md +4056 -2339
  10. data/CONTRIBUTING.md +132 -19
  11. data/DOCKER.md +167 -0
  12. data/Dockerfile +10 -0
  13. data/Gemfile +5 -2
  14. data/Guardfile +22 -4
  15. data/LICENSE +202 -38
  16. data/README.md +87 -87
  17. data/Rakefile +27 -27
  18. data/THIRD_PARTY_NOTICES.md +28 -0
  19. data/Thorfile +5 -0
  20. data/bin/newrelic +3 -2
  21. data/bin/newrelic_cmd +1 -0
  22. data/bin/nrdebug +77 -54
  23. data/config.dot +5 -5
  24. data/docker-compose.yml +107 -0
  25. data/init.rb +5 -7
  26. data/install.rb +3 -3
  27. data/lefthook.yml +9 -0
  28. data/lib/new_relic/agent/adaptive_sampler.rb +14 -10
  29. data/lib/new_relic/agent/agent.rb +125 -969
  30. data/lib/new_relic/agent/agent_helpers/connect.rb +227 -0
  31. data/lib/new_relic/agent/agent_helpers/harvest.rb +153 -0
  32. data/lib/new_relic/agent/agent_helpers/shutdown.rb +72 -0
  33. data/lib/new_relic/agent/agent_helpers/special_startup.rb +74 -0
  34. data/lib/new_relic/agent/agent_helpers/start_worker_thread.rb +167 -0
  35. data/lib/new_relic/agent/agent_helpers/startup.rb +202 -0
  36. data/lib/new_relic/agent/agent_helpers/transmit.rb +76 -0
  37. data/lib/new_relic/agent/agent_logger.rb +26 -18
  38. data/lib/new_relic/agent/attribute_filter.rb +69 -52
  39. data/lib/new_relic/agent/attribute_processing.rb +8 -8
  40. data/lib/new_relic/agent/attributes.rb +153 -0
  41. data/lib/new_relic/agent/audit_logger.rb +19 -4
  42. data/lib/new_relic/agent/autostart.rb +34 -28
  43. data/lib/new_relic/agent/chained_call.rb +2 -2
  44. data/lib/new_relic/agent/commands/agent_command.rb +4 -4
  45. data/lib/new_relic/agent/commands/agent_command_router.rb +15 -33
  46. data/lib/new_relic/agent/commands/thread_profiler_session.rb +13 -11
  47. data/lib/new_relic/agent/configuration/default_source.rb +1480 -1053
  48. data/lib/new_relic/agent/configuration/dotted_hash.rb +7 -6
  49. data/lib/new_relic/agent/configuration/environment_source.rb +15 -11
  50. data/lib/new_relic/agent/configuration/event_harvest_config.rb +68 -0
  51. data/lib/new_relic/agent/configuration/high_security_source.rb +9 -9
  52. data/lib/new_relic/agent/configuration/manager.rb +96 -79
  53. data/lib/new_relic/agent/configuration/manual_source.rb +2 -2
  54. data/lib/new_relic/agent/configuration/mask_defaults.rb +4 -4
  55. data/lib/new_relic/agent/configuration/security_policy_source.rb +83 -86
  56. data/lib/new_relic/agent/configuration/server_source.rb +49 -12
  57. data/lib/new_relic/agent/configuration/yaml_source.rb +42 -13
  58. data/lib/new_relic/agent/configuration.rb +2 -2
  59. data/lib/new_relic/agent/connect/request_builder.rb +61 -0
  60. data/lib/new_relic/agent/connect/response_handler.rb +58 -0
  61. data/lib/new_relic/agent/custom_event_aggregator.rb +15 -15
  62. data/lib/new_relic/agent/database/explain_plan_helpers.rb +5 -6
  63. data/lib/new_relic/agent/database/obfuscation_helpers.rb +16 -15
  64. data/lib/new_relic/agent/database/obfuscator.rb +3 -3
  65. data/lib/new_relic/agent/database/postgres_explain_obfuscator.rb +4 -4
  66. data/lib/new_relic/agent/database.rb +44 -53
  67. data/lib/new_relic/agent/database_adapter.rb +35 -0
  68. data/lib/new_relic/agent/datastores/metric_helper.rb +18 -20
  69. data/lib/new_relic/agent/datastores/mongo/event_formatter.rb +9 -8
  70. data/lib/new_relic/agent/datastores/mongo/metric_translator.rb +7 -11
  71. data/lib/new_relic/agent/datastores/mongo.rb +7 -12
  72. data/lib/new_relic/agent/datastores/nosql_obfuscator.rb +41 -0
  73. data/lib/new_relic/agent/datastores/redis.rb +6 -12
  74. data/lib/new_relic/agent/datastores.rb +19 -23
  75. data/lib/new_relic/agent/deprecator.rb +2 -2
  76. data/lib/new_relic/agent/{cross_app_payload.rb → distributed_tracing/cross_app_payload.rb} +13 -12
  77. data/lib/new_relic/agent/{cross_app_tracing.rb → distributed_tracing/cross_app_tracing.rb} +87 -66
  78. data/lib/new_relic/agent/distributed_tracing/distributed_trace_attributes.rb +84 -0
  79. data/lib/new_relic/agent/distributed_tracing/distributed_trace_metrics.rb +75 -0
  80. data/lib/new_relic/agent/distributed_tracing/distributed_trace_payload.rb +163 -0
  81. data/lib/new_relic/agent/distributed_tracing/distributed_trace_transport_type.rb +38 -0
  82. data/lib/new_relic/agent/distributed_tracing/trace_context.rb +245 -0
  83. data/lib/new_relic/agent/distributed_tracing/trace_context_payload.rb +127 -0
  84. data/lib/new_relic/agent/distributed_tracing.rb +113 -32
  85. data/lib/new_relic/agent/encoding_normalizer.rb +5 -3
  86. data/lib/new_relic/agent/error_collector.rb +99 -63
  87. data/lib/new_relic/agent/error_event_aggregator.rb +10 -8
  88. data/lib/new_relic/agent/error_filter.rb +174 -0
  89. data/lib/new_relic/agent/error_trace_aggregator.rb +6 -4
  90. data/lib/new_relic/agent/event_aggregator.rb +43 -48
  91. data/lib/new_relic/agent/event_buffer.rb +8 -9
  92. data/lib/new_relic/agent/event_listener.rb +2 -3
  93. data/lib/new_relic/agent/event_loop.rb +27 -25
  94. data/lib/new_relic/agent/external.rb +20 -51
  95. data/lib/new_relic/agent/guid_generator.rb +30 -0
  96. data/lib/new_relic/agent/harvester.rb +5 -6
  97. data/lib/new_relic/agent/heap.rb +8 -10
  98. data/lib/new_relic/agent/hostname.rb +26 -5
  99. data/lib/new_relic/agent/http_clients/abstract.rb +81 -0
  100. data/lib/new_relic/agent/http_clients/curb_wrappers.rb +26 -26
  101. data/lib/new_relic/agent/http_clients/excon_wrappers.rb +31 -17
  102. data/lib/new_relic/agent/http_clients/http_rb_wrappers.rb +18 -23
  103. data/lib/new_relic/agent/http_clients/httpclient_wrappers.rb +12 -15
  104. data/lib/new_relic/agent/http_clients/net_http_wrappers.rb +24 -8
  105. data/lib/new_relic/agent/http_clients/typhoeus_wrappers.rb +9 -12
  106. data/lib/new_relic/agent/http_clients/uri_util.rb +12 -13
  107. data/lib/new_relic/agent/instrumentation/action_cable_subscriber.rb +22 -52
  108. data/lib/new_relic/agent/instrumentation/action_controller_other_subscriber.rb +39 -0
  109. data/lib/new_relic/agent/instrumentation/action_controller_subscriber.rb +59 -72
  110. data/lib/new_relic/agent/instrumentation/action_dispatch.rb +31 -0
  111. data/lib/new_relic/agent/instrumentation/action_dispatch_subscriber.rb +64 -0
  112. data/lib/new_relic/agent/instrumentation/action_mailbox.rb +30 -0
  113. data/lib/new_relic/agent/instrumentation/action_mailbox_subscriber.rb +33 -0
  114. data/lib/new_relic/agent/instrumentation/action_mailer.rb +30 -0
  115. data/lib/new_relic/agent/instrumentation/action_mailer_subscriber.rb +85 -0
  116. data/lib/new_relic/agent/instrumentation/action_view_subscriber.rb +86 -62
  117. data/lib/new_relic/agent/instrumentation/active_job.rb +38 -19
  118. data/lib/new_relic/agent/instrumentation/active_job_subscriber.rb +41 -0
  119. data/lib/new_relic/agent/instrumentation/active_merchant.rb +21 -7
  120. data/lib/new_relic/agent/instrumentation/active_record.rb +95 -46
  121. data/lib/new_relic/agent/instrumentation/active_record_helper.rb +82 -61
  122. data/lib/new_relic/agent/instrumentation/active_record_notifications.rb +155 -0
  123. data/lib/new_relic/agent/instrumentation/active_record_prepend.rb +36 -12
  124. data/lib/new_relic/agent/instrumentation/active_record_subscriber.rb +69 -64
  125. data/lib/new_relic/agent/instrumentation/active_storage.rb +8 -4
  126. data/lib/new_relic/agent/instrumentation/active_storage_subscriber.rb +11 -32
  127. data/lib/new_relic/agent/instrumentation/active_support.rb +27 -0
  128. data/lib/new_relic/agent/instrumentation/active_support_logger/chain.rb +23 -0
  129. data/lib/new_relic/agent/instrumentation/active_support_logger/instrumentation.rb +20 -0
  130. data/lib/new_relic/agent/instrumentation/active_support_logger/prepend.rb +12 -0
  131. data/lib/new_relic/agent/instrumentation/active_support_logger.rb +24 -0
  132. data/lib/new_relic/agent/instrumentation/active_support_subscriber.rb +41 -0
  133. data/lib/new_relic/agent/instrumentation/bunny/chain.rb +45 -0
  134. data/lib/new_relic/agent/instrumentation/bunny/instrumentation.rb +150 -0
  135. data/lib/new_relic/agent/instrumentation/bunny/prepend.rb +35 -0
  136. data/lib/new_relic/agent/instrumentation/bunny.rb +14 -134
  137. data/lib/new_relic/agent/instrumentation/concurrent_ruby/chain.rb +36 -0
  138. data/lib/new_relic/agent/instrumentation/concurrent_ruby/instrumentation.rb +21 -0
  139. data/lib/new_relic/agent/instrumentation/concurrent_ruby/prepend.rb +27 -0
  140. data/lib/new_relic/agent/instrumentation/concurrent_ruby.rb +31 -0
  141. data/lib/new_relic/agent/instrumentation/controller_instrumentation.rb +77 -61
  142. data/lib/new_relic/agent/instrumentation/curb/chain.rb +91 -0
  143. data/lib/new_relic/agent/instrumentation/curb/instrumentation.rb +221 -0
  144. data/lib/new_relic/agent/instrumentation/curb/prepend.rb +61 -0
  145. data/lib/new_relic/agent/instrumentation/curb.rb +15 -187
  146. data/lib/new_relic/agent/instrumentation/custom_events.rb +12 -0
  147. data/lib/new_relic/agent/instrumentation/custom_events_subscriber.rb +37 -0
  148. data/lib/new_relic/agent/instrumentation/delayed_job/chain.rb +35 -0
  149. data/lib/new_relic/agent/instrumentation/delayed_job/instrumentation.rb +48 -0
  150. data/lib/new_relic/agent/instrumentation/delayed_job/prepend.rb +33 -0
  151. data/lib/new_relic/agent/instrumentation/delayed_job_instrumentation.rb +30 -52
  152. data/lib/new_relic/agent/instrumentation/elasticsearch/chain.rb +29 -0
  153. data/lib/new_relic/agent/instrumentation/elasticsearch/instrumentation.rb +66 -0
  154. data/lib/new_relic/agent/instrumentation/elasticsearch/prepend.rb +13 -0
  155. data/lib/new_relic/agent/instrumentation/elasticsearch.rb +31 -0
  156. data/lib/new_relic/agent/instrumentation/excon/middleware.rb +8 -7
  157. data/lib/new_relic/agent/instrumentation/excon.rb +29 -31
  158. data/lib/new_relic/agent/instrumentation/fiber/chain.rb +20 -0
  159. data/lib/new_relic/agent/instrumentation/fiber/instrumentation.rb +24 -0
  160. data/lib/new_relic/agent/instrumentation/fiber/prepend.rb +18 -0
  161. data/lib/new_relic/agent/instrumentation/fiber.rb +25 -0
  162. data/lib/new_relic/agent/instrumentation/grape/chain.rb +24 -0
  163. data/lib/new_relic/agent/instrumentation/grape/instrumentation.rb +100 -0
  164. data/lib/new_relic/agent/instrumentation/grape/prepend.rb +17 -0
  165. data/lib/new_relic/agent/instrumentation/grape.rb +16 -121
  166. data/lib/new_relic/agent/instrumentation/grpc/client/chain.rb +97 -0
  167. data/lib/new_relic/agent/instrumentation/grpc/client/instrumentation.rb +89 -0
  168. data/lib/new_relic/agent/instrumentation/grpc/client/prepend.rb +111 -0
  169. data/lib/new_relic/agent/instrumentation/grpc/client/request_wrapper.rb +30 -0
  170. data/lib/new_relic/agent/instrumentation/grpc/helper.rb +32 -0
  171. data/lib/new_relic/agent/instrumentation/grpc/server/chain.rb +69 -0
  172. data/lib/new_relic/agent/instrumentation/grpc/server/instrumentation.rb +134 -0
  173. data/lib/new_relic/agent/instrumentation/grpc/server/rpc_desc_prepend.rb +35 -0
  174. data/lib/new_relic/agent/instrumentation/grpc/server/rpc_server_prepend.rb +26 -0
  175. data/lib/new_relic/agent/instrumentation/grpc_client.rb +23 -0
  176. data/lib/new_relic/agent/instrumentation/grpc_server.rb +25 -0
  177. data/lib/new_relic/agent/instrumentation/httpclient/chain.rb +24 -0
  178. data/lib/new_relic/agent/instrumentation/httpclient/instrumentation.rb +37 -0
  179. data/lib/new_relic/agent/instrumentation/httpclient/prepend.rb +15 -0
  180. data/lib/new_relic/agent/instrumentation/httpclient.rb +12 -32
  181. data/lib/new_relic/agent/instrumentation/httprb/chain.rb +22 -0
  182. data/lib/new_relic/agent/instrumentation/httprb/instrumentation.rb +30 -0
  183. data/lib/new_relic/agent/instrumentation/httprb/prepend.rb +15 -0
  184. data/lib/new_relic/agent/instrumentation/httprb.rb +29 -0
  185. data/lib/new_relic/agent/instrumentation/ignore_actions.rb +5 -6
  186. data/lib/new_relic/agent/instrumentation/logger/chain.rb +21 -0
  187. data/lib/new_relic/agent/instrumentation/logger/instrumentation.rb +66 -0
  188. data/lib/new_relic/agent/instrumentation/logger/prepend.rb +13 -0
  189. data/lib/new_relic/agent/instrumentation/logger.rb +26 -0
  190. data/lib/new_relic/agent/instrumentation/memcache/chain.rb +15 -0
  191. data/lib/new_relic/agent/instrumentation/memcache/dalli.rb +58 -125
  192. data/lib/new_relic/agent/instrumentation/memcache/helper.rb +59 -0
  193. data/lib/new_relic/agent/instrumentation/memcache/instrumentation.rb +90 -0
  194. data/lib/new_relic/agent/instrumentation/memcache/prepend.rb +101 -0
  195. data/lib/new_relic/agent/instrumentation/memcache.rb +57 -71
  196. data/lib/new_relic/agent/instrumentation/middleware_proxy.rb +15 -14
  197. data/lib/new_relic/agent/instrumentation/middleware_tracing.rb +21 -14
  198. data/lib/new_relic/agent/instrumentation/mongo.rb +7 -132
  199. data/lib/new_relic/agent/instrumentation/mongodb_command_subscriber.rb +49 -13
  200. data/lib/new_relic/agent/instrumentation/net_http/chain.rb +24 -0
  201. data/lib/new_relic/agent/instrumentation/net_http/instrumentation.rb +40 -0
  202. data/lib/new_relic/agent/instrumentation/net_http/prepend.rb +21 -0
  203. data/lib/new_relic/agent/instrumentation/net_http.rb +44 -0
  204. data/lib/new_relic/agent/instrumentation/notifications_subscriber.rb +142 -0
  205. data/lib/new_relic/agent/instrumentation/padrino/chain.rb +38 -0
  206. data/lib/new_relic/agent/instrumentation/padrino/instrumentation.rb +28 -0
  207. data/lib/new_relic/agent/instrumentation/padrino/prepend.rb +20 -0
  208. data/lib/new_relic/agent/instrumentation/padrino.rb +22 -58
  209. data/lib/new_relic/agent/instrumentation/passenger_instrumentation.rb +7 -7
  210. data/lib/new_relic/agent/instrumentation/queue_time.rb +9 -10
  211. data/lib/new_relic/agent/instrumentation/rack/chain.rb +66 -0
  212. data/lib/new_relic/agent/instrumentation/rack/helpers.rb +33 -0
  213. data/lib/new_relic/agent/instrumentation/rack/instrumentation.rb +75 -0
  214. data/lib/new_relic/agent/instrumentation/rack/prepend.rb +43 -0
  215. data/lib/new_relic/agent/instrumentation/rack.rb +33 -141
  216. data/lib/new_relic/agent/instrumentation/rails3/action_controller.rb +19 -55
  217. data/lib/new_relic/agent/instrumentation/rails_middleware.rb +5 -5
  218. data/lib/new_relic/agent/instrumentation/rails_notifications/action_cable.rb +36 -0
  219. data/lib/new_relic/agent/instrumentation/rails_notifications/action_controller.rb +45 -0
  220. data/lib/new_relic/agent/instrumentation/rails_notifications/action_view.rb +30 -0
  221. data/lib/new_relic/agent/instrumentation/rails_notifications/custom_events.rb +30 -0
  222. data/lib/new_relic/agent/instrumentation/rake/chain.rb +20 -0
  223. data/lib/new_relic/agent/instrumentation/rake/instrumentation.rb +142 -0
  224. data/lib/new_relic/agent/instrumentation/rake/prepend.rb +14 -0
  225. data/lib/new_relic/agent/instrumentation/rake.rb +18 -159
  226. data/lib/new_relic/agent/instrumentation/redis/chain.rb +45 -0
  227. data/lib/new_relic/agent/instrumentation/redis/constants.rb +17 -0
  228. data/lib/new_relic/agent/instrumentation/redis/instrumentation.rb +93 -0
  229. data/lib/new_relic/agent/instrumentation/redis/middleware.rb +16 -0
  230. data/lib/new_relic/agent/instrumentation/redis/prepend.rb +29 -0
  231. data/lib/new_relic/agent/instrumentation/redis.rb +20 -103
  232. data/lib/new_relic/agent/instrumentation/resque/chain.rb +21 -0
  233. data/lib/new_relic/agent/instrumentation/resque/helper.rb +19 -0
  234. data/lib/new_relic/agent/instrumentation/resque/instrumentation.rb +34 -0
  235. data/lib/new_relic/agent/instrumentation/resque/prepend.rb +15 -0
  236. data/lib/new_relic/agent/instrumentation/resque.rb +33 -41
  237. data/lib/new_relic/agent/instrumentation/sequel.rb +17 -20
  238. data/lib/new_relic/agent/instrumentation/sequel_helper.rb +3 -3
  239. data/lib/new_relic/agent/instrumentation/sidekiq/client.rb +20 -0
  240. data/lib/new_relic/agent/instrumentation/sidekiq/extensions/delayed_class.rb +30 -0
  241. data/lib/new_relic/agent/instrumentation/sidekiq/server.rb +37 -0
  242. data/lib/new_relic/agent/instrumentation/sidekiq.rb +29 -46
  243. data/lib/new_relic/agent/instrumentation/sinatra/chain.rb +55 -0
  244. data/lib/new_relic/agent/instrumentation/sinatra/ignorer.rb +31 -37
  245. data/lib/new_relic/agent/instrumentation/sinatra/instrumentation.rb +125 -0
  246. data/lib/new_relic/agent/instrumentation/sinatra/prepend.rb +33 -0
  247. data/lib/new_relic/agent/instrumentation/sinatra/transaction_namer.rb +3 -3
  248. data/lib/new_relic/agent/instrumentation/sinatra.rb +35 -165
  249. data/lib/new_relic/agent/instrumentation/thread/chain.rb +24 -0
  250. data/lib/new_relic/agent/instrumentation/thread/instrumentation.rb +28 -0
  251. data/lib/new_relic/agent/instrumentation/thread/prepend.rb +22 -0
  252. data/lib/new_relic/agent/instrumentation/thread.rb +20 -0
  253. data/lib/new_relic/agent/instrumentation/tilt/chain.rb +24 -0
  254. data/lib/new_relic/agent/instrumentation/tilt/instrumentation.rb +41 -0
  255. data/lib/new_relic/agent/instrumentation/tilt/prepend.rb +13 -0
  256. data/lib/new_relic/agent/instrumentation/tilt.rb +25 -0
  257. data/lib/new_relic/agent/instrumentation/typhoeus/chain.rb +22 -0
  258. data/lib/new_relic/agent/instrumentation/typhoeus/instrumentation.rb +80 -0
  259. data/lib/new_relic/agent/instrumentation/typhoeus/prepend.rb +14 -0
  260. data/lib/new_relic/agent/instrumentation/typhoeus.rb +14 -76
  261. data/lib/new_relic/agent/instrumentation.rb +2 -2
  262. data/lib/new_relic/agent/internal_agent_error.rb +3 -3
  263. data/lib/new_relic/agent/javascript_instrumentor.rb +51 -45
  264. data/lib/new_relic/agent/linking_metadata.rb +44 -0
  265. data/lib/new_relic/agent/local_log_decorator.rb +37 -0
  266. data/lib/new_relic/agent/log_event_aggregator.rb +235 -0
  267. data/lib/new_relic/agent/log_once.rb +2 -2
  268. data/lib/new_relic/agent/log_priority.rb +20 -0
  269. data/lib/new_relic/agent/logging.rb +142 -0
  270. data/lib/new_relic/agent/memory_logger.rb +3 -3
  271. data/lib/new_relic/agent/messaging.rb +81 -164
  272. data/lib/new_relic/agent/method_tracer.rb +152 -145
  273. data/lib/new_relic/agent/method_tracer_helpers.rb +90 -13
  274. data/lib/new_relic/agent/monitors/cross_app_monitor.rb +117 -0
  275. data/lib/new_relic/agent/monitors/distributed_tracing_monitor.rb +28 -0
  276. data/lib/new_relic/agent/{inbound_request_monitor.rb → monitors/inbound_request_monitor.rb} +5 -6
  277. data/lib/new_relic/agent/{synthetics_monitor.rb → monitors/synthetics_monitor.rb} +9 -15
  278. data/lib/new_relic/agent/monitors.rb +26 -0
  279. data/lib/new_relic/agent/new_relic_service/encoders.rb +7 -7
  280. data/lib/new_relic/agent/new_relic_service/json_marshaller.rb +6 -7
  281. data/lib/new_relic/agent/new_relic_service/marshaller.rb +8 -29
  282. data/lib/new_relic/agent/new_relic_service/security_policy_settings.rb +5 -5
  283. data/lib/new_relic/agent/new_relic_service.rb +282 -166
  284. data/lib/new_relic/agent/noticeable_error.rb +19 -0
  285. data/lib/new_relic/agent/null_logger.rb +8 -4
  286. data/lib/new_relic/agent/obfuscator.rb +9 -11
  287. data/lib/new_relic/agent/parameter_filtering.rb +35 -8
  288. data/lib/new_relic/agent/payload_metric_mapping.rb +10 -11
  289. data/lib/new_relic/agent/pipe_channel_manager.rb +28 -18
  290. data/lib/new_relic/agent/pipe_service.rb +9 -6
  291. data/lib/new_relic/agent/prepend_supportability.rb +3 -3
  292. data/lib/new_relic/agent/priority_sampled_buffer.rb +16 -14
  293. data/lib/new_relic/agent/range_extensions.rb +9 -29
  294. data/lib/new_relic/agent/rules_engine/replacement_rule.rb +12 -12
  295. data/lib/new_relic/agent/rules_engine/segment_terms_rule.rb +13 -14
  296. data/lib/new_relic/agent/rules_engine.rb +6 -5
  297. data/lib/new_relic/agent/sampler.rb +4 -5
  298. data/lib/new_relic/agent/sampler_collection.rb +4 -5
  299. data/lib/new_relic/agent/samplers/cpu_sampler.rb +4 -3
  300. data/lib/new_relic/agent/samplers/delayed_job_sampler.rb +14 -11
  301. data/lib/new_relic/agent/samplers/memory_sampler.rb +26 -15
  302. data/lib/new_relic/agent/samplers/object_sampler.rb +2 -2
  303. data/lib/new_relic/agent/samplers/vm_sampler.rb +22 -20
  304. data/lib/new_relic/agent/span_event_aggregator.rb +14 -16
  305. data/lib/new_relic/agent/span_event_primitive.rb +118 -58
  306. data/lib/new_relic/agent/sql_sampler.rb +25 -25
  307. data/lib/new_relic/agent/stats.rb +79 -42
  308. data/lib/new_relic/agent/stats_engine/gc_profiler.rb +11 -13
  309. data/lib/new_relic/agent/stats_engine/stats_hash.rb +13 -14
  310. data/lib/new_relic/agent/stats_engine.rb +11 -11
  311. data/lib/new_relic/agent/synthetics_event_aggregator.rb +8 -9
  312. data/lib/new_relic/agent/system_info.rb +100 -66
  313. data/lib/new_relic/agent/threading/agent_thread.rb +20 -16
  314. data/lib/new_relic/agent/threading/backtrace_node.rb +13 -14
  315. data/lib/new_relic/agent/threading/backtrace_service.rb +18 -18
  316. data/lib/new_relic/agent/threading/thread_profile.rb +31 -45
  317. data/lib/new_relic/agent/timestamp_sampled_buffer.rb +2 -2
  318. data/lib/new_relic/agent/tracer.rb +513 -0
  319. data/lib/new_relic/agent/transaction/abstract_segment.rb +131 -41
  320. data/lib/new_relic/agent/transaction/datastore_segment.rb +22 -18
  321. data/lib/new_relic/agent/transaction/distributed_tracer.rb +184 -0
  322. data/lib/new_relic/agent/transaction/distributed_tracing.rb +72 -163
  323. data/lib/new_relic/agent/transaction/external_request_segment.rb +66 -63
  324. data/lib/new_relic/agent/transaction/message_broker_segment.rb +34 -46
  325. data/lib/new_relic/agent/transaction/request_attributes.rb +36 -36
  326. data/lib/new_relic/agent/transaction/segment.rb +46 -10
  327. data/lib/new_relic/agent/transaction/slowest_sample_buffer.rb +2 -4
  328. data/lib/new_relic/agent/transaction/synthetics_sample_buffer.rb +2 -2
  329. data/lib/new_relic/agent/transaction/trace.rb +21 -24
  330. data/lib/new_relic/agent/transaction/trace_builder.rb +11 -12
  331. data/lib/new_relic/agent/transaction/trace_context.rb +168 -0
  332. data/lib/new_relic/agent/transaction/trace_node.rb +31 -28
  333. data/lib/new_relic/agent/transaction/tracing.rb +15 -111
  334. data/lib/new_relic/agent/transaction/transaction_sample_buffer.rb +6 -6
  335. data/lib/new_relic/agent/transaction.rb +252 -259
  336. data/lib/new_relic/agent/transaction_error_primitive.rb +34 -37
  337. data/lib/new_relic/agent/transaction_event_aggregator.rb +13 -13
  338. data/lib/new_relic/agent/transaction_event_primitive.rb +44 -56
  339. data/lib/new_relic/agent/transaction_event_recorder.rb +17 -16
  340. data/lib/new_relic/agent/transaction_metrics.rb +11 -10
  341. data/lib/new_relic/agent/transaction_sampler.rb +7 -12
  342. data/lib/new_relic/agent/transaction_time_aggregator.rb +41 -26
  343. data/lib/new_relic/agent/utilization/aws.rb +34 -4
  344. data/lib/new_relic/agent/utilization/azure.rb +4 -4
  345. data/lib/new_relic/agent/utilization/gcp.rb +8 -8
  346. data/lib/new_relic/agent/utilization/pcf.rb +6 -5
  347. data/lib/new_relic/agent/utilization/vendor.rb +44 -29
  348. data/lib/new_relic/agent/utilization_data.rb +43 -6
  349. data/lib/new_relic/agent/vm/jruby_vm.rb +2 -2
  350. data/lib/new_relic/agent/vm/monotonic_gc_profiler.rb +3 -3
  351. data/lib/new_relic/agent/vm/mri_vm.rb +46 -19
  352. data/lib/new_relic/agent/vm/snapshot.rb +6 -6
  353. data/lib/new_relic/agent/vm.rb +2 -2
  354. data/lib/new_relic/agent/worker_loop.rb +11 -13
  355. data/lib/new_relic/agent.rb +151 -79
  356. data/lib/new_relic/cli/command.rb +21 -23
  357. data/lib/new_relic/cli/commands/deployments.rb +94 -45
  358. data/lib/new_relic/cli/commands/install.rb +24 -26
  359. data/lib/new_relic/coerce.rb +42 -15
  360. data/lib/new_relic/collection_helper.rb +51 -49
  361. data/lib/new_relic/constants.rb +39 -0
  362. data/lib/new_relic/control/class_methods.rb +11 -5
  363. data/lib/new_relic/control/frameworks/external.rb +3 -3
  364. data/lib/new_relic/control/frameworks/rails.rb +24 -18
  365. data/lib/new_relic/control/frameworks/rails3.rb +4 -5
  366. data/lib/new_relic/control/frameworks/rails4.rb +2 -2
  367. data/lib/new_relic/control/frameworks/rails_notifications.rb +14 -0
  368. data/lib/new_relic/control/frameworks/ruby.rb +4 -4
  369. data/lib/new_relic/control/frameworks/sinatra.rb +8 -2
  370. data/lib/new_relic/control/frameworks.rb +2 -2
  371. data/lib/new_relic/control/instance_methods.rb +33 -42
  372. data/lib/new_relic/control/instrumentation.rb +40 -12
  373. data/lib/new_relic/control/private_instance_methods.rb +48 -0
  374. data/lib/new_relic/control/server_methods.rb +4 -5
  375. data/lib/new_relic/control.rb +2 -3
  376. data/lib/new_relic/delayed_job_injection.rb +2 -2
  377. data/lib/new_relic/dependency_detection.rb +129 -18
  378. data/lib/new_relic/environment_report.rb +41 -35
  379. data/lib/new_relic/helper.rb +49 -8
  380. data/lib/new_relic/language_support.rb +30 -6
  381. data/lib/new_relic/latest_changes.rb +9 -8
  382. data/lib/new_relic/local_environment.rb +23 -27
  383. data/lib/new_relic/metric_data.rb +32 -27
  384. data/lib/new_relic/metric_spec.rb +9 -7
  385. data/lib/new_relic/noticed_error.rb +46 -33
  386. data/lib/new_relic/rack/agent_hooks.rb +2 -2
  387. data/lib/new_relic/rack/agent_middleware.rb +7 -5
  388. data/lib/new_relic/rack/browser_monitoring.rb +134 -117
  389. data/lib/new_relic/rack.rb +2 -2
  390. data/lib/new_relic/recipes/capistrano3.rb +4 -62
  391. data/lib/new_relic/recipes/capistrano_legacy.rb +24 -27
  392. data/lib/new_relic/recipes/helpers/send_deployment.rb +70 -0
  393. data/lib/new_relic/recipes.rb +2 -2
  394. data/lib/new_relic/supportability_helper.rb +21 -7
  395. data/lib/new_relic/traced_thread.rb +39 -0
  396. data/lib/new_relic/version.rb +7 -18
  397. data/lib/newrelic_rpm.rb +20 -33
  398. data/lib/sequel/extensions/{newrelic_instrumentation.rb → new_relic_instrumentation.rb} +16 -19
  399. data/lib/sequel/plugins/{newrelic_instrumentation.rb → new_relic_instrumentation.rb} +9 -15
  400. data/lib/tasks/all.rb +4 -4
  401. data/lib/tasks/config.rake +22 -118
  402. data/lib/tasks/coverage_report.rake +28 -0
  403. data/lib/tasks/helpers/config.html.erb +21 -0
  404. data/lib/tasks/helpers/format.rb +123 -0
  405. data/lib/tasks/helpers/matches.rb +12 -0
  406. data/lib/tasks/helpers/prompt.rb +24 -0
  407. data/lib/tasks/helpers/removers.rb +33 -0
  408. data/lib/tasks/install.rake +4 -0
  409. data/lib/tasks/instrumentation_generator/README.md +63 -0
  410. data/lib/tasks/instrumentation_generator/TODO.md +33 -0
  411. data/lib/tasks/instrumentation_generator/instrumentation.thor +121 -0
  412. data/lib/tasks/instrumentation_generator/templates/Envfile.tt +9 -0
  413. data/lib/tasks/instrumentation_generator/templates/chain.tt +22 -0
  414. data/lib/tasks/instrumentation_generator/templates/chain_method.tt +8 -0
  415. data/lib/tasks/instrumentation_generator/templates/dependency_detection.tt +29 -0
  416. data/lib/tasks/instrumentation_generator/templates/instrumentation.tt +13 -0
  417. data/lib/tasks/instrumentation_generator/templates/instrumentation_method.tt +3 -0
  418. data/lib/tasks/instrumentation_generator/templates/newrelic.yml.tt +19 -0
  419. data/lib/tasks/instrumentation_generator/templates/prepend.tt +13 -0
  420. data/lib/tasks/instrumentation_generator/templates/prepend_method.tt +3 -0
  421. data/lib/tasks/instrumentation_generator/templates/test.tt +15 -0
  422. data/lib/tasks/multiverse.rake +4 -0
  423. data/lib/tasks/multiverse.rb +12 -5
  424. data/lib/tasks/newrelic.rb +2 -2
  425. data/lib/tasks/tests.rake +14 -14
  426. data/newrelic.yml +672 -3
  427. data/newrelic_rpm.gemspec +40 -31
  428. data/recipes/newrelic.rb +3 -3
  429. data/test/agent_helper.rb +419 -98
  430. metadata +238 -127
  431. data/.travis.yml +0 -228
  432. data/bin/mongrel_rpm +0 -33
  433. data/cert/cacert.pem +0 -1177
  434. data/lib/new_relic/agent/commands/xray_session.rb +0 -55
  435. data/lib/new_relic/agent/commands/xray_session_collection.rb +0 -161
  436. data/lib/new_relic/agent/cross_app_monitor.rb +0 -110
  437. data/lib/new_relic/agent/datastores/mongo/obfuscator.rb +0 -44
  438. data/lib/new_relic/agent/datastores/mongo/statement_formatter.rb +0 -53
  439. data/lib/new_relic/agent/distributed_trace_monitor.rb +0 -41
  440. data/lib/new_relic/agent/distributed_trace_payload.rb +0 -246
  441. data/lib/new_relic/agent/http_clients/abstract_request.rb +0 -31
  442. data/lib/new_relic/agent/instrumentation/active_record_4.rb +0 -42
  443. data/lib/new_relic/agent/instrumentation/active_record_5.rb +0 -41
  444. data/lib/new_relic/agent/instrumentation/acts_as_solr.rb +0 -74
  445. data/lib/new_relic/agent/instrumentation/authlogic.rb +0 -25
  446. data/lib/new_relic/agent/instrumentation/data_mapper.rb +0 -202
  447. data/lib/new_relic/agent/instrumentation/evented_subscriber.rb +0 -104
  448. data/lib/new_relic/agent/instrumentation/excon/connection.rb +0 -46
  449. data/lib/new_relic/agent/instrumentation/http.rb +0 -46
  450. data/lib/new_relic/agent/instrumentation/merb/controller.rb +0 -44
  451. data/lib/new_relic/agent/instrumentation/merb/errors.rb +0 -33
  452. data/lib/new_relic/agent/instrumentation/net.rb +0 -50
  453. data/lib/new_relic/agent/instrumentation/rails/action_controller.rb +0 -125
  454. data/lib/new_relic/agent/instrumentation/rails/action_web_service.rb +0 -46
  455. data/lib/new_relic/agent/instrumentation/rails4/action_controller.rb +0 -32
  456. data/lib/new_relic/agent/instrumentation/rails4/action_view.rb +0 -27
  457. data/lib/new_relic/agent/instrumentation/rails5/action_cable.rb +0 -36
  458. data/lib/new_relic/agent/instrumentation/rails5/action_controller.rb +0 -33
  459. data/lib/new_relic/agent/instrumentation/rails5/action_view.rb +0 -27
  460. data/lib/new_relic/agent/instrumentation/rainbows_instrumentation.rb +0 -26
  461. data/lib/new_relic/agent/instrumentation/sunspot.rb +0 -33
  462. data/lib/new_relic/agent/supported_versions.rb +0 -275
  463. data/lib/new_relic/agent/transaction/attributes.rb +0 -154
  464. data/lib/new_relic/agent/transaction/xray_sample_buffer.rb +0 -64
  465. data/lib/new_relic/agent/transaction_state.rb +0 -186
  466. data/lib/new_relic/build.rb +0 -2
  467. data/lib/new_relic/control/frameworks/merb.rb +0 -29
  468. data/lib/new_relic/control/frameworks/rails5.rb +0 -14
  469. data/lib/new_relic/metrics.rb +0 -13
  470. data/lib/tasks/config.html.erb +0 -32
  471. data/lib/tasks/versions.html.erb +0 -28
  472. data/lib/tasks/versions.postface.html +0 -8
  473. data/lib/tasks/versions.preface.html +0 -9
  474. data/lib/tasks/versions.rake +0 -65
  475. data/lib/tasks/versions.txt.erb +0 -14
  476. /data/lib/tasks/{config.text.erb → helpers/config.text.erb} +0 -0
@@ -1,6 +1,6 @@
1
- # encoding: utf-8
2
1
  # This file is distributed under New Relic's license terms.
3
- # See https://github.com/newrelic/rpm/blob/master/LICENSE for complete details.
2
+ # See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details.
3
+ # frozen_string_literal: true
4
4
 
5
5
  require 'new_relic/agent/configuration/dotted_hash'
6
6
 
@@ -26,9 +26,10 @@ module NewRelic
26
26
  def change_setting(policies, option, new_value)
27
27
  current_value = Agent.config[option]
28
28
  unless current_value == new_value
29
- NewRelic::Agent.logger.info \
29
+ NewRelic::Agent.logger.info( \
30
30
  "Setting changed: {#{option}: from #{current_value} " \
31
31
  "to #{new_value}}. Source: SecurityPolicySource"
32
+ )
32
33
  end
33
34
  policies[option] = new_value
34
35
  end
@@ -52,150 +53,143 @@ module NewRelic
52
53
  SECURITY_SETTINGS_MAP = {
53
54
  "record_sql" => [
54
55
  {
55
- option: :'transaction_tracer.record_sql',
56
- supported: true,
57
- enabled_fn: method(:record_sql_enabled?),
56
+ option: :'transaction_tracer.record_sql',
57
+ supported: true,
58
+ enabled_fn: method(:record_sql_enabled?),
58
59
  disabled_value: 'off',
59
- permitted_fn: proc { |policies|
60
+ permitted_fn: proc { |policies|
60
61
  change_setting(policies, :'transaction_tracer.record_sql', 'obfuscated')
61
62
  }
62
63
  },
63
64
  {
64
- option: :'slow_sql.record_sql',
65
- supported: true,
66
- enabled_fn: method(:record_sql_enabled?),
65
+ option: :'slow_sql.record_sql',
66
+ supported: true,
67
+ enabled_fn: method(:record_sql_enabled?),
67
68
  disabled_value: 'off',
68
- permitted_fn: proc { |policies|
69
+ permitted_fn: proc { |policies|
69
70
  change_setting(policies, :'slow_sql.record_sql', 'obfuscated')
70
71
  }
71
72
  },
72
73
  {
73
- option: :'mongo.capture_queries',
74
- supported: true,
75
- enabled_fn: method(:enabled?),
74
+ option: :'mongo.capture_queries',
75
+ supported: true,
76
+ enabled_fn: method(:enabled?),
76
77
  disabled_value: false,
77
- permitted_fn: proc{ |policies|
78
+ permitted_fn: proc { |policies|
78
79
  change_setting(policies, :'mongo.obfuscate_queries', true)
79
80
  }
80
81
  },
81
82
  {
82
- option: :'transaction_tracer.record_redis_arguments',
83
- supported: true,
84
- enabled_fn: method(:enabled?),
83
+ option: :'elasticsearch.capture_queries',
84
+ supported: true,
85
+ enabled_fn: method(:enabled?),
85
86
  disabled_value: false,
86
- permitted_fn: nil
87
+ permitted_fn: proc { |policies|
88
+ change_setting(policies, :'elasticsearch.obfuscate_queries', true)
89
+ }
90
+ },
91
+ {
92
+ option: :'transaction_tracer.record_redis_arguments',
93
+ supported: true,
94
+ enabled_fn: method(:enabled?),
95
+ disabled_value: false,
96
+ permitted_fn: nil
87
97
  }
88
98
  ],
89
99
  "attributes_include" => [
90
100
  {
91
- option: :'attributes.include',
92
- supported: true,
93
- enabled_fn: method(:not_empty?),
101
+ option: :'attributes.include',
102
+ supported: true,
103
+ enabled_fn: method(:not_empty?),
94
104
  disabled_value: [],
95
- permitted_fn: nil
105
+ permitted_fn: nil
96
106
  },
97
107
  {
98
- option: :'transaction_tracer.attributes.include',
99
- supported: true,
100
- enabled_fn: method(:not_empty?),
108
+ option: :'transaction_tracer.attributes.include',
109
+ supported: true,
110
+ enabled_fn: method(:not_empty?),
101
111
  disabled_value: [],
102
- permitted_fn: nil
112
+ permitted_fn: nil
103
113
  },
104
114
  {
105
- option: :'transaction_events.attributes.include',
106
- supported: true,
107
- enabled_fn: method(:not_empty?),
115
+ option: :'transaction_events.attributes.include',
116
+ supported: true,
117
+ enabled_fn: method(:not_empty?),
108
118
  disabled_value: [],
109
- permitted_fn: nil
119
+ permitted_fn: nil
110
120
  },
111
121
  {
112
- option: :'error_collector.attributes.include',
113
- supported: true,
114
- enabled_fn: method(:not_empty?),
122
+ option: :'error_collector.attributes.include',
123
+ supported: true,
124
+ enabled_fn: method(:not_empty?),
115
125
  disabled_value: [],
116
- permitted_fn: nil
126
+ permitted_fn: nil
117
127
  },
118
128
  {
119
- option: :'browser_monitoring.attributes.include',
120
- supported: true,
121
- enabled_fn: method(:not_empty?),
129
+ option: :'browser_monitoring.attributes.include',
130
+ supported: true,
131
+ enabled_fn: method(:not_empty?),
122
132
  disabled_value: [],
123
- permitted_fn: nil
133
+ permitted_fn: nil
124
134
  },
125
135
  {
126
- option: :'span_events.attributes.include',
127
- supported: true,
128
- enabled_fn: method(:not_empty?),
136
+ option: :'span_events.attributes.include',
137
+ supported: true,
138
+ enabled_fn: method(:not_empty?),
129
139
  disabled_value: [],
130
- permitted_fn: nil
140
+ permitted_fn: nil
131
141
  },
132
142
  {
133
- option: :'transaction_segments.attributes.include',
134
- supported: true,
135
- enabled_fn: method(:not_empty?),
143
+ option: :'transaction_segments.attributes.include',
144
+ supported: true,
145
+ enabled_fn: method(:not_empty?),
136
146
  disabled_value: [],
137
- permitted_fn: nil
147
+ permitted_fn: nil
138
148
  }
139
149
  ],
140
150
  "allow_raw_exception_messages" => [
141
151
  {
142
- option: :'strip_exception_messages.enabled',
143
- supported: true,
144
- enabled_fn: method(:enabled?),
152
+ option: :'strip_exception_messages.enabled',
153
+ supported: true,
154
+ enabled_fn: method(:enabled?),
145
155
  disabled_value: false,
146
- permitted_fn: nil
156
+ permitted_fn: nil
147
157
  }
148
158
  ],
149
159
  "custom_events" => [
150
160
  {
151
- option: :'custom_insights_events.enabled',
152
- supported: true,
153
- enabled_fn: method(:enabled?),
161
+ option: :'custom_insights_events.enabled',
162
+ supported: true,
163
+ enabled_fn: method(:enabled?),
154
164
  disabled_value: false,
155
- permitted_fn: nil
165
+ permitted_fn: nil
156
166
  }
157
167
  ],
158
168
  "custom_parameters" => [
159
169
  {
160
- option: :'custom_attributes.enabled',
161
- supported: true,
162
- enabled_fn: method(:enabled?),
170
+ option: :'custom_attributes.enabled',
171
+ supported: true,
172
+ enabled_fn: method(:enabled?),
163
173
  disabled_value: false,
164
- permitted_fn: nil
174
+ permitted_fn: nil
165
175
  }
166
176
  ],
167
177
  "custom_instrumentation_editor" => [
168
178
  {
169
- option: nil,
170
- supported: false,
171
- enabled_fn: nil,
179
+ option: nil,
180
+ supported: false,
181
+ enabled_fn: nil,
172
182
  disabled_value: nil,
173
- permitted_fn: nil
183
+ permitted_fn: nil
174
184
  }
175
185
  ],
176
186
  "message_parameters" => [
177
187
  {
178
- option: :'message_tracer.segment_parameters.enabled',
179
- supported: true,
180
- enabled_fn: method(:enabled?),
181
- disabled_value: false,
182
- permitted_fn: nil
183
- }
184
- ],
185
- "job_arguments" => [
186
- {
187
- option: :'resque.capture_params',
188
- supported: true,
189
- enabled_fn: method(:enabled?),
190
- disabled_value: false,
191
- permitted_fn: nil
192
- },
193
- {
194
- option: :'sidekiq.capture_params',
195
- supported: true,
196
- enabled_fn: method(:enabled?),
188
+ option: :'message_tracer.segment_parameters.enabled',
189
+ supported: true,
190
+ enabled_fn: method(:enabled?),
197
191
  disabled_value: false,
198
- permitted_fn: nil
192
+ permitted_fn: nil
199
193
  }
200
194
  ]
201
195
  }
@@ -211,6 +205,7 @@ module NewRelic
211
205
  security_policies.inject({}) do |settings, (policy_name, policy_settings)|
212
206
  SECURITY_SETTINGS_MAP[policy_name].each do |policy|
213
207
  next unless policy[:supported]
208
+
214
209
  if policy_settings[ENABLED]
215
210
  if policy[:enabled_fn].call(policy[:option])
216
211
  if permitted_fn = policy[:permitted_fn]
@@ -218,15 +213,17 @@ module NewRelic
218
213
  end
219
214
  else
220
215
  config_source = Agent.config.source(policy[:option]).class.name.split(COLON_COLON).last
221
- NewRelic::Agent.logger.info \
216
+ NewRelic::Agent.logger.info( \
222
217
  "Setting applied: {#{policy[:option]}: #{policy[:disabled_value]}}. " \
223
218
  "Source: #{config_source}"
219
+ )
224
220
  end
225
221
  else
226
- settings[policy[:option]] = policy[:disabled_value]
227
- NewRelic::Agent.logger.info \
222
+ settings[policy[:option]] = policy[:disabled_value]
223
+ NewRelic::Agent.logger.info( \
228
224
  "Setting applied: {#{policy[:option]}: #{policy[:disabled_value]}}. " \
229
225
  "Source: SecurityPolicySource"
226
+ )
230
227
  end
231
228
  end
232
229
  settings
@@ -1,6 +1,6 @@
1
- # encoding: utf-8
2
1
  # This file is distributed under New Relic's license terms.
3
- # See https://github.com/newrelic/rpm/blob/master/LICENSE for complete details.
2
+ # See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details.
3
+ # frozen_string_literal: true
4
4
 
5
5
  module NewRelic
6
6
  module Agent
@@ -20,8 +20,8 @@ module NewRelic
20
20
  "browser_monitoring.loader_version",
21
21
  "cross_process_id",
22
22
  "data_report_period",
23
- "data_report_periods.analytic_event_data",
24
23
  "encoding_key",
24
+ "entity_guid",
25
25
  "error_beacon",
26
26
  "js_agent_file",
27
27
  "js_agent_loader",
@@ -33,12 +33,13 @@ module NewRelic
33
33
  "trusted_account_key"
34
34
  ]
35
35
 
36
- def initialize(connect_reply, existing_config={})
36
+ def initialize(connect_reply, existing_config = {})
37
37
  merged_settings = {}
38
38
 
39
39
  merge_top_level_keys(merged_settings, connect_reply)
40
40
  merge_agent_config_hash(merged_settings, connect_reply)
41
41
  fix_transaction_threshold(merged_settings)
42
+ add_event_harvest_config(merged_settings, connect_reply)
42
43
  filter_keys(merged_settings)
43
44
 
44
45
  apply_feature_gates(merged_settings, connect_reply, existing_config)
@@ -69,11 +70,46 @@ module NewRelic
69
70
 
70
71
  def fix_transaction_threshold(merged_settings)
71
72
  # when value is "apdex_f" remove the config and defer to default
72
- if merged_settings['transaction_tracer.transaction_threshold'] =~ /apdex_f/i
73
+ if merged_settings['transaction_tracer.transaction_threshold'].to_s =~ /apdex_f/i
73
74
  merged_settings.delete('transaction_tracer.transaction_threshold')
74
75
  end
75
76
  end
76
77
 
78
+ EVENT_HARVEST_CONFIG_SUPPORTABILITY_METRIC_NAMES = {
79
+ :'transaction_events.max_samples_stored' => 'Supportability/EventHarvest/AnalyticEventData/HarvestLimit',
80
+ :'custom_insights_events.max_samples_stored' => 'Supportability/EventHarvest/CustomEventData/HarvestLimit',
81
+ :'error_collector.max_event_samples_stored' => 'Supportability/EventHarvest/ErrorEventData/HarvestLimit',
82
+ :'application_logging.forwarding.max_samples_stored' => 'Supportability/EventHarvest/LogEventData/HarvestLimit',
83
+ :'span_events.max_samples_stored' => 'Supportability/SpanEvent/Limit',
84
+ :event_report_period => 'Supportability/EventHarvest/ReportPeriod',
85
+ :'event_report_period.span_event_data' => 'Supportability/SpanEvent/ReportPeriod'
86
+ }
87
+
88
+ def add_event_harvest_config(merged_settings, connect_reply)
89
+ return unless event_harvest_config_is_valid(connect_reply)
90
+
91
+ event_harvest_config = EventHarvestConfig.to_config_hash(connect_reply)
92
+ EVENT_HARVEST_CONFIG_SUPPORTABILITY_METRIC_NAMES.each do |config_key, metric_name|
93
+ NewRelic::Agent.record_metric(metric_name, event_harvest_config[config_key])
94
+ end
95
+
96
+ merged_settings.merge!(event_harvest_config)
97
+ end
98
+
99
+ def event_harvest_config_is_valid(connect_reply)
100
+ event_harvest_config = connect_reply['event_harvest_config']
101
+
102
+ if event_harvest_config.nil? \
103
+ || event_harvest_config['harvest_limits'].values.min < 0 \
104
+ || (event_harvest_config['report_period_ms'] / 1000) <= 0
105
+ NewRelic::Agent.logger.warn("Invalid event harvest config found " \
106
+ "in connect response; using default event report period.")
107
+ false
108
+ else
109
+ true
110
+ end
111
+ end
112
+
77
113
  def filter_keys(merged_settings)
78
114
  merged_settings.delete_if do |key, _|
79
115
  setting_spec = DEFAULTS[key.to_sym]
@@ -98,18 +134,19 @@ module NewRelic
98
134
  # do the real enforcement there.
99
135
  def apply_feature_gates(merged_settings, connect_reply, existing_config)
100
136
  gated_features = {
101
- 'transaction_tracer.enabled' => 'collect_traces',
102
- 'slow_sql.enabled' => 'collect_traces',
103
- 'error_collector.enabled' => 'collect_errors',
104
- 'analytics_events.enabled' => 'collect_analytics_events',
137
+ 'transaction_tracer.enabled' => 'collect_traces',
138
+ 'slow_sql.enabled' => 'collect_traces',
139
+ 'error_collector.enabled' => 'collect_errors',
140
+ 'transaction_events.enabled' => 'collect_analytics_events',
105
141
  'custom_insights_events.enabled' => 'collect_custom_events',
106
- 'error_collector.capture_events' => 'collect_error_events'
142
+ 'error_collector.capture_events' => 'collect_error_events',
143
+ 'span_events.enabled' => 'collect_span_events'
107
144
  }
108
145
  gated_features.each do |config_key, gate_key|
109
146
  if connect_reply.has_key?(gate_key)
110
147
  allowed_by_server = connect_reply[gate_key]
111
- requested_value = ungated_value(config_key, merged_settings, existing_config)
112
- effective_value = (allowed_by_server && requested_value)
148
+ requested_value = ungated_value(config_key, merged_settings, existing_config)
149
+ effective_value = (allowed_by_server && requested_value)
113
150
  merged_settings[config_key] = effective_value
114
151
  end
115
152
  end
@@ -1,6 +1,6 @@
1
- # encoding: utf-8
2
1
  # This file is distributed under New Relic's license terms.
3
- # See https://github.com/newrelic/rpm/blob/master/LICENSE for complete details.
2
+ # See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details.
3
+ # frozen_string_literal: true
4
4
 
5
5
  require 'new_relic/agent/configuration/dotted_hash'
6
6
 
@@ -11,8 +11,13 @@ module NewRelic
11
11
  attr_accessor :file_path, :failures
12
12
  attr_reader :generated_for_user, :license_key
13
13
 
14
+ # These are configuration options that have a value of a Hash
15
+ # This is used in YamlSource#dot_flattened prevent flattening these values
16
+ CONFIG_WITH_HASH_VALUE = %w[expected_messages ignore_messages]
17
+
14
18
  def initialize(path, env)
15
- config = {}
19
+ @path = path
20
+ config = {}
16
21
  @failures = []
17
22
 
18
23
  # These are needed in process_erb for populating the newrelic.yml via
@@ -29,7 +34,7 @@ module NewRelic
29
34
  ::NewRelic::Agent.logger.info("Reading configuration from #{path} (#{Dir.pwd})")
30
35
  raw_file = File.read(@file_path)
31
36
  erb_file = process_erb(raw_file)
32
- config = process_yaml(erb_file, env, config, @file_path)
37
+ config = process_yaml(erb_file, env, config, @file_path)
33
38
  rescue ScriptError, StandardError => e
34
39
  log_failure("Failed to read or parse configuration file at #{path}", e)
35
40
  end
@@ -58,8 +63,8 @@ module NewRelic
58
63
  end
59
64
 
60
65
  def warn_missing_config_file(path)
61
- based_on = 'unknown'
62
- source = ::NewRelic::Agent.config.source(:config_path)
66
+ based_on = 'unknown'
67
+ source = ::NewRelic::Agent.config.source(:config_path)
63
68
  candidate_paths = [path]
64
69
 
65
70
  case source
@@ -98,7 +103,12 @@ module NewRelic
98
103
 
99
104
  def process_yaml(file, env, config, path)
100
105
  if file
101
- confighash = YAML.load(file)
106
+ confighash = if YAML.respond_to?(:unsafe_load)
107
+ YAML.unsafe_load(file)
108
+ else
109
+ YAML.load(file)
110
+ end
111
+
102
112
  unless confighash.key?(env)
103
113
  log_failure("Config file at #{path} doesn't include a '#{env}' section!")
104
114
  end
@@ -111,30 +121,49 @@ module NewRelic
111
121
 
112
122
  def substitute_transaction_threshold(config)
113
123
  if config['transaction_tracer'] &&
114
- config['transaction_tracer']['transaction_threshold'] =~ /apdex_f/i
124
+ config['transaction_tracer']['transaction_threshold'].to_s =~ /apdex_f/i
115
125
  # when value is "apdex_f" remove the config and defer to default
116
126
  config['transaction_tracer'].delete('transaction_threshold')
127
+ elsif config['transaction_tracer.transaction_threshold'].to_s =~ /apdex_f/i
128
+ config.delete('transaction_tracer.transaction_threshold')
117
129
  end
118
130
  end
119
131
 
120
132
  def booleanify_values(config, *keys)
121
- # auto means defer ro default
133
+ # auto means defer to default
122
134
  keys.each do |option|
123
- if config[option] == 'auto'
135
+ if 'auto' == config[option]
124
136
  config.delete(option)
125
137
  elsif !config[option].nil? && !is_boolean?(config[option])
126
- config[option] = !!(config[option] =~ /yes|on|true/i)
138
+ coerced_value = !!(config[option].to_s =~ /yes|on|true/i)
139
+ if !coerced_value
140
+ log_failure("Unexpected value (#{config[option]}) for '#{option}' in #{@path}")
141
+ end
142
+ config[option] = coerced_value
127
143
  end
128
144
  end
129
145
  end
130
146
 
131
147
  def is_boolean?(value)
132
- value == !!value
148
+ !!value == value
133
149
  end
134
150
 
135
151
  def log_failure(*messages)
136
152
  ::NewRelic::Agent.logger.error(*messages)
137
- @failures << messages
153
+ messages.each { |message| @failures << message }
154
+ end
155
+
156
+ def dot_flattened(nested_hash, names = [], result = {})
157
+ nested_hash.each do |key, val|
158
+ next if val.nil?
159
+
160
+ if val.respond_to?(:has_key?) && !CONFIG_WITH_HASH_VALUE.include?(key)
161
+ dot_flattened(val, names + [key], result)
162
+ else
163
+ result[(names + [key]).join('.')] = val
164
+ end
165
+ end
166
+ result
138
167
  end
139
168
  end
140
169
  end
@@ -1,6 +1,6 @@
1
- # encoding: utf-8
2
1
  # This file is distributed under New Relic's license terms.
3
- # See https://github.com/newrelic/rpm/blob/master/LICENSE for complete details.
2
+ # See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details.
3
+ # frozen_string_literal: true
4
4
 
5
5
  require 'new_relic/agent/configuration/manager'
6
6
  require 'new_relic/agent/configuration/dotted_hash'
@@ -0,0 +1,61 @@
1
+ # This file is distributed under New Relic's license terms.
2
+ # See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details.
3
+ # frozen_string_literal: true
4
+
5
+ require 'new_relic/environment_report'
6
+ require 'new_relic/agent/configuration/event_harvest_config'
7
+
8
+ module NewRelic
9
+ module Agent
10
+ module Connect
11
+ class RequestBuilder
12
+ def initialize(new_relic_service, config, event_harvest_config, environment_report)
13
+ @service = new_relic_service
14
+ @config = config
15
+ @event_harvest_config = event_harvest_config
16
+ @environment_report = sanitize_environment_report(environment_report)
17
+ end
18
+
19
+ # Initializes the hash of settings that we send to the
20
+ # server. Returns a literal hash containing the options
21
+ def connect_payload
22
+ {
23
+ :pid => $$,
24
+ :host => local_host,
25
+ :display_host => Agent.config[:'process_host.display_name'],
26
+ :app_name => Agent.config[:app_name],
27
+ :language => 'ruby',
28
+ :labels => Agent.config.parsed_labels,
29
+ :agent_version => NewRelic::VERSION::STRING,
30
+ :environment => @environment_report,
31
+ :metadata => environment_metadata,
32
+ :settings => Agent.config.to_collector_hash,
33
+ :high_security => Agent.config[:high_security],
34
+ :utilization => UtilizationData.new.to_collector_hash,
35
+ :identifier => "ruby:#{local_host}:#{Agent.config[:app_name].sort.join(',')}",
36
+ :event_harvest_config => @event_harvest_config
37
+ }
38
+ end
39
+
40
+ # We've seen objects in the environment report (Rails.env in
41
+ # particular) that can't serialize to JSON. Cope with that here and
42
+ # clear out so downstream code doesn't have to check again.
43
+ def sanitize_environment_report(environment_report)
44
+ return NewRelic::EMPTY_ARRAY unless @service.valid_to_marshal?(environment_report)
45
+
46
+ environment_report
47
+ end
48
+
49
+ def environment_metadata
50
+ env_copy = {}
51
+ ENV.keys.each { |k| env_copy[k] = ENV[k] if k =~ /^NEW_RELIC_METADATA_/ }
52
+ env_copy
53
+ end
54
+
55
+ def local_host
56
+ NewRelic::Agent::Hostname.get
57
+ end
58
+ end
59
+ end
60
+ end
61
+ end
@@ -0,0 +1,58 @@
1
+ # This file is distributed under New Relic's license terms.
2
+ # See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details.
3
+ # frozen_string_literal: true
4
+
5
+ module NewRelic
6
+ module Agent
7
+ module Connect
8
+ class ResponseHandler
9
+ def initialize(agent, config)
10
+ @agent = agent
11
+ @config = config
12
+ end
13
+
14
+ # Takes a hash of configuration data returned from the
15
+ # server and uses it to set local variables and to
16
+ # initialize various parts of the agent that are configured
17
+ # separately.
18
+ #
19
+ # Can accommodate most arbitrary data - anything extra is
20
+ # ignored unless we say to do something with it here.
21
+ def configure_agent(config_data)
22
+ return if config_data.nil?
23
+
24
+ @agent.agent_id = config_data['agent_run_id']
25
+
26
+ security_policies = config_data.delete('security_policies')
27
+
28
+ add_server_side_config(config_data)
29
+ add_security_policy_config(security_policies) if security_policies
30
+
31
+ @agent.transaction_rules = RulesEngine.create_transaction_rules(config_data)
32
+ @agent.stats_engine.metric_rules = RulesEngine.create_metric_rules(config_data)
33
+
34
+ # If you're adding something else here to respond to the server-side config,
35
+ # use Agent.instance.events.subscribe(:initial_configuration_complete) callback instead!
36
+ end
37
+
38
+ def add_server_side_config(config_data)
39
+ if config_data['agent_config']
40
+ ::NewRelic::Agent.logger.debug("Using config from server")
41
+ end
42
+
43
+ ::NewRelic::Agent.logger.debug("Server provided config: #{config_data.inspect}")
44
+ server_config = NewRelic::Agent::Configuration::ServerSource.new(config_data, @config)
45
+ @config.replace_or_add_config(server_config)
46
+ end
47
+
48
+ def add_security_policy_config(security_policies)
49
+ ::NewRelic::Agent.logger.info('Installing security policies')
50
+ security_policy_source = NewRelic::Agent::Configuration::SecurityPolicySource.new(security_policies)
51
+ @config.replace_or_add_config(security_policy_source)
52
+ # drop data collected before applying security policies
53
+ @agent.drop_buffered_data
54
+ end
55
+ end
56
+ end
57
+ end
58
+ end