Class: LogSanity::RequestLogger

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

Instance Method Summary collapse

Constructor Details

#initialize(app) ⇒ RequestLogger

Returns a new instance of RequestLogger.



4
5
6
# File 'lib/log_sanity/middleware/request_logger.rb', line 4

def initialize(app)
  @app = app
end

Instance Method Details

#call(env) ⇒ Object



8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
# File 'lib/log_sanity/middleware/request_logger.rb', line 8

def call(env)
  request = ActionDispatch::Request.new(env)

  conditionally_silence(request) do |silence|
    payload = {
      env:     env,
      method:  (request.request_method rescue 'INVALID'),
      request: request,
      silence: silence
    }
    handle = start(payload)
    begin
      status, headers, body = response = @app.call(env)
      payload[:response] = response
      body = Rack::BodyProxy.new(body){ handle.finish }
      if response.frozen?
        [status, headers, body]
      else
        response[2] = body
        response
      end
    rescue Exception => e
      payload[:exception] = e
      handle.finish
      raise e
    end
  end
ensure
  ActiveSupport::LogSubscriber.flush_all!
end

#conditionally_silence(request) ⇒ Object



39
40
41
42
43
44
45
46
47
# File 'lib/log_sanity/middleware/request_logger.rb', line 39

def conditionally_silence(request)
  if silence = silence_path?(request)
    logger.silence do
      yield silence
    end
  else
    yield silence
  end
end