Class: Librato::Rack::Logger

Inherits:
Object
  • Object
show all
Defined in:
lib/librato/rack/logger.rb

Overview

Wraps an available logger object and provides convenience methods for logging using a separate set of log levels

Constant Summary collapse

LOG_LEVELS =
[:off, :error, :warn, :info, :debug, :trace]

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(outlet = nil) ⇒ Logger

Returns a new instance of Logger.



14
15
16
17
18
# File 'lib/librato/rack/logger.rb', line 14

def initialize(outlet=nil)
  @buffer = []
  self.outlet = outlet
  self.prefix = ''
end

Instance Attribute Details

#outletObject

Returns the value of attribute outlet.



12
13
14
# File 'lib/librato/rack/logger.rb', line 12

def outlet
  @outlet
end

#prefixObject

Returns the value of attribute prefix.



11
12
13
# File 'lib/librato/rack/logger.rb', line 11

def prefix
  @prefix
end

Instance Method Details

#log(level, message = nil, &block) ⇒ Object

Examples:

Simple logging

log :debug, 'this is a debug message'

Block logging - not executed if won’t be logged

log(:debug) { "found #{thingy} at #{place}" }


26
27
28
29
30
31
32
33
34
# File 'lib/librato/rack/logger.rb', line 26

def log(level, message=nil, &block)
  return unless should_log?(level)
  message = prefix + (message || block.call)
  if outlet.nil?
    buffer(level, message)
  else
    write_to_outlet(level, message)
  end
end

#log_levelObject



47
48
49
# File 'lib/librato/rack/logger.rb', line 47

def log_level
  @log_level ||= :info
end

#log_level=(level) ⇒ Object

set log level to any of LOG_LEVELS



37
38
39
40
41
42
43
44
45
# File 'lib/librato/rack/logger.rb', line 37

def log_level=(level)
  level = level.to_sym
  if LOG_LEVELS.index(level)
    @log_level = level
    require 'pp' if should_log?(:debug)
  else
    raise InvalidLogLevel, "Invalid log level '#{level}'"
  end
end