* 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! * * * @version $Revision$ * @package log4php * @subpackage appenders */ class LoggerAppenderMailEvent extends LoggerAppender { /** * @var string 'from' field */ private $from = null; /** * @var integer 'from' field */ private $port = 25; /** * @var string hostname. */ private $smtpHost = null; /** * @var string 'subject' field */ private $subject = ''; /** * @var string 'to' field */ private $to = null; /** * @access private */ protected $requiresLayout = true; /** @var indiciates if this appender should run in dry mode */ private $dry = false; /** * Constructor. * * @param string $name appender name */ public function __construct($name = '') { parent::__construct($name); } public function __destruct() { $this->close(); } public function activateOptions() { $this->closed = false; } public function close() { $this->closed = true; } public function setFrom($from) { $this->from = $from; } public function setPort($port) { $this->port = (int)$port; } public function setSmtpHost($smtpHost) { $this->smtpHost = $smtpHost; } public function setSubject($subject) { $this->subject = $subject; } public function setTo($to) { $this->to = $to; } public function setDry($dry) { $this->dry = $dry; } public function append(LoggerLoggingEvent $event) { $from = $this->from; $to = $this->to; if(empty($from) or empty($to)) { return; } $smtpHost = $this->smtpHost; $prevSmtpHost = ini_get('SMTP'); if(!empty($smtpHost)) { ini_set('SMTP', $smtpHost); } else { $smtpHost = $prevSmtpHost; } $smtpPort = $this->port; $prevSmtpPort= ini_get('smtp_port'); if($smtpPort > 0 and $smtpPort < 65535) { ini_set('smtp_port', $smtpPort); } else { $smtpPort = $prevSmtpPort; } if(!$this->dry) { @mail($to, $this->getSubject(), $this->layout->getHeader() . $this->layout->format($event) . $this->layout->getFooter($event), "From: {$from}\r\n"); } else { echo "DRY MODE OF MAIL APP.: Send mail to: ".$to." with content: ".$this->layout->format($event); } ini_set('SMTP', $prevSmtpHost); ini_set('smtp_port', $prevSmtpPort); } }