Class: Appsignal::Rack::RailsInstrumentation

Inherits:
Object
  • Object
show all
Defined in:
lib/appsignal/rack/rails_instrumentation.rb

Instance Method Summary collapse

Constructor Details

#initialize(app, options = {}) ⇒ RailsInstrumentation

Returns a new instance of RailsInstrumentation.



6
7
8
9
# File 'lib/appsignal/rack/rails_instrumentation.rb', line 6

def initialize(app, options = {})
  Appsignal.logger.debug 'Initializing Appsignal::Rack::RailsInstrumentation'
  @app, @options = app, options
end

Instance Method Details

#call(env) ⇒ Object



11
12
13
14
15
16
17
# File 'lib/appsignal/rack/rails_instrumentation.rb', line 11

def call(env)
  if Appsignal.active?
    call_with_appsignal_monitoring(env)
  else
    @app.call(env)
  end
end

#call_with_appsignal_monitoring(env) ⇒ Object



19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
# File 'lib/appsignal/rack/rails_instrumentation.rb', line 19

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.('path', request.path)
    transaction.('method', request.request_method)
    Appsignal::Transaction.complete_current!
  end
end

#request_id(env) ⇒ Object



44
45
46
# File 'lib/appsignal/rack/rails_instrumentation.rb', line 44

def request_id(env)
  env['action_dispatch.request_id'] || SecureRandom.uuid
end