Class: Rack::ActionLogger::Context
- Inherits:
-
Object
- Object
- Rack::ActionLogger::Context
- Defined in:
- lib/rack/action_logger/context.rb
Instance Method Summary collapse
- #call(env) ⇒ Object
- #capture_rack_log(env, status_code, headers, body) ⇒ Object
-
#initialize(app) ⇒ Context
constructor
A new instance of Context.
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 |