Class: BufferedRemoteSyslogLogger::Middleware
- Inherits:
-
Object
- Object
- BufferedRemoteSyslogLogger::Middleware
- Defined in:
- lib/buffered_remote_syslog_logger/middleware.rb
Instance Attribute Summary collapse
-
#app ⇒ Object
Returns the value of attribute app.
-
#logger ⇒ Object
Returns the value of attribute logger.
Instance Method Summary collapse
- #call(env) ⇒ Object
-
#initialize(app, options = {}) ⇒ Middleware
constructor
A new instance of Middleware.
Constructor Details
#initialize(app, options = {}) ⇒ Middleware
Returns a new instance of Middleware.
9 10 11 12 |
# File 'lib/buffered_remote_syslog_logger/middleware.rb', line 9 def initialize(app, = {}) @logger = Rails.logger @app = app end |
Instance Attribute Details
#app ⇒ Object
Returns the value of attribute app.
6 7 8 |
# File 'lib/buffered_remote_syslog_logger/middleware.rb', line 6 def app @app end |
#logger ⇒ Object
Returns the value of attribute logger.
6 7 8 |
# File 'lib/buffered_remote_syslog_logger/middleware.rb', line 6 def logger @logger end |
Instance Method Details
#call(env) ⇒ Object
15 16 17 18 19 20 21 22 23 24 25 |
# File 'lib/buffered_remote_syslog_logger/middleware.rb', line 15 def call(env) request_id = env['HTTP_X_REQUEST_ID'] || rand(100000000) request_id = sprintf("%08d", request_id) Thread.current.thread_variable_set(:http_request_id, request_id) @status, @headers, @response = app.call(env) [@status, @headers, @response] ensure logger.flush logger.close end |