Class: DefaultLogger

Inherits:
Faraday::Middleware
  • Object
show all
Extended by:
Forwardable
Defined in:
lib/shutl/resource/default_logger.rb

Instance Method Summary collapse

Constructor Details

#initialize(app, options = {}) ⇒ DefaultLogger

Returns a new instance of DefaultLogger.



8
9
10
11
12
13
14
# File 'lib/shutl/resource/default_logger.rb', line 8

def initialize(app, options = {})
  @app = app
  @logger = options.fetch(:logger) {
    require 'logger'
    ::Logger.new($stderr)
  }
end

Instance Method Details

#call(env) ⇒ Object



16
17
18
19
20
21
22
23
24
25
26
27
# File 'lib/shutl/resource/default_logger.rb', line 16

def call(env)
  start_time = Time.now
  info  request_info(env)
  request_debug(env)

  @app.call(env).on_complete do
    end_time = Time.now
    response_time = end_time - start_time
    info  response_info(env, response_time)
    response_debug(env)
  end
end