module LogFormatter::Common::JSON
Public Instance Methods
build_event(message, severity, time, progname)
click to toggle source
# File lib/log_formatter/common_json.rb, line 2 def build_event(message, severity, time, progname) data = message if data.is_a?(String) && data.start_with?('{'.freeze) data = (JSON.parse(message) rescue nil) || message end event = case data when Hash data else {"message".freeze => msg2str(data)} end event[@config[:level].freeze] ||= severity if @config[:level] event[@config[:type].freeze] = progname if @config[:type] event[@config[:app].freeze] = @app if @config[:app] event[@config[:timestamp].freeze] = current_time(time).iso8601 if @config[:timestamp] "#{@ext.merge(event).to_json}\n" end