Class: UnifiedLogger::RequestLogger
- Inherits:
-
Object
- Object
- UnifiedLogger::RequestLogger
- Defined in:
- lib/unified_logger/request_logger.rb
Instance Method Summary collapse
- #call(env) ⇒ Object
-
#initialize(app) ⇒ RequestLogger
constructor
A new instance of RequestLogger.
Constructor Details
#initialize(app) ⇒ RequestLogger
Returns a new instance of RequestLogger.
3 4 5 |
# File 'lib/unified_logger/request_logger.rb', line 3 def initialize(app) @app = app end |
Instance Method Details
#call(env) ⇒ Object
7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
# File 'lib/unified_logger/request_logger.rb', line 7 def call(env) return @app.call(env) unless UnifiedLogger.current_logger.is_a?(UnifiedLogger::Logger) UnifiedLogger::Logger.reset_thread_logs UnifiedLogger.setup_silencing(env["REQUEST_PATH"]) started = UnifiedLogger.current_time status, headers, response = @app.call(env) ensure if UnifiedLogger.current_logger.is_a?(UnifiedLogger::Logger) && !UnifiedLogger.silenced? log = build_log(started, env, status, headers, response) UnifiedLogger.transform_request_log_callable&.call(log, env) UnifiedLogger::Logger.write_log(log) end end |