Class: Superlogger::Middleware

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

Instance Method Summary collapse

Constructor Details

#initialize(app) ⇒ Middleware

Returns a new instance of Middleware.



3
4
5
# File 'lib/superlogger/middleware.rb', line 3

def initialize(app)
  @app = app
end

Instance Method Details

#call(env) ⇒ Object



7
8
9
10
11
12
13
14
15
16
# File 'lib/superlogger/middleware.rb', line 7

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

  # only process the actual request, less the assets
  if request.path.start_with?('/assets/') == false
    process_request(request)
  end

  @app.call(env)
end

#process_request(request) ⇒ Object



18
19
20
21
22
23
24
25
26
27
28
29
# File 'lib/superlogger/middleware.rb', line 18

def process_request(request)
  if request.env['rack.session']
    # Session is lazy loaded. Force session to load if it is not already loaded.
    request.env['rack.session'].send(:load!) unless request.env['rack.session'].id

    # Store session id before any actual logging is done
    Superlogger::Logger.session_id = request.env['rack.session'].id
  end

  # Start of request logging
  Logger.info method: request.method, path: request.fullpath, ip: request.ip
end