Sha256: 72380b406a1a08f4ef7765854fe55b73b1b161991303c16c9d8741b5493c686e
Contents?: true
Size: 1.57 KB
Versions: 1
Compression:
Stored size: 1.57 KB
Contents
require 'active_support/core_ext/class/attribute' require 'active_support/log_subscriber' module Lograge class RequestLogSubscriber < ActiveSupport::LogSubscriber def process_action(event) payload = event.payload message = "#{payload[:method]} #{payload[:path]} format=#{payload[:format]} action=#{payload[:params]['controller']}##{payload[:params]['action']}" message << extract_status(payload) message << runtimes(event) message << location(event) message << custom_options(event) logger.info(message) end def redirect_to(event) Thread.current[:lograge_location] = event.payload[:location] end private def extract_status(payload) if payload[:status] " status=#{payload[:status]}" elsif payload[:exception] exception, message = payload[:exception] " status=500 error='#{exception}:#{message}'" end end def custom_options(event) message = "" (Lograge.custom_options(event) || {}).each do |name, value| message << " #{name}=#{value}" end message end def runtimes(event) message = "" {:duration => event.duration, :view => event.payload[:view_runtime], :db => event.payload[:db_runtime]}.each do |name, runtime| message << " #{name}=%.2f" % runtime if runtime end message end def location(event) if location = Thread.current[:lograge_location] Thread.current[:lograge_location] = nil " location=#{location}" else "" end end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
lograge-0.0.4 | lib/lograge/log_subscriber.rb |