ActiveSupport::LogSubscriber is an object set to consume ActiveSupport::Notifications with the sole purpose of logging them. The log subscriber dispatches notifications to a registered object based on its given namespace.
An example would be Active Record log subscriber responsible for logging queries:
module ActiveRecord class LogSubscriber < ActiveSupport::LogSubscriber def sql(event) "#{event.payload[:name]} (#{event.duration}) #{event.payload[:sql]}" end end end
And it’s finally registered as:
ActiveRecord::LogSubscriber.attach_to :active_record
Since we need to know all instance methods before attaching the log
subscriber, the line above should be called after your
ActiveRecord::LogSubscriber
definition.
After configured, whenever a “sql.active_record” notification is published, it will properly dispatch the event (ActiveSupport::Notifications::Event) to the sql method.
Log subscriber also has some helpers to deal with logging and automatically flushes all logs when the request finishes (via action_dispatch.callback notification) in a Rails environment.
- A
- C
- F
- L
CLEAR | = | "\e[0m" |
Embed in a String to clear all previous ANSI sequences. |
||
BOLD | = | "\e[1m" |
BLACK | = | "\e[30m" |
Colors |
||
RED | = | "\e[31m" |
GREEN | = | "\e[32m" |
YELLOW | = | "\e[33m" |
BLUE | = | "\e[34m" |
MAGENTA | = | "\e[35m" |
CYAN | = | "\e[36m" |
WHITE | = | "\e[37m" |
# File activesupport/lib/active_support/log_subscriber.rb, line 59 def attach_to(namespace, log_subscriber=new, notifier=ActiveSupport::Notifications) log_subscribers << log_subscriber @@flushable_loggers = nil log_subscriber.public_methods(false).each do |event| next if 'call' == event.to_s notifier.subscribe("#{event}.#{namespace}", log_subscriber) end end
Flush all ::log_subscribers’ logger.
# File activesupport/lib/active_support/log_subscriber.rb, line 88 def call(message, *args) return unless logger method = message.split('.').first begin send(method, ActiveSupport::Notifications::Event.new(message, *args)) rescue Exception => e logger.error "Could not log #{message.inspect} event. #{e.class}: #{e.message}" end end