Class: ManageEngine::APMLogger

Inherits:
Object
  • Object
show all
Defined in:
lib/agent/logging/am_logger.rb

Instance Method Summary collapse

Constructor Details

#initializeAPMLogger

Returns a new instance of APMLogger.



9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
# File 'lib/agent/logging/am_logger.rb', line 9

def initialize
	@obj=ManageEngine::APMObjectHolder.instance
	path = getLogsPath
	#puts "#{path}"
	if  Dir[path] == []
		Dir.mkdir(path)
	end
	@apmLogPath= path + '/apm.log'
	#puts "#{path}"
#			file = open(path, File::WRONLY | File::APPEND | File::CREAT)
    begin
      @apmlog = Logger.new(@apmLogPath, 10, 5 * 1024 * 1024)
      @apmlog.level = Logger::INFO
    rescue Exception => e
      puts "Unable to create/edit the log file #{@apmLogPath}. Writing agent logs to STDOUT.\nError: #{e.message}"
      @apmlog = Logger.new(STDOUT)
      @apmlog.level = Logger::WARN
    end
    # @apmlog = Logger.new(file)
    @apmlog.datetime_format = "%Y-%m-%d %H:%M:%S" 
	@apmlog.formatter = proc do |severity, datetime, progname, msg|
		"[#{datetime}|#{Process.pid}][#{severity}]:#{msg}\n"
	end
	@apmlog.debug("[LOGGER] APM Agent Logging Initialized")

end

Instance Method Details

#closeObject



114
115
116
# File 'lib/agent/logging/am_logger.rb', line 114

def close
	@apmlog.close
end

#debug(msg) ⇒ Object



92
93
94
# File 'lib/agent/logging/am_logger.rb', line 92

def debug(msg)
	@apmlog.debug(msg)
end

#error(msg) ⇒ Object



100
101
102
# File 'lib/agent/logging/am_logger.rb', line 100

def error(msg)
	@apmlog.error(msg)
end

#fatal(msg) ⇒ Object



104
105
106
# File 'lib/agent/logging/am_logger.rb', line 104

def fatal(msg)
	@apmlog.fatal(msg)
end

#getLogFilePathObject



36
37
38
# File 'lib/agent/logging/am_logger.rb', line 36

def getLogFilePath
  return @apmLogPath
end

#getLogsPathObject



40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
# File 'lib/agent/logging/am_logger.rb', line 40

def	getLogsPath
	props = {}
	begin
		if FileTest.exists?(@obj.constants.apm_conf)
		propsFile=File.open(@obj.constants.apm_conf, 'r') 
		propsFile.read.each_line do |line|
			line.strip!
			if (line[0] != ?# and line[0] != ?=)
				i = line.index('=')
				if (i)
					props[line[0..i - 1].strip] = line[i + 1..-1].strip
				else
					props[line] = ''
				end
			end
		end
		else
			puts "ManageEngine Ruby Agent Configuration File Not exist in #{@obj.constants.apm_conf}.\n Duplicate file will be available in <Gems Folder>/apm-agent/lib/config "
		end
	rescue Exception=>e
		puts "Problem in Reading Property File : \n #{e.message} \n  #{e.backtrace}"
	ensure
		#
	end
	if props["apminsight.log.dir"]!=nil
		return props["apminsight.log.dir"]
	else
		return @obj.constants.conf_location+"log"
	end

end

#info(msg) ⇒ Object



88
89
90
# File 'lib/agent/logging/am_logger.rb', line 88

def info(msg)
	@apmlog.info(msg)
end

#logException(msg, e) ⇒ Object



109
110
111
112
# File 'lib/agent/logging/am_logger.rb', line 109

def logException(msg,e)
	@apmlog.warn( "#{msg} => #{e.message}")
	@apmlog.warn( "Message  : #{msg}\nTrace :\n#{e.backtrace}")
end

#setLevel(level) ⇒ Object



72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
# File 'lib/agent/logging/am_logger.rb', line 72

def setLevel level
	level =  level.upcase
	case level.upcase 
	when "INFO" then @apmlog.level = Logger::INFO
	when "DEBUG" then @apmlog.level = Logger::DEBUG
	when "WARN" then @apmlog.level = Logger::WARN
	when "ERROR" then @apmlog.level = Logger::ERROR
	when "FATAL" then @apmlog.level = Logger::FATAL
	when "FINE" then @apmlog.level = Logger::DEBUG
	when "SEVERE" then @apmlog.level = Logger::ERROR
	when "WARNING" then @apmlog.level = Logger::WARN
	else 
		@apmlog.level = Logger::DEBUG
	end
end

#warn(msg) ⇒ Object



96
97
98
# File 'lib/agent/logging/am_logger.rb', line 96

def warn(msg)
	@apmlog.warn(msg)
end