Sha256: 241183fd42c970371ebee67d643f57a3db059d3a48850b00ea3e2e467c34de1c

Contents?: true

Size: 821 Bytes

Versions: 42

Compression:

Stored size: 821 Bytes

Contents

module Rex
module Logging
module Sinks

###
#
# This class implements the LogSink interface and backs it against a 
# file on disk.
#
###
class Flatfile

	include Rex::Logging::LogSink

	#
	# Creates a flatfile log sink instance that will be configured to log to
	# the supplied file path.
	#
	def initialize(file)
		self.fd = File.new(file, "a")
	end

	def cleanup # :nodoc:
		fd.close
	end

	def log(sev, src, level, msg, from) # :nodoc:
		if (sev == LOG_RAW)
			fd.write(msg)
		else
			code = 'i'

			case sev
				when LOG_DEBUG
					code = 'd'
				when LOG_ERROR
					code = 'e'
				when LOG_INFO
					code = 'i'
				when LOG_WARN
					code = 'w'
			end
			fd.write("[#{get_current_timestamp}] [#{code}(#{level})] #{src}: #{msg}\n")
		end
			
		fd.flush
	end

protected

	attr_accessor :fd # :nodoc:

end

end end end

Version data entries

42 entries across 42 versions & 1 rubygems

Version Path
librex-0.0.35 lib/rex/logging/sinks/flatfile.rb
librex-0.0.34 lib/rex/logging/sinks/flatfile.rb
librex-0.0.33 lib/rex/logging/sinks/flatfile.rb
librex-0.0.32 lib/rex/logging/sinks/flatfile.rb
librex-0.0.30 lib/rex/logging/sinks/flatfile.rb
librex-0.0.29 lib/rex/logging/sinks/flatfile.rb
librex-0.0.28 lib/rex/logging/sinks/flatfile.rb
librex-0.0.27 lib/rex/logging/sinks/flatfile.rb
librex-0.0.26 lib/rex/logging/sinks/flatfile.rb
librex-0.0.25 lib/rex/logging/sinks/flatfile.rb
librex-0.0.23 lib/rex/logging/sinks/flatfile.rb
librex-0.0.21 lib/rex/logging/sinks/flatfile.rb
librex-0.0.19 lib/rex/logging/sinks/flatfile.rb
librex-0.0.17 lib/rex/logging/sinks/flatfile.rb
librex-0.0.13 lib/rex/logging/sinks/flatfile.rb
librex-0.0.12 lib/rex/logging/sinks/flatfile.rb
librex-0.0.7 lib/rex/logging/sinks/flatfile.rb
librex-0.0.6 lib/rex/logging/sinks/flatfile.rb
librex-0.0.5 lib/rex/logging/sinks/flatfile.rb
librex-0.0.4 lib/rex/logging/sinks/flatfile.rb