3 * log4php is a PHP port of the log4j java logging package.
5 * <p>This framework is based on log4j (see {@link http://jakarta.apache.org/log4j log4j} for details).</p>
6 * <p>Design, strategies and part of the methods documentation are developed by log4j team
7 * (Ceki Gülcü as log4j project founder and
8 * {@link http://jakarta.apache.org/log4j/docs/contributors.html contributors}).</p>
10 * <p>PHP port, extensions and modifications by VxR. All rights reserved.<br>
11 * For more information, please see {@link http://www.vxr.it/log4php/}.</p>
13 * <p>This software is published under the terms of the LGPL License
14 * a copy of which has been included with this distribution in the LICENSE file.</p>
17 * @subpackage appenders
23 if (!defined('LOG4PHP_DIR')) define('LOG4PHP_DIR', dirname(__FILE__) . '/..');
25 require_once(LOG4PHP_DIR . '/LoggerAppenderSkeleton.php');
26 require_once(LOG4PHP_DIR . '/LoggerLog.php');
29 * Appends log events to mail using php function {@link PHP_MANUAL#mail}.
31 * <p>Parameters are {@link $from}, {@link $to}, {@link $subject}.</p>
32 * <p>This appender requires a layout.</p>
34 * @author VxR <vxr@vxr.it>
35 * @version $Revision: 2 $
37 * @subpackage appenders
39 class LoggerAppenderMail extends LoggerAppenderSkeleton {
42 * @var string 'from' field
47 * @var string 'subject' field
49 var $subject = 'Log4php Report';
52 * @var string 'to' field
57 * @var string used to create mail body
65 var $requiresLayout = true;
70 * @param string $name appender name
72 function LoggerAppenderMail($name)
74 $this->LoggerAppenderSkeleton($name);
77 function activateOptions()
79 $this->closed = false;
85 $from = $this->getFrom();
88 if (!empty($this->body) and $from !== null and $to !== null and $this->layout !== null) {
90 $subject = $this->getSubject();
92 LoggerLog::debug("LoggerAppenderMail::close() sending mail from=[{$from}] to=[{$to}] subject=[{$subject}]");
96 $this->layout->getHeader() . $this->body . $this->layout->getFooter(),
100 $this->closed = true;
114 function getSubject()
116 return $this->subject;
127 function setSubject($subject)
129 $this->subject = $subject;
137 function setFrom($from)
142 function append($event)
144 if ($this->layout !== null)
145 $this->body .= $this->layout->format($event);