mirror of
				https://github.com/Seldaek/monolog.git
				synced 2025-10-25 10:36:33 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			191 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			191 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php declare(strict_types=1);
 | |
| 
 | |
| /*
 | |
|  * This file is part of the Monolog package.
 | |
|  *
 | |
|  * (c) Jordi Boggiano <j.boggiano@seld.be>
 | |
|  *
 | |
|  * For the full copyright and license information, please view the LICENSE
 | |
|  * file that was distributed with this source code.
 | |
|  */
 | |
| 
 | |
| namespace Monolog\Handler;
 | |
| 
 | |
| use Monolog\Logger;
 | |
| use Monolog\Formatter\LineFormatter;
 | |
| 
 | |
| /**
 | |
|  * NativeMailerHandler uses the mail() function to send the emails
 | |
|  *
 | |
|  * @author Christophe Coevoet <stof@notk.org>
 | |
|  * @author Mark Garrett <mark@moderndeveloperllc.com>
 | |
|  */
 | |
| class NativeMailerHandler extends MailHandler
 | |
| {
 | |
|     /**
 | |
|      * The email addresses to which the message will be sent
 | |
|      * @var array
 | |
|      */
 | |
|     protected $to;
 | |
| 
 | |
|     /**
 | |
|      * The subject of the email
 | |
|      * @var string
 | |
|      */
 | |
|     protected $subject;
 | |
| 
 | |
|     /**
 | |
|      * Optional headers for the message
 | |
|      * @var array
 | |
|      */
 | |
|     protected $headers = [];
 | |
| 
 | |
|     /**
 | |
|      * Optional parameters for the message
 | |
|      * @var array
 | |
|      */
 | |
|     protected $parameters = [];
 | |
| 
 | |
|     /**
 | |
|      * The wordwrap length for the message
 | |
|      * @var int
 | |
|      */
 | |
|     protected $maxColumnWidth;
 | |
| 
 | |
|     /**
 | |
|      * The Content-type for the message
 | |
|      * @var string
 | |
|      */
 | |
|     protected $contentType;
 | |
| 
 | |
|     /**
 | |
|      * The encoding for the message
 | |
|      * @var string
 | |
|      */
 | |
|     protected $encoding = 'utf-8';
 | |
| 
 | |
|     /**
 | |
|      * @param string|array $to             The receiver of the mail
 | |
|      * @param string       $subject        The subject of the mail
 | |
|      * @param string       $from           The sender of the mail
 | |
|      * @param int          $level          The minimum logging level at which this handler will be triggered
 | |
|      * @param bool         $bubble         Whether the messages that are handled can bubble up the stack or not
 | |
|      * @param int          $maxColumnWidth The maximum column width that the message lines will have
 | |
|      */
 | |
|     public function __construct($to, $subject, $from, $level = Logger::ERROR, $bubble = true, $maxColumnWidth = 70)
 | |
|     {
 | |
|         parent::__construct($level, $bubble);
 | |
|         $this->to = (array) $to;
 | |
|         $this->subject = $subject;
 | |
|         $this->addHeader(sprintf('From: %s', $from));
 | |
|         $this->maxColumnWidth = $maxColumnWidth;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Add headers to the message
 | |
|      *
 | |
|      * @param  string|array $headers Custom added headers
 | |
|      * @return self
 | |
|      */
 | |
|     public function addHeader($headers)
 | |
|     {
 | |
|         foreach ((array) $headers as $header) {
 | |
|             if (strpos($header, "\n") !== false || strpos($header, "\r") !== false) {
 | |
|                 throw new \InvalidArgumentException('Headers can not contain newline characters for security reasons');
 | |
|             }
 | |
|             $this->headers[] = $header;
 | |
|         }
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Add parameters to the message
 | |
|      *
 | |
|      * @param  string|array $parameters Custom added parameters
 | |
|      * @return self
 | |
|      */
 | |
|     public function addParameter($parameters)
 | |
|     {
 | |
|         $this->parameters = array_merge($this->parameters, (array) $parameters);
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * {@inheritdoc}
 | |
|      */
 | |
|     protected function send(string $content, array $records)
 | |
|     {
 | |
|         $contentType = $this->getContentType() ?: ($this->isHtmlBody($content) ? 'text/html' : 'text/plain');
 | |
| 
 | |
|         if ($contentType !== 'text/html') {
 | |
|             $content = wordwrap($content, $this->maxColumnWidth);
 | |
|         }
 | |
| 
 | |
|         $headers = ltrim(implode("\r\n", $this->headers) . "\r\n", "\r\n");
 | |
|         $headers .= 'Content-type: ' . $contentType . '; charset=' . $this->getEncoding() . "\r\n";
 | |
|         if ($contentType === 'text/html' && false === strpos($headers, 'MIME-Version:')) {
 | |
|             $headers .= 'MIME-Version: 1.0' . "\r\n";
 | |
|         }
 | |
| 
 | |
|         $subject = $this->subject;
 | |
|         if ($records) {
 | |
|             $subjectFormatter = new LineFormatter($this->subject);
 | |
|             $subject = $subjectFormatter->format($this->getHighestRecord($records));
 | |
|         }
 | |
| 
 | |
|         $parameters = implode(' ', $this->parameters);
 | |
|         foreach ($this->to as $to) {
 | |
|             mail($to, $subject, $content, $headers, $parameters);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @return string $contentType
 | |
|      */
 | |
|     public function getContentType()
 | |
|     {
 | |
|         return $this->contentType;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @return string $encoding
 | |
|      */
 | |
|     public function getEncoding()
 | |
|     {
 | |
|         return $this->encoding;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param  string $contentType The content type of the email - Defaults to text/plain. Use text/html for HTML
 | |
|      *                             messages.
 | |
|      * @return self
 | |
|      */
 | |
|     public function setContentType($contentType)
 | |
|     {
 | |
|         if (strpos($contentType, "\n") !== false || strpos($contentType, "\r") !== false) {
 | |
|             throw new \InvalidArgumentException('The content type can not contain newline characters to prevent email header injection');
 | |
|         }
 | |
| 
 | |
|         $this->contentType = $contentType;
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param  string $encoding
 | |
|      * @return self
 | |
|      */
 | |
|     public function setEncoding($encoding)
 | |
|     {
 | |
|         if (strpos($encoding, "\n") !== false || strpos($encoding, "\r") !== false) {
 | |
|             throw new \InvalidArgumentException('The encoding can not contain newline characters to prevent email header injection');
 | |
|         }
 | |
| 
 | |
|         $this->encoding = $encoding;
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| }
 |