1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37
|
require "cabin"
# Wrap Ruby stdlib's logger. This allows you to output to a normal ruby logger
# with Cabin. Since Ruby's Logger has a love for strings alone, this
# wrapper will convert the data/event to ruby inspect format before sending it
# to Logger.
class Cabin::Outputs::StdlibLogger
public
def initialize(logger)
@logger = logger
@logger.level = logger.class::DEBUG
end # def initialize
# Receive an event
public
def <<(event)
if !event.include?(:level)
event[:level] = :info
end
if event[:level].is_a?(Symbol)
method = event[:level]
else
method = event[:level].downcase.to_sym || :info
end
event.delete(:level)
data = event.clone
# delete things from the 'data' portion that's not really data.
data.delete(:message)
data.delete(:timestamp)
message = "#{event[:message]} #{data.inspect}"
#p [@logger.level, logger.class::DEBUG]
# This will call @logger.info(data) or something similar.
@logger.send(method, message)
end # def <<
end # class Cabin::Outputs::StdlibLogger
|