Class: JsonTaggedLogger::Formatter
- Inherits:
-
Object
- Object
- JsonTaggedLogger::Formatter
- Defined in:
- lib/json_tagged_logger/formatter.rb
Instance Attribute Summary collapse
-
#pretty_print ⇒ Object
Returns the value of attribute pretty_print.
Instance Method Summary collapse
- #call(severity, _time, _progname, message) ⇒ Object
-
#initialize(pretty_print: false) ⇒ Formatter
constructor
A new instance of Formatter.
Constructor Details
#initialize(pretty_print: false) ⇒ Formatter
Returns a new instance of Formatter.
8 9 10 |
# File 'lib/json_tagged_logger/formatter.rb', line 8 def initialize(pretty_print: false) @pretty_print = pretty_print end |
Instance Attribute Details
#pretty_print ⇒ Object
Returns the value of attribute pretty_print.
6 7 8 |
# File 'lib/json_tagged_logger/formatter.rb', line 6 def pretty_print @pretty_print end |
Instance Method Details
#call(severity, _time, _progname, message) ⇒ Object
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 38 39 40 41 42 43 44 45 |
# File 'lib/json_tagged_logger/formatter.rb', line 12 def call(severity, _time, _progname, ) log = { level: severity, } , = .each { |t| log.merge!(t) } if .present? log[:tags] = .to_a end = () begin = JSON.parse() rescue JSON::ParserError = ensure if .is_a?(Hash) .symbolize_keys! if log.has_key?(:tags) && .has_key?(:tags) [:tags] = [:tags] + log[:tags] end log.merge!() else log.merge!(msg: .to_s.strip) end end format_for_output(log) end |