Class: Semlogr::Events::LogEvent

Inherits:
Object
  • Object
show all
Defined in:
lib/semlogr/events/log_event.rb

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(severity, template, error: nil, **properties) ⇒ LogEvent

Returns a new instance of LogEvent.



12
13
14
15
16
17
18
# File 'lib/semlogr/events/log_event.rb', line 12

def initialize(severity, template, error: nil, **properties)
  @timestamp = Time.now.utc
  @severity = severity
  @template = template
  @error = error
  @properties = properties
end

Instance Attribute Details

#errorObject (readonly)

Returns the value of attribute error.



8
9
10
# File 'lib/semlogr/events/log_event.rb', line 8

def error
  @error
end

#propertiesObject (readonly)

Returns the value of attribute properties.



9
10
11
# File 'lib/semlogr/events/log_event.rb', line 9

def properties
  @properties
end

#severityObject (readonly)

Returns the value of attribute severity.



6
7
8
# File 'lib/semlogr/events/log_event.rb', line 6

def severity
  @severity
end

#templateObject (readonly)

Returns the value of attribute template.



7
8
9
# File 'lib/semlogr/events/log_event.rb', line 7

def template
  @template
end

#timestampObject (readonly)

Returns the value of attribute timestamp.



10
11
12
# File 'lib/semlogr/events/log_event.rb', line 10

def timestamp
  @timestamp
end

Class Method Details

.create(severity, template, properties) ⇒ Object



20
21
22
23
24
# File 'lib/semlogr/events/log_event.rb', line 20

def self.create(severity, template, properties)
  template = Templates::Parser.parse(template)

  LogEvent.new(severity, template, properties)
end

Instance Method Details

#add_property(properties) ⇒ Object



30
31
32
# File 'lib/semlogr/events/log_event.rb', line 30

def add_property(properties)
  @properties.merge!(properties)
end

#add_property_if_absent(properties) ⇒ Object



34
35
36
# File 'lib/semlogr/events/log_event.rb', line 34

def add_property_if_absent(properties)
  @properties.merge!(properties) { |_, old, _| old }
end

#get_property(name) ⇒ Object



26
27
28
# File 'lib/semlogr/events/log_event.rb', line 26

def get_property(name)
  @properties[name]
end

#render(output) ⇒ Object



38
39
40
# File 'lib/semlogr/events/log_event.rb', line 38

def render(output)
  @template.render(output, @properties)
end

#to_sObject



42
43
44
45
46
47
48
# File 'lib/semlogr/events/log_event.rb', line 42

def to_s
  output = ''

  render(output)

  output
end