From 7fe908c50c8dbc5cc05f571dbe11d66141caacd4 Mon Sep 17 00:00:00 2001
From: Marius Cramer <m.cramer@pixcept.de>
Date: Thu, 14 Nov 2013 09:01:22 -0500
Subject: [PATCH] Cleaning up code to match coding guidelines

---
 interface/lib/classes/ispcmail.inc.php | 1383 +++++++++++++++++++++++++++++---------------------------
 1 files changed, 719 insertions(+), 664 deletions(-)

diff --git a/interface/lib/classes/ispcmail.inc.php b/interface/lib/classes/ispcmail.inc.php
index d49af96..dff71f3 100644
--- a/interface/lib/classes/ispcmail.inc.php
+++ b/interface/lib/classes/ispcmail.inc.php
@@ -30,498 +30,544 @@
 
 /**
  * email class
- * 
+ *
  * @package pxFramework
  *
  */
+
+
 class ispcmail {
-    
-    /**#@+
+
+	/**#@+
      * @access private
      */
-    private $html_part;
-    private $text_part;
-    
-    private $headers;
-    
-    private $_logged_in = false;
-    private $_smtp_conn = null;
-    
-    private $_crlf = "\n";
-    
-    private $attach_type = 'application/octet-stream';
-    private $attachments;
-    private $mime_boundary;
-    private $body = '';
-    private $_mail_sender = '';
-    private $_sent_mails = 0;
-    private $user_agent = 'ISPConfig/3 (Mailer Class)';
-    /**#@-*/
-    
-    /**
-     * set the mail charset
-     */
-    private $mail_charset  = 'UTF-8';//'ISO-8859-1';
-    
-    /**#@+
+	private $html_part;
+	private $text_part;
+
+	private $headers;
+
+	private $_logged_in = false;
+	private $_smtp_conn = null;
+
+	private $_crlf = "\n";
+
+	private $attach_type = 'application/octet-stream';
+	private $attachments;
+	private $mime_boundary;
+	private $body = '';
+	private $_mail_sender = '';
+	private $_sent_mails = 0;
+	private $user_agent = 'ISPConfig/3 (Mailer Class)';
+	/**#@-*/
+
+
+
+	/**
+	 * set the mail charset
+	 */
+	private $mail_charset  = 'UTF-8';//'ISO-8859-1';
+
+	/**#@+
      * Provide smtp credentials for smtp mail sending
      *
      * @access public
      */
-    /**
-     * if set to true smtp is used instead of mail() to send emails
-     * @see mail
-     */
-    private $use_smtp = false;
-    /**
-     * the smtp helo string - use the mail server name here!
-     */
-    private $smtp_helo = '';
-    /**
-     * the smtp server to send mails
-     */
-    private $smtp_host = '';
-    /**
-     * the smtp port
-     */
-    private $smtp_port = 25;
-    /**
-     * if the smtp server needs authentication you can set the smtp user here
-     */
-    private $smtp_user = '';
-    /**
-     * if the smtp server needs authentication you can set the smtp password here
-     */
-    private $smtp_pass = '';
-    /**
-     * If you want to use tls/ssl specify it here
-     */
-    private $smtp_crypt = ''; // tls or ssl
-    /**
-     * How many mails should be sent via one single smtp connection
-     */
-    private $smtp_max_mails = 20;
-    /**
-     * Should the mail be signed
-     */
-    private $sign_email = false;
-    /**
-     * The cert and key to use for email signing
-     */
-    private $sign_key = '';
-    private $sign_key_pass = '';
-    private $sign_cert = '';
-    private $sign_bundle = '';
-    private $_is_signed = false;
-    /**
-     * get disposition notification
-     */
-    private $notification = false;
-    /**#@-*/
-    
-    public function __construct($options = array()) {
-        $rand = md5(microtime());
-        $this->mime_boundary = '==Multipart_Boundary_x' . $rand . 'x';
-        
-        $this->headers = array();
-        $this->attachments = array();
-        
-        $this->headers['MIME-Version'] = '1.0';
-        $this->headers['User-Agent'] = $this->user_agent;
-        if(is_array($options) && count($options) > 0) $this->setOptions($options);
-    }
-    
-    public function __destruct() {
-        $this->finish();
-    }
-    
-    /**
-     * Set option
-     * 
-     * @param string $key the option to set
-     * @param string $value the option value to set
-     */
-    public function setOption($key, $value) {
-        switch($key) {
-            case 'smtp_helo':
-                $this->smtp_helo = $value;
-                break;
-            case 'smtp_host':
-                $this->smtp_host = $value;
-                break;
-            case 'smtp_server':
-                $this->smtp_host = $value;
-                break;
-            case 'smtp_port':
-                $this->smtp_port = $value;
-                break;
-            case 'smtp_user':
-                $this->smtp_user = $value;
-                break;
-            case 'smtp_pass':
-                $this->smtp_pass = $value;
-                break;
-            case 'smtp_max_mails':
-                $this->smtp_max_mails = intval($value);
-                if($this->smtp_max_mails < 1) $this->smtp_max_mails = 1;
-                break;
-            case 'use_smtp':
-                $this->use_smtp = ($value == true ? true : false);
-                if($value == true) $this->_crlf = "\r\n";
-                break;
-            case 'smtp_crypt':
-                if($value != 'ssl' && $value != 'tls') $value = '';
-                $this->smtp_crypt = $value;
-                break;
-            case 'sign_email':
-                $this->sign_email = ($value == true ? true : false);
-                break;
-            case 'sign_key':
-                $this->sign_key = $value;
-                break;
-            case 'sign_key_pass':
-                $this->sign_key_pass = $value;
-                break;
-            case 'sign_cert':
-                $this->sign_cert = $value;
-                break;
-            case 'sign_bundle':
-                $this->sign_bundle = $value;
-                break;
-            case 'mail_charset':
-                $this->mail_charset = $value;
-                break;
-            case 'notify':
-                $this->notification = ($value == true ? true : false);
-                break;
-        }
-    }
-    
-    /** Detect the helo string if none given
-     * 
-     */
-    private function detectHelo() {
-        if(isset($_SERVER['HTTP_HOST'])) $this->smtp_helo = $_SERVER['HTTP_HOST'];
-        elseif(isset($_SERVER['SERVER_NAME'])) $this->smtp_helo = $_SERVER['SERVER_NAME'];
-        else $this->smtp_helo = php_uname('n');
-        if($this->smtp_helo == '') $this->smtp_helo = 'localhost';
-    }
-    
-    /**
-     * Set options
-     * 
-     * @param array $options the options to set as an associative array key => value
-     */
-    public function setOptions($options) {
-        foreach($options as $key => $value) $this->setOption($key, $value);
-    }
-    
-    /**
-     * Read a file's contents
-     *
-     * Simply gets the file's content
-     *
-     * @access public
-     * @param string $filename name and path of file to read
-     * @return string file content (can be binary)
-     */
-    public function read_File($filename) {
-        $content = '';
-        
-        $fp = fopen($filename, 'r');
-        if(!$fp) return false;
-        
-        while(!feof($fp)) {
-            $content .= fread($fp, 1024);
-        }
-        fclose($fp);
-        
-        return $content;
-    }
-    
-    /**
-     * set smtp connection encryption
-     * 
-     * @access public
-     * @param string $mode encryption mode (tls, ssl or empty string)
-     */
-    public function setSMTPEncryption($mode = '') {
-        if($mode != 'ssl' && $mode != 'tls') $mode = '';
-        $this->smtp_crypt = $mode;
-    }
 
-    /**
-     * set a mail header
-     *
-     * Sets a single mail header to a given value
-     *
-     * @access public
-     * @param string $header header name to set
-     * @param string $value value to set in header field
-     */
-    public function setHeader($header, $value) {
-        if(strtolower($header) == 'bcc') $header = 'Bcc';
-        elseif(strtolower($header) == 'cc') $header = 'Cc';
-        elseif(strtolower($header) == 'from') $header = 'From';
-        $this->headers["$header"] = $value;
-    }
-    
-    /**
-     * get a mail header value
-     *
-     * Returns a value of a single mail header
-     *
-     * @access public
-     * @param string $header header name to get
-     * @return string header value
-     */
-    public function getHeader($header) {
-        if(strtolower($header) == 'bcc') $header = 'Bcc';
-        elseif(strtolower($header) == 'cc') $header = 'Cc';
-        elseif(strtolower($header) == 'from') $header = 'From';
-        return (isset($this->headers["$header"]) ? $this->headers["$header"] : '');
-    }
-    
-    /**
-     * Set email sender
-     *
-     * Sets the email sender and optionally the sender's name
-     *
-     * @access public
-     * @param string $email sender email address
-     * @param string $name sender name
-     */
-    public function setSender($email, $name = '') {
-        if($name) $header = '"' . $name . '" <' . $email . '>';
-        else $header = '<' . $email . '>';
-        
-        $this->_mail_sender = $email;
-        
-        $this->setHeader('From', $header);
-    }
-    
-    /**
-     * Set mail subject
-     *
-     * @access public
-     * @param string $subject the mail subject
-     * @return string where-string for db query
-     */
-    public function setSubject($subject) {
-        $this->setHeader('Subject', $subject);
-    }
-    
-    /**
-     * Get current mail subject
-     *
-     * @access public
-     * @return string mail subject
-     */
-    public function getSubject() {
-        return $this->headers['Subject'];
-    }
-    
-    /**
-     * Set mail content
-     *
-     * Sets the mail html and plain text content
-     *
-     * @access public
-     * @param string $text plain text mail content (can be empty)
-     * @param string $html html mail content
-     */
-    public function setMailText($text, $html = '') {
-        $this->text_part = $text;
-        $this->html_part = $html;
-    }
-    
-    /**
-     * Read and attach a file
-     *
-     * Reads a file and attaches it to the current email
-     *
-     * @access public
-     * @param string $filename the file to read and attach
-     * @param string $display_name the name that will be displayed in the mail
-     * @see read_File
-     */
-    public function readAttachFile($filename, $display_name = '') {
-        if($display_name == '') {
-            $path_parts = pathinfo($filename);
-            $display_name = $path_parts["basename"];
-            unset($path_parts);
-        }
-        $this->attachFile($this->read_File($filename), $display_name);
-    }
-    
-    /**
-     * Attach a file
-     *
-     * Attaches a string (can be binary) as a file to the mail
-     *
-     * @access public
-     * @param string $content attachment data string
-     * @param string $filename name for file attachment
-     */
-    public function attachFile($content, $filename) {
-        $attachment = array('content' => $content,
-                            'filename' => $filename,
-                            'type' => 'application/octet-stream',
-                            'encoding' => 'base64'
-                           );
-        $this->attachments[] = $attachment;
-    }
-    
-    /**
-     * @access private
-     */
-    private function create() {
-        $attach = false;
-        $html = false;
-        $text = false;
-        
-        if($this->html_part) $html = true;
-        if($this->text_part) $text = true;
-        if(count($this->attachments) > 0) $attach = true;
-        
-        $textonly = false;
-        $htmlonly = false;
-        if($text == true && $html == false && $attach == false) {
-            // only text
-            $content_type = 'text/plain; charset="' . strtolower($this->mail_charset) . '"';
-            $textonly = true;
-        } elseif($text == true && $html == false && $attach == true) {
-            // text and attachment
-            $content_type = 'multipart/mixed;';
-            $content_type .= "\n" . ' boundary="' . $this->mime_boundary . '"';
-        } elseif($html == true && $text == true && $attach == false) {
-            // html only (or text too)
-            $content_type = 'multipart/alternative;';
-            $content_type .= "\n" . ' boundary="' . $this->mime_boundary . '"';
-        } elseif($html == true && $text == false && $attach == false) {
-            // html only (or text too)
-            $content_type = 'text/html; charset="' . strtolower($this->mail_charset) . '"';
-            $htmlonly = true;
-        } elseif($html == true && $attach == true) {
-            // html and attachments
-            $content_type = 'multipart/mixed;';
-            $content_type .= "\n" . ' boundary="' . $this->mime_boundary . '"';
-        }
-        
-        $this->headers['Content-Type'] = $content_type;
-        
-        if($textonly == false && $htmlonly == false) {
-            $this->body = "This is a multi-part message in MIME format.\n\n";
-            
-            if($text) {
-                /*$this->body .= "--{$this->mime_boundary}\n" .
+	/**
+	 * if set to true smtp is used instead of mail() to send emails
+	 * @see mail
+	 */
+	private $use_smtp = false;
+
+	/**
+	 * the smtp helo string - use the mail server name here!
+	 */
+	private $smtp_helo = '';
+
+	/**
+	 * the smtp server to send mails
+	 */
+	private $smtp_host = '';
+
+	/**
+	 * the smtp port
+	 */
+	private $smtp_port = 25;
+
+	/**
+	 * if the smtp server needs authentication you can set the smtp user here
+	 */
+	private $smtp_user = '';
+
+	/**
+	 * if the smtp server needs authentication you can set the smtp password here
+	 */
+	private $smtp_pass = '';
+
+	/**
+	 * If you want to use tls/ssl specify it here
+	 */
+	private $smtp_crypt = ''; // tls or ssl
+	/**
+	 * How many mails should be sent via one single smtp connection
+	 */
+	private $smtp_max_mails = 20;
+
+	/**
+	 * Should the mail be signed
+	 */
+	private $sign_email = false;
+
+	/**
+	 * The cert and key to use for email signing
+	 */
+	private $sign_key = '';
+	private $sign_key_pass = '';
+	private $sign_cert = '';
+	private $sign_bundle = '';
+	private $_is_signed = false;
+
+	/**
+	 * get disposition notification
+	 */
+	private $notification = false;
+	/**#@-*/
+
+	public function __construct($options = array()) {
+		$rand = md5(microtime());
+		$this->mime_boundary = '==Multipart_Boundary_x' . $rand . 'x';
+
+		$this->headers = array();
+		$this->attachments = array();
+
+		$this->headers['MIME-Version'] = '1.0';
+		$this->headers['User-Agent'] = $this->user_agent;
+		if(is_array($options) && count($options) > 0) $this->setOptions($options);
+	}
+
+	public function __destruct() {
+		$this->finish();
+	}
+
+
+
+	/**
+	 * Set option
+	 *
+	 * @param string $key the option to set
+	 * @param string $value the option value to set
+	 */
+	public function setOption($key, $value) {
+		switch($key) {
+		case 'smtp_helo':
+			$this->smtp_helo = $value;
+			break;
+		case 'smtp_host':
+			$this->smtp_host = $value;
+			break;
+		case 'smtp_server':
+			$this->smtp_host = $value;
+			break;
+		case 'smtp_port':
+			$this->smtp_port = $value;
+			break;
+		case 'smtp_user':
+			$this->smtp_user = $value;
+			break;
+		case 'smtp_pass':
+			$this->smtp_pass = $value;
+			break;
+		case 'smtp_max_mails':
+			$this->smtp_max_mails = intval($value);
+			if($this->smtp_max_mails < 1) $this->smtp_max_mails = 1;
+			break;
+		case 'use_smtp':
+			$this->use_smtp = ($value == true ? true : false);
+			if($value == true) $this->_crlf = "\r\n";
+			break;
+		case 'smtp_crypt':
+			if($value != 'ssl' && $value != 'tls') $value = '';
+			$this->smtp_crypt = $value;
+			break;
+		case 'sign_email':
+			$this->sign_email = ($value == true ? true : false);
+			break;
+		case 'sign_key':
+			$this->sign_key = $value;
+			break;
+		case 'sign_key_pass':
+			$this->sign_key_pass = $value;
+			break;
+		case 'sign_cert':
+			$this->sign_cert = $value;
+			break;
+		case 'sign_bundle':
+			$this->sign_bundle = $value;
+			break;
+		case 'mail_charset':
+			$this->mail_charset = $value;
+			break;
+		case 'notify':
+			$this->notification = ($value == true ? true : false);
+			break;
+		}
+	}
+
+
+
+	/** Detect the helo string if none given
+	 *
+	 */
+	private function detectHelo() {
+		if(isset($_SERVER['HTTP_HOST'])) $this->smtp_helo = $_SERVER['HTTP_HOST'];
+		elseif(isset($_SERVER['SERVER_NAME'])) $this->smtp_helo = $_SERVER['SERVER_NAME'];
+		else $this->smtp_helo = php_uname('n');
+		if($this->smtp_helo == '') $this->smtp_helo = 'localhost';
+	}
+
+
+
+	/**
+	 * Set options
+	 *
+	 * @param array $options the options to set as an associative array key => value
+	 */
+	public function setOptions($options) {
+		foreach($options as $key => $value) $this->setOption($key, $value);
+	}
+
+
+
+	/**
+	 * Read a file's contents
+	 *
+	 * Simply gets the file's content
+	 *
+	 * @access public
+	 * @param string $filename name and path of file to read
+	 * @return string file content (can be binary)
+	 */
+	public function read_File($filename) {
+		$content = '';
+
+		$fp = fopen($filename, 'r');
+		if(!$fp) return false;
+
+		while(!feof($fp)) {
+			$content .= fread($fp, 1024);
+		}
+		fclose($fp);
+
+		return $content;
+	}
+
+
+
+	/**
+	 * set smtp connection encryption
+	 *
+	 * @access public
+	 * @param string $mode encryption mode (tls, ssl or empty string)
+	 */
+	public function setSMTPEncryption($mode = '') {
+		if($mode != 'ssl' && $mode != 'tls') $mode = '';
+		$this->smtp_crypt = $mode;
+	}
+
+	/**
+	 * set a mail header
+	 *
+	 * Sets a single mail header to a given value
+	 *
+	 * @access public
+	 * @param string $header header name to set
+	 * @param string $value value to set in header field
+	 */
+	public function setHeader($header, $value) {
+		if(strtolower($header) == 'bcc') $header = 'Bcc';
+		elseif(strtolower($header) == 'cc') $header = 'Cc';
+		elseif(strtolower($header) == 'from') $header = 'From';
+		$this->headers["$header"] = $value;
+	}
+
+
+
+	/**
+	 * get a mail header value
+	 *
+	 * Returns a value of a single mail header
+	 *
+	 * @access public
+	 * @param string $header header name to get
+	 * @return string header value
+	 */
+	public function getHeader($header) {
+		if(strtolower($header) == 'bcc') $header = 'Bcc';
+		elseif(strtolower($header) == 'cc') $header = 'Cc';
+		elseif(strtolower($header) == 'from') $header = 'From';
+		return isset($this->headers["$header"]) ? $this->headers["$header"] : '';
+	}
+
+
+
+	/**
+	 * Set email sender
+	 *
+	 * Sets the email sender and optionally the sender's name
+	 *
+	 * @access public
+	 * @param string $email sender email address
+	 * @param string $name sender name
+	 */
+	public function setSender($email, $name = '') {
+		if($name) $header = '"' . $name . '" <' . $email . '>';
+		else $header = '<' . $email . '>';
+
+		$this->_mail_sender = $email;
+
+		$this->setHeader('From', $header);
+	}
+
+
+
+	/**
+	 * Set mail subject
+	 *
+	 * @access public
+	 * @param string $subject the mail subject
+	 * @return string where-string for db query
+	 */
+	public function setSubject($subject) {
+		$this->setHeader('Subject', $subject);
+	}
+
+
+
+	/**
+	 * Get current mail subject
+	 *
+	 * @access public
+	 * @return string mail subject
+	 */
+	public function getSubject() {
+		return $this->headers['Subject'];
+	}
+
+
+
+	/**
+	 * Set mail content
+	 *
+	 * Sets the mail html and plain text content
+	 *
+	 * @access public
+	 * @param string $text plain text mail content (can be empty)
+	 * @param string $html html mail content
+	 */
+	public function setMailText($text, $html = '') {
+		$this->text_part = $text;
+		$this->html_part = $html;
+	}
+
+
+
+	/**
+	 * Read and attach a file
+	 *
+	 * Reads a file and attaches it to the current email
+	 *
+	 * @access public
+	 * @param string $filename the file to read and attach
+	 * @param string $display_name the name that will be displayed in the mail
+	 * @see read_File
+	 */
+	public function readAttachFile($filename, $display_name = '') {
+		if($display_name == '') {
+			$path_parts = pathinfo($filename);
+			$display_name = $path_parts["basename"];
+			unset($path_parts);
+		}
+		$this->attachFile($this->read_File($filename), $display_name);
+	}
+
+
+
+	/**
+	 * Attach a file
+	 *
+	 * Attaches a string (can be binary) as a file to the mail
+	 *
+	 * @access public
+	 * @param string $content attachment data string
+	 * @param string $filename name for file attachment
+	 */
+	public function attachFile($content, $filename) {
+		$attachment = array('content' => $content,
+			'filename' => $filename,
+			'type' => 'application/octet-stream',
+			'encoding' => 'base64'
+		);
+		$this->attachments[] = $attachment;
+	}
+
+
+
+	/**
+	 * @access private
+	 */
+	private function create() {
+		$attach = false;
+		$html = false;
+		$text = false;
+
+		if($this->html_part) $html = true;
+		if($this->text_part) $text = true;
+		if(count($this->attachments) > 0) $attach = true;
+
+		$textonly = false;
+		$htmlonly = false;
+		if($text == true && $html == false && $attach == false) {
+			// only text
+			$content_type = 'text/plain; charset="' . strtolower($this->mail_charset) . '"';
+			$textonly = true;
+		} elseif($text == true && $html == false && $attach == true) {
+			// text and attachment
+			$content_type = 'multipart/mixed;';
+			$content_type .= "\n" . ' boundary="' . $this->mime_boundary . '"';
+		} elseif($html == true && $text == true && $attach == false) {
+			// html only (or text too)
+			$content_type = 'multipart/alternative;';
+			$content_type .= "\n" . ' boundary="' . $this->mime_boundary . '"';
+		} elseif($html == true && $text == false && $attach == false) {
+			// html only (or text too)
+			$content_type = 'text/html; charset="' . strtolower($this->mail_charset) . '"';
+			$htmlonly = true;
+		} elseif($html == true && $attach == true) {
+			// html and attachments
+			$content_type = 'multipart/mixed;';
+			$content_type .= "\n" . ' boundary="' . $this->mime_boundary . '"';
+		}
+
+		$this->headers['Content-Type'] = $content_type;
+
+		if($textonly == false && $htmlonly == false) {
+			$this->body = "This is a multi-part message in MIME format.\n\n";
+
+			if($text) {
+				/*$this->body .= "--{$this->mime_boundary}\n" .
                               "Content-Type:text/plain; charset=\"" . strtolower($this->mail_charset) . "\"\n" .
                               "Content-Transfer-Encoding: 7bit\n\n" . $this->text_part . "\n\n";*/
 				$this->body .= "--{$this->mime_boundary}\n" .
-                              "Content-Type:text/plain; charset=\"UTF-8\"\n" .
-                              "Content-Transfer-Encoding: 8bit\n\n" . $this->text_part . "\n\n";
+					"Content-Type:text/plain; charset=\"UTF-8\"\n" .
+					"Content-Transfer-Encoding: 8bit\n\n" . $this->text_part . "\n\n";
 			}
-            
-            if($html) {
-                /*$this->body .= "--{$this->mime_boundary}\n" .
-                               "Content-Type:text/html; charset=\"" . strtolower($this->mail_charset) . "\"\n" . 
+
+			if($html) {
+				/*$this->body .= "--{$this->mime_boundary}\n" .
+                               "Content-Type:text/html; charset=\"" . strtolower($this->mail_charset) . "\"\n" .
                                "Content-Transfer-Encoding: 7bit\n\n" . $this->html_part . "\n\n";*/
 				$this->body .= "--{$this->mime_boundary}\n" .
-                              "Content-Type:text/html; charset=\"UTF-8\"\n" .
-                              "Content-Transfer-Encoding: 8bit\n\n" . $this->html_part . "\n\n";
+					"Content-Type:text/html; charset=\"UTF-8\"\n" .
+					"Content-Transfer-Encoding: 8bit\n\n" . $this->html_part . "\n\n";
 			}
-            
-            if($attach) {
-                foreach($this->attachments as $att) {
-                    $this->body .= "--{$this->mime_boundary}\n" .
-                                   "Content-Type: " . $att['type'] . ";\n" .
-                                   " name=\"" . $att['filename'] . "\"\n" .
-                                   "Content-Transfer-Encoding: base64\n" . 
-                                   "Content-Disposition: attachment;\n\n" .
-                                   chunk_split(base64_encode($att['content'])) . "\n\n";
-                }
-            }
-            $this->body .= "--{$this->mime_boundary}--\n";
-        } elseif($htmlonly == true) {
-            $this->body = $this->html_part;
-        } else {
-            $this->body = $this->text_part;
-        }
-        
-        if (isset($this->body)) {
-            // Add message ID header
-            $message_id = sprintf('<%s.%s@%s>', base_convert(time(), 10, 36), base_convert(rand(), 10, 36), $this->smtp_helo != '' ? $this->smtp_helo : $this->detectHelo());
-            $this->headers['Message-ID'] = $message_id;
-            return true;
-        } else {
-            return false;
-        }
-    }
-    
-    /**
-     * Function to sign an email body
-     */
-    private function sign() {
-        if($this->sign_email == false || $this->sign_key == '' || $this->sign_cert == '') return false;
-        if(function_exists('openssl_pkcs7_sign') == false) return false;
-        
-        $tmpin = tempnam(sys_get_temp_dir(), 'sign');
-        $tmpout = tempnam(sys_get_temp_dir(), 'sign');
-        if(!file_exists($tmpin) || !is_writable($tmpin)) return false;
-        
-        file_put_contents($tmpin, 'Content-Type: ' . $this->getHeader('Content-Type') . "\n\n" . $this->body);
-        $tmpf_key = tempnam(sys_get_temp_dir(), 'sign');
-        file_put_contents($tmpf_key, $this->sign_key);
-        $tmpf_cert = tempnam(sys_get_temp_dir(), 'sign');
-        file_put_contents($tmpf_cert, $this->sign_cert);
-        if($this->sign_bundle != '')  {
-            $tmpf_bundle = tempnam(sys_get_temp_dir(), 'sign');
-            file_put_contents($tmpf_bundle, $this->sign_bundle);
-            openssl_pkcs7_sign($tmpin, $tmpout, 'file://' . realpath($tmpf_cert), array('file://' . realpath($tmpf_key), $this->sign_key_pass), array(), PKCS7_DETACHED, realpath($tmpf_bundle));
-        } else {
-            openssl_pkcs7_sign($tmpin, $tmpout, 'file://' . realpath($tmpf_cert), array('file://' . realpath($tmpf_key), $this->sign_key_pass), array());
-        }
-        unlink($tmpin);
-        unlink($tmpf_cert);
-        unlink($tmpf_key);
-        if(file_exists($tmpf_bundle)) unlink($tmpf_bundle);
-        
-        if(!file_exists($tmpout) || !is_readable($tmpout)) return false;
-        $this->body = file_get_contents($tmpout);
-        unlink($tmpout);
-        
-        unset($this->headers['Content-Type']);
-        unset($this->headers['MIME-Version']);
-        
-        $this->_is_signed = true;
-    }
-    
-    private function _char_to_hex($matches) {
-        return '=' . strtoupper(dechex(ord($matches[1])));
-    }
-    
-    /**
-    * Function to encode a header if necessary
-    * according to RFC2047
-    * @access private
-    */
-    private function _encodeHeader($input, $charset = 'ISO-8859-1') {
+
+			if($attach) {
+				foreach($this->attachments as $att) {
+					$this->body .= "--{$this->mime_boundary}\n" .
+						"Content-Type: " . $att['type'] . ";\n" .
+						" name=\"" . $att['filename'] . "\"\n" .
+						"Content-Transfer-Encoding: base64\n" .
+						"Content-Disposition: attachment;\n\n" .
+						chunk_split(base64_encode($att['content'])) . "\n\n";
+				}
+			}
+			$this->body .= "--{$this->mime_boundary}--\n";
+		} elseif($htmlonly == true) {
+			$this->body = $this->html_part;
+		} else {
+			$this->body = $this->text_part;
+		}
+
+		if (isset($this->body)) {
+			// Add message ID header
+			$message_id = sprintf('<%s.%s@%s>', base_convert(time(), 10, 36), base_convert(rand(), 10, 36), $this->smtp_helo != '' ? $this->smtp_helo : $this->detectHelo());
+			$this->headers['Message-ID'] = $message_id;
+			return true;
+		} else {
+			return false;
+		}
+	}
+
+
+
+	/**
+	 * Function to sign an email body
+	 */
+	private function sign() {
+		if($this->sign_email == false || $this->sign_key == '' || $this->sign_cert == '') return false;
+		if(function_exists('openssl_pkcs7_sign') == false) return false;
+
+		$tmpin = tempnam(sys_get_temp_dir(), 'sign');
+		$tmpout = tempnam(sys_get_temp_dir(), 'sign');
+		if(!file_exists($tmpin) || !is_writable($tmpin)) return false;
+
+		file_put_contents($tmpin, 'Content-Type: ' . $this->getHeader('Content-Type') . "\n\n" . $this->body);
+		$tmpf_key = tempnam(sys_get_temp_dir(), 'sign');
+		file_put_contents($tmpf_key, $this->sign_key);
+		$tmpf_cert = tempnam(sys_get_temp_dir(), 'sign');
+		file_put_contents($tmpf_cert, $this->sign_cert);
+		if($this->sign_bundle != '')  {
+			$tmpf_bundle = tempnam(sys_get_temp_dir(), 'sign');
+			file_put_contents($tmpf_bundle, $this->sign_bundle);
+			openssl_pkcs7_sign($tmpin, $tmpout, 'file://' . realpath($tmpf_cert), array('file://' . realpath($tmpf_key), $this->sign_key_pass), array(), PKCS7_DETACHED, realpath($tmpf_bundle));
+		} else {
+			openssl_pkcs7_sign($tmpin, $tmpout, 'file://' . realpath($tmpf_cert), array('file://' . realpath($tmpf_key), $this->sign_key_pass), array());
+		}
+		unlink($tmpin);
+		unlink($tmpf_cert);
+		unlink($tmpf_key);
+		if(file_exists($tmpf_bundle)) unlink($tmpf_bundle);
+
+		if(!file_exists($tmpout) || !is_readable($tmpout)) return false;
+		$this->body = file_get_contents($tmpout);
+		unlink($tmpout);
+
+		unset($this->headers['Content-Type']);
+		unset($this->headers['MIME-Version']);
+
+		$this->_is_signed = true;
+	}
+
+	private function _char_to_hex($matches) {
+		return '=' . strtoupper(dechex(ord($matches[1])));
+	}
+
+
+
+	/**
+	 * Function to encode a header if necessary
+	 * according to RFC2047
+	 * @access private
+	 */
+	private function _encodeHeader($input, $charset = 'ISO-8859-1') {
 		preg_match_all('/(\s?\w*[\x80-\xFF]+\w*\s?)/', $input, $matches);
 		foreach ($matches[1] as $value) {
 			$replacement = preg_replace_callback('/([\x20\x80-\xFF])/', array($this, '_char_to_hex'), $value);
 			$input = str_replace($value, '=?' . $charset . '?Q?' . $replacement . '?=', $input);
 		}
-        
-        return $input;
-    }
-	
+
+		return $input;
+	}
+
+
+
 	/**
-    * Function to encode the subject if necessary
-    * according to RFC2047
-    * @access private
-    */
-    private function _encodeSubject($input, $charset = 'ISO-8859-1') {
-        /*
+	 * Function to encode the subject if necessary
+	 * according to RFC2047
+	 * @access private
+	 */
+	private function _encodeSubject($input, $charset = 'ISO-8859-1') {
+		/*
 		if($charset == 'UTF-8' && function_exists('imap_8bit')) {
 			$input = "=?utf-8?Q?" . imap_8bit($input) . "?=";
 		} else {
@@ -532,204 +578,213 @@
 			}
 		}*/
 		$input='=?UTF-8?B?'.base64_encode($input).'?=';
-        
-        return $input;
-    }
-    
-    /**
-     * @access private
-     */
-    private function _smtp_login() {
-        $this->_smtp_conn = fsockopen(($this->smtp_crypt == 'ssl' ? 'ssl://' : '') . $this->smtp_host, $this->smtp_port, $errno, $errstr, 30);
-        $response = fgets($this->_smtp_conn, 515);
-        if(empty($this->_smtp_conn)) return false;
-        
-        // ENCRYPTED?
-        if($this->smtp_crypt == 'tls') {
-            fputs($this->_smtp_conn, 'STARTTLS' . $this->_crlf);
-            fgets($this->_smtp_conn, 515);
-            stream_socket_enable_crypto($this->_smtp_conn, true, STREAM_CRYPTO_METHOD_TLS_CLIENT);
-        }
-        
-        //Say Hello to SMTP
-        if($this->smtp_helo == '') $this->detectHelo();
-        fputs($this->_smtp_conn, 'HELO ' . $this->smtp_helo . $this->_crlf);
-        $response = fgets($this->_smtp_conn, 515);
-        
-        //AUTH LOGIN
-        fputs($this->_smtp_conn, 'AUTH LOGIN' . $this->_crlf);
-        $response = fgets($this->_smtp_conn, 515);
-        
-        //Send username
-        fputs($this->_smtp_conn, base64_encode($this->smtp_user) . $this->_crlf);
-        $response = fgets($this->_smtp_conn, 515);
-        
-        //Send password
-        fputs($this->_smtp_conn, base64_encode($this->smtp_pass) . $this->_crlf);
-        $response = fgets($this->_smtp_conn, 515);
-        
-        $this->_logged_in = true;
-        return true;
-    }
-    
-    /**
-     * @access private
-     */
-    private function _smtp_close() {
-        $this->_logged_in = false;
-        
-        if(empty($this->_smtp_conn)) {
-            return false;
-        }
-        
-        fputs($this->_smtp_conn, 'QUIT' . $this->_crlf);
-        $response = @fgets($this->_smtp_conn, 515);
-        return true;
-    }
-    
-    /**
-     * Send the mail to one or more recipients
-     *
-     * The recipients can be either a string (1 recipient email without name) or an associative array of recipients with names as keys and email addresses as values.
-     *
-     * @access public
-     * @param mixed $recipients one email address or array of recipients with names as keys and email addresses as values
-     */
-    public function send($recipients) {
-        if(!is_array($recipients)) $recipients = array($recipients);
-        
-        if($this->use_smtp == true) $this->_crlf = "\r\n";
-        else $this->_crlf = "\n";
-        
-        $this->create();
-        if($this->sign_email == true) $this->sign();
-        
-        $subject = '';
-        if (!empty($this->headers['Subject'])) {
-            //$subject = $this->_encodeHeader($this->headers['Subject'], $this->mail_charset);
-            $subject = $this->headers['Subject'];
-            
-            //$enc_subject = $this->_encodeHeader($subject, $this->mail_charset);
-			$enc_subject = $this->_encodeSubject($subject, $this->mail_charset);
-            unset($this->headers['Subject']);
-        }
-        
-        if($this->notification == true) $this->setHeader('Disposition-Notification-To', $this->getHeader('From'));
-        
-        unset($this->headers['To']); // always reset the To header to prevent from sending to multiple users at once
-        $this->headers['Date'] = date('r'); //date('D, d M Y H:i:s O');
 
-        // Get flat representation of headers
-        foreach ($this->headers as $name => $value) {
-            if(strtolower($name) == 'to' || strtolower($name) == 'cc' || strtolower($name) == 'bcc') continue; // never add the To header
-            $headers[] = $name . ': ' . $this->_encodeHeader($value, $this->mail_charset);
-        }
-        
-        if($this->use_smtp == true) {
-            if(!$this->_logged_in || !$this->_smtp_conn) {
-                $result = $this->_smtp_login();
-                if(!$result) return false;
-            }
-            foreach($recipients as $recipname => $recip) {
-                if($this->_sent_mails >= $this->smtp_max_mails) {
-                    // close connection to smtp and reconnect
-                    $this->_sent_mails = 0;
-                    $this->_smtp_close();
-                    $result = $this->_smtp_login();
-                    if(!$result) return false;
-                }
-                $this->_sent_mails += 1;
-                
-                $recipname = trim(str_replace('"', '', $recipname));
-                $recip = $this->_encodeHeader($recip, $this->mail_charset);
-                $recipname = $this->_encodeHeader($recipname, $this->mail_charset);
-                
-                //Email From
-                fputs($this->_smtp_conn, 'MAIL FROM: ' . $this->_mail_sender . $this->_crlf);
-                $response = fgets($this->_smtp_conn, 515);
-                
-                //Email To
-                fputs($this->_smtp_conn, 'RCPT TO: ' . $recip . $this->_crlf);
-                $response = fgets($this->_smtp_conn, 515);
-                
-                //The Email
-                fputs($this->_smtp_conn, 'DATA' . $this->_crlf);
-                $response = fgets($this->_smtp_conn, 515);
-                
-                //Construct Headers
-                if($recipname && !is_numeric($recipname)) $this->setHeader('To', $recipname . ' <' . $recip . '>');
-                else $this->setHeader('To', $recip);
-                
-                $mail_content = 'Subject: ' . $enc_subject . $this->_crlf;
-                $mail_content .= 'To: ' . $this->getHeader('To') . $this->_crlf;
-                if($this->getHeader('Bcc') != '') $mail_content .= 'Bcc: ' . $this->_encodeHeader($this->getHeader('Bcc'), $this->mail_charset) . $this->_crlf;
-                if($this->getHeader('Cc') != '') $mail_content .= 'Cc: ' . $this->_encodeHeader($this->getHeader('Cc'), $this->mail_charset) . $this->_crlf;
-                $mail_content .= implode($this->_crlf, $headers) . $this->_crlf . ($this->_is_signed == false ? $this->_crlf : '') . $this->body;
-                
-                fputs($this->_smtp_conn, $mail_content . $this->_crlf . '.' . $this->_crlf);
-                $response = fgets($this->_smtp_conn, 515);
-                
-                // hopefully message was correctly sent now
-                $result = true;
-            }
-        } else {
-            if($this->getHeader('Bcc') != '') $headers[] = 'Bcc: ' . $this->_encodeHeader($this->getHeader('Bcc'), $this->mail_charset);
-            if($this->getHeader('Cc') != '') $headers[] = 'Cc: ' . $this->_encodeHeader($this->getHeader('Cc'), $this->mail_charset);
-            $rec_string = '';
-            foreach($recipients as $recipname => $recip) {
-                $recipname = trim(str_replace('"', '', $recipname));
-                
-                if($rec_string != '') $rec_string .= ', ';
-                if($recipname && !is_numeric($recipname)) $rec_string .= $recipname . '<' . $recip . '>';
-                else $rec_string .= $recip;
-            }
-            $to = $this->_encodeHeader($rec_string, $this->mail_charset);
-            //$result = mail($to, $subject, $this->body, implode($this->_crlf, $headers));
+		return $input;
+	}
+
+
+
+	/**
+	 * @access private
+	 */
+	private function _smtp_login() {
+		$this->_smtp_conn = fsockopen(($this->smtp_crypt == 'ssl' ? 'ssl://' : '') . $this->smtp_host, $this->smtp_port, $errno, $errstr, 30);
+		$response = fgets($this->_smtp_conn, 515);
+		if(empty($this->_smtp_conn)) return false;
+
+		// ENCRYPTED?
+		if($this->smtp_crypt == 'tls') {
+			fputs($this->_smtp_conn, 'STARTTLS' . $this->_crlf);
+			fgets($this->_smtp_conn, 515);
+			stream_socket_enable_crypto($this->_smtp_conn, true, STREAM_CRYPTO_METHOD_TLS_CLIENT);
+		}
+
+		//Say Hello to SMTP
+		if($this->smtp_helo == '') $this->detectHelo();
+		fputs($this->_smtp_conn, 'HELO ' . $this->smtp_helo . $this->_crlf);
+		$response = fgets($this->_smtp_conn, 515);
+
+		//AUTH LOGIN
+		fputs($this->_smtp_conn, 'AUTH LOGIN' . $this->_crlf);
+		$response = fgets($this->_smtp_conn, 515);
+
+		//Send username
+		fputs($this->_smtp_conn, base64_encode($this->smtp_user) . $this->_crlf);
+		$response = fgets($this->_smtp_conn, 515);
+
+		//Send password
+		fputs($this->_smtp_conn, base64_encode($this->smtp_pass) . $this->_crlf);
+		$response = fgets($this->_smtp_conn, 515);
+
+		$this->_logged_in = true;
+		return true;
+	}
+
+
+
+	/**
+	 * @access private
+	 */
+	private function _smtp_close() {
+		$this->_logged_in = false;
+
+		if(empty($this->_smtp_conn)) {
+			return false;
+		}
+
+		fputs($this->_smtp_conn, 'QUIT' . $this->_crlf);
+		$response = @fgets($this->_smtp_conn, 515);
+		return true;
+	}
+
+
+
+	/**
+	 * Send the mail to one or more recipients
+	 *
+	 * The recipients can be either a string (1 recipient email without name) or an associative array of recipients with names as keys and email addresses as values.
+	 *
+	 * @access public
+	 * @param mixed $recipients one email address or array of recipients with names as keys and email addresses as values
+	 */
+	public function send($recipients) {
+		if(!is_array($recipients)) $recipients = array($recipients);
+
+		if($this->use_smtp == true) $this->_crlf = "\r\n";
+		else $this->_crlf = "\n";
+
+		$this->create();
+		if($this->sign_email == true) $this->sign();
+
+		$subject = '';
+		if (!empty($this->headers['Subject'])) {
+			//$subject = $this->_encodeHeader($this->headers['Subject'], $this->mail_charset);
+			$subject = $this->headers['Subject'];
+
+			//$enc_subject = $this->_encodeHeader($subject, $this->mail_charset);
+			$enc_subject = $this->_encodeSubject($subject, $this->mail_charset);
+			unset($this->headers['Subject']);
+		}
+
+		if($this->notification == true) $this->setHeader('Disposition-Notification-To', $this->getHeader('From'));
+
+		unset($this->headers['To']); // always reset the To header to prevent from sending to multiple users at once
+		$this->headers['Date'] = date('r'); //date('D, d M Y H:i:s O');
+
+		// Get flat representation of headers
+		foreach ($this->headers as $name => $value) {
+			if(strtolower($name) == 'to' || strtolower($name) == 'cc' || strtolower($name) == 'bcc') continue; // never add the To header
+			$headers[] = $name . ': ' . $this->_encodeHeader($value, $this->mail_charset);
+		}
+
+		if($this->use_smtp == true) {
+			if(!$this->_logged_in || !$this->_smtp_conn) {
+				$result = $this->_smtp_login();
+				if(!$result) return false;
+			}
+			foreach($recipients as $recipname => $recip) {
+				if($this->_sent_mails >= $this->smtp_max_mails) {
+					// close connection to smtp and reconnect
+					$this->_sent_mails = 0;
+					$this->_smtp_close();
+					$result = $this->_smtp_login();
+					if(!$result) return false;
+				}
+				$this->_sent_mails += 1;
+
+				$recipname = trim(str_replace('"', '', $recipname));
+				$recip = $this->_encodeHeader($recip, $this->mail_charset);
+				$recipname = $this->_encodeHeader($recipname, $this->mail_charset);
+
+				//Email From
+				fputs($this->_smtp_conn, 'MAIL FROM: ' . $this->_mail_sender . $this->_crlf);
+				$response = fgets($this->_smtp_conn, 515);
+
+				//Email To
+				fputs($this->_smtp_conn, 'RCPT TO: ' . $recip . $this->_crlf);
+				$response = fgets($this->_smtp_conn, 515);
+
+				//The Email
+				fputs($this->_smtp_conn, 'DATA' . $this->_crlf);
+				$response = fgets($this->_smtp_conn, 515);
+
+				//Construct Headers
+				if($recipname && !is_numeric($recipname)) $this->setHeader('To', $recipname . ' <' . $recip . '>');
+				else $this->setHeader('To', $recip);
+
+				$mail_content = 'Subject: ' . $enc_subject . $this->_crlf;
+				$mail_content .= 'To: ' . $this->getHeader('To') . $this->_crlf;
+				if($this->getHeader('Bcc') != '') $mail_content .= 'Bcc: ' . $this->_encodeHeader($this->getHeader('Bcc'), $this->mail_charset) . $this->_crlf;
+				if($this->getHeader('Cc') != '') $mail_content .= 'Cc: ' . $this->_encodeHeader($this->getHeader('Cc'), $this->mail_charset) . $this->_crlf;
+				$mail_content .= implode($this->_crlf, $headers) . $this->_crlf . ($this->_is_signed == false ? $this->_crlf : '') . $this->body;
+
+				fputs($this->_smtp_conn, $mail_content . $this->_crlf . '.' . $this->_crlf);
+				$response = fgets($this->_smtp_conn, 515);
+
+				// hopefully message was correctly sent now
+				$result = true;
+			}
+		} else {
+			if($this->getHeader('Bcc') != '') $headers[] = 'Bcc: ' . $this->_encodeHeader($this->getHeader('Bcc'), $this->mail_charset);
+			if($this->getHeader('Cc') != '') $headers[] = 'Cc: ' . $this->_encodeHeader($this->getHeader('Cc'), $this->mail_charset);
+			$rec_string = '';
+			foreach($recipients as $recipname => $recip) {
+				$recipname = trim(str_replace('"', '', $recipname));
+
+				if($rec_string != '') $rec_string .= ', ';
+				if($recipname && !is_numeric($recipname)) $rec_string .= $recipname . '<' . $recip . '>';
+				else $rec_string .= $recip;
+			}
+			$to = $this->_encodeHeader($rec_string, $this->mail_charset);
+			//$result = mail($to, $subject, $this->body, implode($this->_crlf, $headers));
 			$result = mail($to, $enc_subject, $this->body, implode($this->_crlf, $headers));
-        }
-        
-        // Reset the subject in case mail is resent
-        if ($subject !== '') {
-            $this->headers['Subject'] = $subject;
-        }
-        
-        // Return
-        return $result;
-    }
-    
-    /**
-     * Close mail connections
-     *
-     * This closes an open smtp connection so you should always call this function in your script if you have finished sending all emails
-     *
-     * @access public
-     */
-    public function finish() {
-        if($this->use_smtp == true) $this->_smtp_close();
-        
-        $rand = md5(microtime());
-        $this->mime_boundary = '==Multipart_Boundary_x' . $rand . 'x';
-        
-        $this->headers = array();
-        $this->attachments = array();
-        $this->text_part = '';
-        $this->html_part = '';
-        
-        $this->headers['MIME-Version'] = '1.0';
-        $this->headers['User-Agent'] = $this->user_agent;
-        
-        $this->smtp_helo = '';
-        $this->smtp_host = '';
-        $this->smtp_port = '';
-        $this->smtp_user = '';
-        $this->smtp_pass = '';
-        $this->use_smtp = false;
-        $this->smtp_crypt = false;
-        $this->mail_charset = 'UTF-8';
-        $this->_sent_mails = 0;
-        
-        return;
-    }
+		}
+
+		// Reset the subject in case mail is resent
+		if ($subject !== '') {
+			$this->headers['Subject'] = $subject;
+		}
+
+		// Return
+		return $result;
+	}
+
+
+
+	/**
+	 * Close mail connections
+	 *
+	 * This closes an open smtp connection so you should always call this function in your script if you have finished sending all emails
+	 *
+	 * @access public
+	 */
+	public function finish() {
+		if($this->use_smtp == true) $this->_smtp_close();
+
+		$rand = md5(microtime());
+		$this->mime_boundary = '==Multipart_Boundary_x' . $rand . 'x';
+
+		$this->headers = array();
+		$this->attachments = array();
+		$this->text_part = '';
+		$this->html_part = '';
+
+		$this->headers['MIME-Version'] = '1.0';
+		$this->headers['User-Agent'] = $this->user_agent;
+
+		$this->smtp_helo = '';
+		$this->smtp_host = '';
+		$this->smtp_port = '';
+		$this->smtp_user = '';
+		$this->smtp_pass = '';
+		$this->use_smtp = false;
+		$this->smtp_crypt = false;
+		$this->mail_charset = 'UTF-8';
+		$this->_sent_mails = 0;
+
+		return;
+	}
+
 }
 
 ?>

--
Gitblit v1.9.1