Class: SimpleJsonLogFormatter

Inherits:
Object
  • Object
show all
Defined in:
lib/simple_json_log_formatter.rb,
lib/simple_json_log_formatter/version.rb

Constant Summary collapse

VERSION =
"0.1.0"

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(opts = {}) ⇒ SimpleJsonLogFormatter

Returns a new instance of SimpleJsonLogFormatter.

Parameters:

  • opts (Hash) (defaults to: {})

Options Hash (opts):

  • time_key (String) — default: default: time
  • severity_key (String) — default: default: severity
  • message_key (String) — default: default: message
  • datetime_format (String) — default: default: nil


15
16
17
18
19
20
21
22
# File 'lib/simple_json_log_formatter.rb', line 15

def initialize(opts={})
  @opts = opts.map {|k, v| [k.to_sym, v] }.to_h
  @opts[:time_key] = :time unless @opts.has_key?(:time_key)
  @opts[:severity_key] = :severity unless @opts.has_key?(:severity_key)
  @opts[:progname_key] = :progname unless @opts.has_key?(:progname_key)
  @opts[:message_key] ||= :message
  @opts[:datetime_format] = @opts.dig(:datetime_format)
end

Instance Attribute Details

#optsObject

Returns the value of attribute opts.



8
9
10
# File 'lib/simple_json_log_formatter.rb', line 8

def opts
  @opts
end

Instance Method Details

#call(severity, time, progname, msg) ⇒ Object



24
25
26
27
# File 'lib/simple_json_log_formatter.rb', line 24

def call(severity, time, progname, msg)
  log = [*format_time(time), *format_severity(severity), *format_progname(progname), *format_message(msg)].to_h
  "#{log.to_json}\n"
end