Class: StructuredEventLogger::Syslogger

Inherits:
Object
  • Object
show all
Defined in:
lib/structured_event_logger/syslogger.rb

Defined Under Namespace

Classes: MessageExceedsMaximumSize

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(log_level = Syslog::LOG_INFO, max_size = 64 * 1024 - 1) ⇒ Syslogger

Returns a new instance of Syslogger.



11
12
13
# File 'lib/structured_event_logger/syslogger.rb', line 11

def initialize(log_level = Syslog::LOG_INFO, max_size = 64 * 1024 - 1)
  @log_level, @max_size = log_level, max_size
end

Instance Attribute Details

#log_levelObject

Returns the value of attribute log_level.



9
10
11
# File 'lib/structured_event_logger/syslogger.rb', line 9

def log_level
  @log_level
end

#max_sizeObject

Returns the value of attribute max_size.



9
10
11
# File 'lib/structured_event_logger/syslogger.rb', line 9

def max_size
  @max_size
end

Instance Method Details

#call(scope, event, hash, record) ⇒ Object



15
16
17
18
19
# File 'lib/structured_event_logger/syslogger.rb', line 15

def call(scope, event, hash, record)
  message = MultiJson.encode(record)
  raise MessageExceedsMaximumSize, "Event too big to be submitted to syslog" if message.bytesize > max_size
  Syslog.log(log_level, '%s', message)
end