|
EmailOutputterThis is an experimental class. It should work fine if Net:SMTP doesn't give you any problems. Just in case, create a logger named 'log4r' and give it an outputter to see the logging statements made by this class. If it fails to send email, it will set itself to OFF and stop logging. In order to use it, require 'log4r/outputter/emailoutputter' SMTP ConfigurationAll arguments to Net::SMTP.start are supported. Pass them as hash parameters to new. The to field is specified as a comma-delimited list of emails (padded with \s* if desired). An example: EmailOutputter.new 'myemail', :server=>'localhost', :port=>25, :domain=>'somewhere.com', :from=>'me@foo.bar', :to=>'them@foo.bar, me@foo.bar, bozo@clown.net' LogEvent BufferThis class has an internal LogEvent buffer to let you accumulate a bunch of log messages per email. Specify the size of the buffer with the hash parameter buffsize. The default is 100. Flush MeWhen shutting down your program, you might want to call flush on this outputter to send the remaining LogEvents. Might as well flush everything while you're at it: Outputter.each_outputter {|o| o.flush} Format When?You may choose to format the LogEvents as they come in or as the email is being composed. To do the former, specify a value of true to the hash parameter formatfirst. The default is to format during email composition. Immediate NotificationIf you want certain log priorities to trigger an immediate email, set the hash parameter immediate_at to a string list of comma-delimited trigger levels (padded by \s* if desired). ExampleA security logger sends email to several folks, buffering up to 25 log events and sending immediates on CRIT and WARN EmailOutputter.new 'security', :to => 'bob@secure.net, frank@secure.net', :buffsize => 25, :immediate_at => 'WARN, CRIT' XML ConfigurationSee log4r/configurator.rb for details. Here's an example: <outputter name="security" type="EmailOutputter" buffsize="25" level="ALL"> <immediate_at>WARN, CRIT</immediate_at> <server>localhost</server> <from>me@secure.net</from> <to> bob@secure.net, frank@secure.net </to> ... </outputter>
send out an email with the current buffer |