Sha256: 85b807c1c30f83b980b196e95ad5bbd85fd6888339502486017c7c9423061658
Contents?: true
Size: 1.37 KB
Versions: 70
Compression:
Stored size: 1.37 KB
Contents
require 'rack' module Appsignal module Rack class RailsInstrumentation def initialize(app, options = {}) Appsignal.logger.debug 'Initializing Appsignal::Rack::RailsInstrumentation' @app, @options = app, options end def call(env) if Appsignal.active? call_with_appsignal_monitoring(env) else @app.call(env) end end def call_with_appsignal_monitoring(env) request = ActionDispatch::Request.new(env) transaction = Appsignal::Transaction.create( request_id(env), Appsignal::Transaction::HTTP_REQUEST, request, :params_method => :filtered_parameters ) begin @app.call(env) rescue => error transaction.set_error(error) raise error ensure controller = env['action_controller.instance'] if controller transaction.set_action("#{controller.class.to_s}##{controller.action_name}") end transaction.set_http_or_background_queue_start transaction.set_metadata('path', request.path) transaction.set_metadata('method', request.request_method) Appsignal::Transaction.complete_current! end end def request_id(env) env['action_dispatch.request_id'] || SecureRandom.uuid end end end end
Version data entries
70 entries across 70 versions & 1 rubygems