Class: OpenAISwarm::Logger

Inherits:
Object
  • Object
show all
Defined in:
lib/ruby-openai-swarm/logger.rb

Constant Summary collapse

SEVERITY_COLORS =
{
  'DEBUG' => "\e[36m", # Cyan
  'INFO'  => "\e[32m", # Green
  'WARN'  => "\e[33m", # Yellow
  'ERROR' => "\e[31m", # Red
  'FATAL' => "\e[35m", # Purple
  'ANY'   => "\e[0m"   # Reset color
}.freeze

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initializeLogger

Returns a new instance of Logger.



19
20
21
# File 'lib/ruby-openai-swarm/logger.rb', line 19

def initialize
  @loggers = {}
end

Class Method Details

.instanceObject



15
16
17
# File 'lib/ruby-openai-swarm/logger.rb', line 15

def self.instance
  @instance ||= new
end

Instance Method Details

#logger(log_path = nil) ⇒ Object



23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
# File 'lib/ruby-openai-swarm/logger.rb', line 23

def logger(log_path = nil)
  return OpenAISwarm.configuration.logger if OpenAISwarm.configuration.logger
  return @loggers[log_path] if @loggers[log_path]

  path = determine_log_path(log_path)
  ensure_log_directory(path)

  logger = ::Logger.new(path)
  logger.formatter = proc do |severity, datetime, progname, msg|
    color = SEVERITY_COLORS[severity] || SEVERITY_COLORS['ANY']
    reset = SEVERITY_COLORS['ANY']
    "[#{datetime}] #{color}#{severity}#{reset} OpenAISwarm: #{msg}\n"
  end

  @loggers[log_path] = logger
end