Class: Rack::ActionLogger::Context

Inherits:
Object
  • Object
show all
Defined in:
lib/rack/action_logger/context.rb

Instance Method Summary collapse

Constructor Details

#initialize(app) ⇒ Context

Returns a new instance of Context.



4
5
6
# File 'lib/rack/action_logger/context.rb', line 4

def initialize(app)
  @app = app
end

Instance Method Details

#call(env) ⇒ Object



8
9
10
11
12
13
14
# File 'lib/rack/action_logger/context.rb', line 8

def call(env)
  Emitter.new.emit do
    status_code, headers, body = @app.call(env)
    capture_rack_log(env, status_code, headers, body)
    [status_code, headers, body]
  end
end

#capture_rack_log(env, status_code, headers, body) ⇒ Object



16
17
18
19
20
# File 'lib/rack/action_logger/context.rb', line 16

def capture_rack_log(env, status_code, headers, body)
  rack_metrics = Rack::ActionLogger.configuration.rack_metrics.new(env, status_code, headers, body)
  Rack::ActionLogger::Container.set_request_log(rack_metrics.metrics, rack_metrics.tag_suffix)
  Rack::ActionLogger::Container.merge_attributes({ request_id: rack_metrics.request_id })
end