* Date: Tue, 8 Sep 2009 21:51:04 +0200 (CEST) * From: someone@example.com * To: root@localhost * Subject: Log4php test * * Tue Sep 8 21:51:04 2009,120 [5485] FATAL root - Some critical message! * Tue Sep 8 21:51:06 2009,120 [5485] FATAL root - Some more critical message! * * @version $Revision: 883108 $ * @package log4php * @subpackage appenders */ class LoggerAppenderMail extends LoggerAppender { /** @var string 'from' field */ private $from = null; /** @var string 'subject' field */ private $subject = 'Log4php Report'; /** @var string 'to' field */ private $to = null; /** @var indiciates if this appender should run in dry mode */ private $dry = false; /** @var string used to create mail body */ private $body = ''; /** * Constructor. * * @param string $name appender name */ public function __construct($name = '') { parent::__construct($name); $this->requiresLayout = true; } public function __destruct() { $this->close(); } public function activateOptions() { $this->closed = false; } public function close() { if($this->closed != true) { $from = $this->from; $to = $this->to; if(!empty($this->body) and $from !== null and $to !== null and $this->layout !== null) { $subject = $this->subject; if(!$this->dry) { mail( $to, $subject, $this->layout->getHeader() . $this->body . $this->layout->getFooter(), "From: {$from}\r\n"); } else { echo "DRY MODE OF MAIL APP.: Send mail to: ".$to." with content: ".$this->body; } } $this->closed = true; } } public function setSubject($subject) { $this->subject = $subject; } public function setTo($to) { $this->to = $to; } public function setFrom($from) { $this->from = $from; } public function setDry($dry) { $this->dry = $dry; } public function append(LoggerLoggingEvent $event) { if($this->layout !== null) { $this->body .= $this->layout->format($event); } } }