Sha256: 0775874771fc855a1e53ef2299a38c4a3663792008aac59dc4e68ed490edba4a
Contents?: true
Size: 1.35 KB
Versions: 1
Compression:
Stored size: 1.35 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) 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 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.3 | lib/lograge/log_subscriber.rb |