class Tire::Logger

Public Class Methods

new(device, options={}) click to toggle source
# File lib/tire/logger.rb, line 4
def initialize(device, options={})
  @device = if device.respond_to?(:write)
    device
  else
    File.open(device, 'a')
  end
  @device.sync = true if @device.respond_to?(:sync)
  @options = options
  at_exit { @device.close unless @device.closed? } if @device.respond_to?(:closed?) && @device.respond_to?(:close)
end

Public Instance Methods

level() click to toggle source
# File lib/tire/logger.rb, line 15
def level
  @options[:level] || 'info'
end
log_request(endpoint, params=nil, curl='') click to toggle source
# File lib/tire/logger.rb, line 23
def log_request(endpoint, params=nil, curl='')
  # 2001-02-12 18:20:42:32 [_search] (articles,users)
  #
  # curl -X POST ....
  #
  content  = "# #{time}"
  content += " [#{endpoint}]"
  content += " (#{params.inspect})" if params
  content += "\n#\n"
  content += curl
  content += "\n\n"
  write content
end
log_response(status, took=nil, json='') click to toggle source
# File lib/tire/logger.rb, line 37
def log_response(status, took=nil, json='')
  # 2001-02-12 18:20:42:32 [200] (4 msec)
  #
  # {
  #   "took" : 4,
  #   "hits" : [...]
  #   ...
  # }
  #
  content  = "# #{time}"
  content += " [#{status}]"
  content += " (#{took} msec)" if took
  content += "\n#\n" unless json.to_s !~ %r\S/
  json.to_s.each_line { |line| content += "# #{line}" } unless json.to_s !~ %r\S/
  content += "\n\n"
  write content
end
time() click to toggle source
# File lib/tire/logger.rb, line 55
def time
  Time.now.strftime('%Y-%m-%d %H:%M:%S:%L')
end
write(message) click to toggle source
# File lib/tire/logger.rb, line 19
def write(message)
  @device.write message
end