Sha256: 6f72f815f7995b1ce7466987a979c3e7c8a70592c260353f850f17f41f4f10d2

Contents?: true

Size: 1.01 KB

Versions: 16

Compression:

Stored size: 1.01 KB

Contents

require 'logger'

class KuberKit::Tools::LoggerFactory
  SEVERITY_COLORS_BY_LEVEL = {
    Logger::INFO   => String::Colors::GREEN,
    Logger::WARN   => String::Colors::PURPLE,
    Logger::DEBUG  => String::Colors::YELLOW,
    Logger::ERROR  => String::Colors::RED,
    Logger::FATAL  => String::Colors::PURPLE,
  }

  include KuberKit::Import[
    "configs",
  ]

  def create(stdout = nil, level = nil)
    logger = Logger.new(stdout || configs.log_file_path)

    logger.level = level || Logger::DEBUG

    logger.formatter = proc do |severity, datetime, progname, msg|
      level = Logger::SEV_LABEL.index(severity)

      severity_color = SEVERITY_COLORS_BY_LEVEL[level]

      severity_text  = severity.to_s
      severity_text  = severity_text.colorize(severity_color) if severity_color

      if level == Logger::DEBUG
        "#{datetime.strftime("%Y/%m/%d %H:%M:%S").grey} #{msg}\n"
      else
        "#{datetime.strftime("%Y/%m/%d %H:%M:%S").grey} #{severity_text.downcase}: #{msg}\n"
      end
    end

    logger
  end
end

Version data entries

16 entries across 16 versions & 1 rubygems

Version Path
kuber_kit-0.5.5 lib/kuber_kit/tools/logger_factory.rb
kuber_kit-0.5.4 lib/kuber_kit/tools/logger_factory.rb
kuber_kit-0.5.3 lib/kuber_kit/tools/logger_factory.rb
kuber_kit-0.5.2 lib/kuber_kit/tools/logger_factory.rb
kuber_kit-0.5.1 lib/kuber_kit/tools/logger_factory.rb
kuber_kit-0.5.0 lib/kuber_kit/tools/logger_factory.rb
kuber_kit-0.4.9 lib/kuber_kit/tools/logger_factory.rb
kuber_kit-0.4.8 lib/kuber_kit/tools/logger_factory.rb
kuber_kit-0.4.7 lib/kuber_kit/tools/logger_factory.rb
kuber_kit-0.4.6 lib/kuber_kit/tools/logger_factory.rb
kuber_kit-0.4.5 lib/kuber_kit/tools/logger_factory.rb
kuber_kit-0.4.4 lib/kuber_kit/tools/logger_factory.rb
kuber_kit-0.4.3 lib/kuber_kit/tools/logger_factory.rb
kuber_kit-0.4.2 lib/kuber_kit/tools/logger_factory.rb
kuber_kit-0.4.1 lib/kuber_kit/tools/logger_factory.rb
kuber_kit-0.4.0 lib/kuber_kit/tools/logger_factory.rb