require 'json' module SemanticLogger module Formatters class Raw < Base # Fields are added by populating this hash. attr_accessor :hash, :log, :logger # Host name def host hash[:host] = logger.host if log_host && logger.host end # Application name def application hash[:application] = logger.application if log_application && logger.application end # Date & time def time hash[:time] = log.time end # Log level def level hash[:level] = log.level hash[:level_index] = log.level_index end # Process info def process_info hash[:pid] = $$ hash[:thread] = log.thread_name file, line = log.file_name_and_line if file hash[:file] = file hash[:line] = line.to_i end end # Tags def tags hash[:tags] = log.tags if log.tags && !log.tags.empty? end # Named Tags def named_tags hash[:named_tags] = log.named_tags if log.named_tags && !log.named_tags.empty? end # Duration def duration return unless log.duration hash[:duration_ms] = log.duration hash[:duration] = log.duration_human end # Class / app name def name hash[:name] = log.name end # Log message def message hash[:message] = log.cleansed_message if log.message end # Payload def payload hash[:payload] = log.payload if log.payload && log.payload.respond_to?(:empty?) && !log.payload.empty? end # Exception def exception return unless log.exception root = hash log.each_exception do |exception, i| name = i == 0 ? :exception : :cause root[name] = { name: exception.class.name, message: exception.message, stack_trace: exception.backtrace } root = root[name] end end # Metric def metric hash[:metric] = log.metric if log.metric hash[:metric_amount] = log.metric_amount if log.metric_amount end # Returns log messages in Hash format def call(log, logger) self.hash = {} self.log = log self.logger = logger host; application; time; level; process_info; duration; tags; named_tags; name; message; payload; exception; metric hash end end end end