class Ougai::Logger
def self.broadcast(logger)
def self.broadcast(logger) Module.new do |mdl| ::Logger::Severity.constants.each do |severity| method_name = severity.downcase.to_sym mdl.send(:define_method, method_name) do |*args| logger.send(method_name, *args) super(*args) end end define_method(:level=) do |level| logger.level = level super(level) end end end
def append(severity, args)
def append(severity, args) hooks = @before_log ? [@before_log] : [] write(severity, args, @with_fields, hooks) end
def chain(severity, args, fields, hooks)
def chain(severity, args, fields, hooks) hooks.push(@before_log) if @before_log write(severity, args, merge_fields(@with_fields, fields), hooks) end
def create_formatter
def create_formatter Formatters::Bunyan.new end
def create_item_with_1arg(msg)
def create_item_with_1arg(msg) item = {} if msg.is_a?(Exception) item[:msg] = msg.to_s set_exc(item, msg) elsif msg.is_a?(Hash) item[:msg] = @default_message unless msg.key?(:msg) item.merge!(msg) else item[:msg] = msg.to_s end item end
def create_item_with_2args(msg, ex)
def create_item_with_2args(msg, ex) item = {} if ex.is_a?(Exception) item[:msg] = msg.to_s set_exc(item, ex) elsif ex.is_a?(Hash) item.merge!(ex) if msg.is_a?(Exception) set_exc(item, msg) else item[:msg] = msg.to_s end end item end
def create_item_with_3args(msg, ex, data)
def create_item_with_3args(msg, ex, data) item = {} set_exc(item, ex) if ex.is_a?(Exception) item.merge!(data) if data.is_a?(Hash) item[:msg] = msg.to_s item end
def initialize(*args)
def initialize(*args) super(*args) @default_message = 'No message' @exc_key = :err @with_fields = {} @formatter = create_formatter end
def set_exc(item, exc)
def set_exc(item, exc) item[@exc_key] = @formatter.serialize_exc(exc) end
def to_item(args)
def to_item(args) msg, ex, data = args if ex.nil? create_item_with_1arg(msg) elsif data.nil? create_item_with_2args(msg, ex) elsif msg create_item_with_3args(msg, ex, data) else # No args { msg: @default_message } end end
def write(severity, args, fields, hooks)
def write(severity, args, fields, hooks) data = merge_fields(fields, to_item(args)) hooks.each do |hook| return false if hook.call(data) == false end add(severity, data) end