Class: Wovnrb::WovnLogger

Inherits:
Object
  • Object
show all
Includes:
Singleton
Defined in:
lib/wovnrb/services/wovn_logger.rb

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initializeWovnLogger

Returns a new instance of WovnLogger.



20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
# File 'lib/wovnrb/services/wovn_logger.rb', line 20

def initialize
  @uuid = SecureRandom.uuid
  path = Store.instance.settings['log_path']
  if path
    begin
      @logger = Logger.new(path)
    rescue
      begin
        @logger = Logger.new('wovn_error.log')
        @logger.error("Wovn Error: log_path(#{path}) is invalid, please change log_path at config")
      rescue
        @logger = $stderr
        $stderr.puts("Wovn Error: log_path(#{path}) is invalid, please change log_path at config")
      end
    end
  else
    @logger = $stderr
  end
end

Instance Attribute Details

#uuidObject (readonly)

Returns the value of attribute uuid.



6
7
8
# File 'lib/wovnrb/services/wovn_logger.rb', line 6

def uuid
  @uuid
end

Class Method Details

.error(message) ⇒ Object



11
12
13
# File 'lib/wovnrb/services/wovn_logger.rb', line 11

def error(message)
  instance.error(message)
end

.uuidObject



15
16
17
# File 'lib/wovnrb/services/wovn_logger.rb', line 15

def uuid
  instance.uuid
end

Instance Method Details

#error(message) ⇒ Object



48
49
50
51
52
53
54
# File 'lib/wovnrb/services/wovn_logger.rb', line 48

def error(message)
  if @logger == $stderr
    @logger.puts "[#{@uuid}] Wovnrb Error: #{message}"
  else
    @logger.error "[#{@uuid}] #{message}"
  end
end

#set_logger(logger) ⇒ Object



40
41
42
43
44
45
46
# File 'lib/wovnrb/services/wovn_logger.rb', line 40

def set_logger(logger)
  [:error].each do |method|
    raise 'not suite for logger' unless logger.respond_to? method
  end

  @logger = logger
end