Sha256: aa51f3999f21a7026df77d9425afe4503d8ab84e55d153158b1f58cfcb39994c

Contents?: true

Size: 1018 Bytes

Versions: 7

Compression:

Stored size: 1018 Bytes

Contents

# frozen_string_literal: true

module Truemail
  class Logger
    require 'logger'

    attr_reader :event, :stdout, :file

    def initialize(event, error_stdout, log_absolute_path)
      @event = event
      @stdout = error_stdout
      @file = log_absolute_path
    end

    def push(validator_instance)
      current_event = Truemail::Log::Event.new(event, validator_instance)
      return unless current_event.valid?
      create_logs(current_event.log_level, Truemail::Log::Serializer::Text.call(validator_instance))
    end

    private

    def init_log_file
      output_file = Pathname(file)
      return output_file if output_file.exist?
      output_file.parent.mkpath && FileUtils.touch(output_file)
      output_file
    end

    def create_logs(log_level, serialized_object)
      %i[stdout file].each do |output_type|
        next unless public_send(output_type)
        ::Logger.new(output_type.eql?(:stdout) ? $stdout : init_log_file).add(log_level) { serialized_object }
      end
    end
  end
end

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
truemail-1.8.0 lib/truemail/logger.rb
truemail-1.7.1 lib/truemail/logger.rb
truemail-1.7.0 lib/truemail/logger.rb
truemail-1.6.1 lib/truemail/logger.rb
truemail-1.6.0 lib/truemail/logger.rb
truemail-1.5.1 lib/truemail/logger.rb
truemail-1.5.0 lib/truemail/logger.rb