Class: UnifiedLogger::RequestLogger

Inherits:
Object
  • Object
show all
Defined in:
lib/unified_logger/request_logger.rb

Instance Method Summary collapse

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