Просмотр исходного кода

Merge remote-tracking branch 'moderndeveloperllc/master'

Jordi Boggiano 12 лет назад
Родитель
Сommit
5d91d4145f
1 измененных файлов с 78 добавлено и 3 удалено
  1. 78 3
      src/Monolog/Handler/NativeMailerHandler.php

+ 78 - 3
src/Monolog/Handler/NativeMailerHandler.php

@@ -17,16 +17,46 @@ use Monolog\Logger;
  * 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 address to which the message is delivered
+     * @var string
+     */
     protected $to;
+
+    /**
+     * The subject of the email
+     * @var string
+     */
     protected $subject;
-    protected $headers = array(
-        'Content-type: text/plain; charset=utf-8'
-    );
+
+    /**
+     * Optional headers for the message
+     * @var array
+     */
+    protected $headers = array();
+
+    /**
+     * The wordwrap length for the message
+     * @var integer
+     */
     protected $maxColumnWidth;
 
+    /**
+     * The Content-type for the message
+     * @var string
+     */
+    protected $contentType = 'text/plain';
+
+    /**
+     * 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
@@ -45,7 +75,10 @@ class NativeMailerHandler extends MailHandler
     }
 
     /**
+     * Add headers to the message
+     *
      * @param string|array $headers Custom added headers
+     * @return null
      */
     public function addHeader($headers)
     {
@@ -64,8 +97,50 @@ class NativeMailerHandler extends MailHandler
     {
         $content = wordwrap($content, $this->maxColumnWidth);
         $headers = implode("\r\n", $this->headers) . "\r\n";
+        $headers .= 'Content-type: ' . $this->getContentType() . '; charset=' . $this->getEncoding() . "\r\n";
+        if ($this->getContentType() == 'text/html' && false === strpos($headers, 'MIME-Version:')) {
+            $headers .= 'MIME-Version: 1.0' . "\r\n";
+        }
         foreach ($this->to as $to) {
             mail($to, $this->subject, $content, $headers);
         }
     }
+
+    /**
+     * @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)
+    {
+        $this->contentType = $contentType;
+        return $this;
+    }
+
+
+    /**
+     * @param string $encoding
+     * @return self
+     */
+    public function setEncoding($encoding)
+    {
+        $this->encoding = $encoding;
+        return $this;
+    }
 }