Class: RemoteSyslogLogger::Sender

Inherits:
Object
  • Object
show all
Defined in:
lib/remote_syslog_logger/sender.rb

Direct Known Subclasses

TcpSender, UdpSender

Instance Method Summary collapse

Constructor Details

#initialize(remote_hostname, remote_port, options = {}) ⇒ Sender

Returns a new instance of Sender.



6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
# File 'lib/remote_syslog_logger/sender.rb', line 6

def initialize(remote_hostname, remote_port, options = {})
  @remote_hostname = remote_hostname
  @remote_port     = remote_port
  @whinyerrors     = options[:whinyerrors]

  @packet = SyslogProtocol::Packet.new

  local_hostname   = options[:local_hostname] || (Socket.gethostname rescue `hostname`.chomp)
  local_hostname   = 'localhost' if local_hostname.nil? || local_hostname.empty?
  @packet.hostname = local_hostname

  @packet.facility = options[:facility] || 'user'
  @packet.severity = options[:severity] || 'notice'
  @packet.tag      = options[:program]  || "#{File.basename($0)}[#{$$}]"

  @socket = nil
end

Instance Method Details

#closeObject



41
42
43
# File 'lib/remote_syslog_logger/sender.rb', line 41

def close
  @socket.close
end

#transmit(message) ⇒ Object Also known as: write



24
25
26
27
28
29
30
31
32
33
34
35
36
# File 'lib/remote_syslog_logger/sender.rb', line 24

def transmit(message)
  message.split(/\r?\n/).each do |line|
    begin
      next if line =~ /^\s*$/
      packet = @packet.dup
      packet.content = line
      send_msg(packet.assemble)
    rescue
      $stderr.puts "#{self.class} error: #{$!.class}: #{$!}\nOriginal message: #{line}"
      raise if @whinyerrors
    end
  end
end