Class: ThriftRack::Logger
- Inherits:
-
Object
- Object
- ThriftRack::Logger
- Defined in:
- lib/thrift_rack/logger.rb
Instance Method Summary collapse
- #call(env) ⇒ Object
-
#initialize(app) ⇒ Logger
constructor
A new instance of Logger.
- #logger ⇒ Object
Constructor Details
#initialize(app) ⇒ Logger
Returns a new instance of Logger.
5 6 7 |
# File 'lib/thrift_rack/logger.rb', line 5 def initialize(app) @app = app end |
Instance Method Details
#call(env) ⇒ Object
9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 |
# File 'lib/thrift_rack/logger.rb', line 9 def call(env) request_at = Time.now req = Rack::Request.new(env) resp = @app.call(env) resp ensure end_time = Time.now self.logger.info(JSON.dump({ request_at: request_at.iso8601(6), request_id: req.env["HTTP_X_REQUEST_ID"], rpc_id: req.env["HTTP_X_RPC_ID"], duration: ((end_time - request_at) * 1000).round(4), path: req.path, func: req.env["HTTP_X_RPC_FUNC"], from: req.env["HTTP_X_FROM"], })) end |
#logger ⇒ Object
27 28 29 |
# File 'lib/thrift_rack/logger.rb', line 27 def logger @logger ||= (defined? Rails) ? rails_logger : std_logger end |