Class: TMSAPI::CustomLogger

Inherits:
Faraday::Middleware
  • Object
show all
Extended by:
Forwardable
Defined in:
lib/tmsapi/middleware/custom_logger.rb

Instance Method Summary collapse

Constructor Details

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

Returns a new instance of CustomLogger.



6
7
8
9
10
11
12
# File 'lib/tmsapi/middleware/custom_logger.rb', line 6

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

Instance Method Details

#call(env) ⇒ Object



14
15
16
17
18
19
20
21
22
23
24
# File 'lib/tmsapi/middleware/custom_logger.rb', line 14

def call(env)
  start_time = Time.now
  info  { request_info(env) }
  debug { 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) }
    debug { response_debug(env) }
  end
end