Commit 30cddba8 by Scott

Update PHPMailer (5.2.14)

Close #367.
parent 9040e36b
...@@ -29,66 +29,66 @@ class PHPMailer ...@@ -29,66 +29,66 @@ class PHPMailer
{ {
/** /**
* The PHPMailer Version number. * The PHPMailer Version number.
* @type string * @var string
*/ */
public $Version = '5.2.13'; public $Version = '5.2.14';
/** /**
* Email priority. * Email priority.
* Options: null (default), 1 = High, 3 = Normal, 5 = low. * Options: null (default), 1 = High, 3 = Normal, 5 = low.
* When null, the header is not set at all. * When null, the header is not set at all.
* @type integer * @var integer
*/ */
public $Priority = null; public $Priority = null;
/** /**
* The character set of the message. * The character set of the message.
* @type string * @var string
*/ */
public $CharSet = 'iso-8859-1'; public $CharSet = 'iso-8859-1';
/** /**
* The MIME Content-type of the message. * The MIME Content-type of the message.
* @type string * @var string
*/ */
public $ContentType = 'text/plain'; public $ContentType = 'text/plain';
/** /**
* The message encoding. * The message encoding.
* Options: "8bit", "7bit", "binary", "base64", and "quoted-printable". * Options: "8bit", "7bit", "binary", "base64", and "quoted-printable".
* @type string * @var string
*/ */
public $Encoding = '8bit'; public $Encoding = '8bit';
/** /**
* Holds the most recent mailer error message. * Holds the most recent mailer error message.
* @type string * @var string
*/ */
public $ErrorInfo = ''; public $ErrorInfo = '';
/** /**
* The From email address for the message. * The From email address for the message.
* @type string * @var string
*/ */
public $From = 'root@localhost'; public $From = 'root@localhost';
/** /**
* The From name of the message. * The From name of the message.
* @type string * @var string
*/ */
public $FromName = 'Root User'; public $FromName = 'Root User';
/** /**
* The Sender email (Return-Path) of the message. * The Sender email (Return-Path) of the message.
* If not empty, will be sent via -f to sendmail or as 'MAIL FROM' in smtp mode. * If not empty, will be sent via -f to sendmail or as 'MAIL FROM' in smtp mode.
* @type string * @var string
*/ */
public $Sender = ''; public $Sender = '';
/** /**
* The Return-Path of the message. * The Return-Path of the message.
* If empty, it will be set to either From or Sender. * If empty, it will be set to either From or Sender.
* @type string * @var string
* @deprecated Email senders should never set a return-path header; * @deprecated Email senders should never set a return-path header;
* it's the receiver's job (RFC5321 section 4.4), so this no longer does anything. * it's the receiver's job (RFC5321 section 4.4), so this no longer does anything.
* @link https://tools.ietf.org/html/rfc5321#section-4.4 RFC5321 reference * @link https://tools.ietf.org/html/rfc5321#section-4.4 RFC5321 reference
...@@ -97,14 +97,14 @@ class PHPMailer ...@@ -97,14 +97,14 @@ class PHPMailer
/** /**
* The Subject of the message. * The Subject of the message.
* @type string * @var string
*/ */
public $Subject = ''; public $Subject = '';
/** /**
* An HTML or plain text message body. * An HTML or plain text message body.
* If HTML then call isHTML(true). * If HTML then call isHTML(true).
* @type string * @var string
*/ */
public $Body = ''; public $Body = '';
...@@ -113,7 +113,7 @@ class PHPMailer ...@@ -113,7 +113,7 @@ class PHPMailer
* This body can be read by mail clients that do not have HTML email * This body can be read by mail clients that do not have HTML email
* capability such as mutt & Eudora. * capability such as mutt & Eudora.
* Clients that can read HTML will view the normal Body. * Clients that can read HTML will view the normal Body.
* @type string * @var string
*/ */
public $AltBody = ''; public $AltBody = '';
...@@ -123,27 +123,27 @@ class PHPMailer ...@@ -123,27 +123,27 @@ class PHPMailer
* To generate iCal events, use the bundled extras/EasyPeasyICS.php class or iCalcreator * To generate iCal events, use the bundled extras/EasyPeasyICS.php class or iCalcreator
* @link http://sprain.ch/blog/downloads/php-class-easypeasyics-create-ical-files-with-php/ * @link http://sprain.ch/blog/downloads/php-class-easypeasyics-create-ical-files-with-php/
* @link http://kigkonsult.se/iCalcreator/ * @link http://kigkonsult.se/iCalcreator/
* @type string * @var string
*/ */
public $Ical = ''; public $Ical = '';
/** /**
* The complete compiled MIME message body. * The complete compiled MIME message body.
* @access protected * @access protected
* @type string * @var string
*/ */
protected $MIMEBody = ''; protected $MIMEBody = '';
/** /**
* The complete compiled MIME message headers. * The complete compiled MIME message headers.
* @type string * @var string
* @access protected * @access protected
*/ */
protected $MIMEHeader = ''; protected $MIMEHeader = '';
/** /**
* Extra headers that createHeader() doesn't fold in. * Extra headers that createHeader() doesn't fold in.
* @type string * @var string
* @access protected * @access protected
*/ */
protected $mailHeader = ''; protected $mailHeader = '';
...@@ -151,64 +151,64 @@ class PHPMailer ...@@ -151,64 +151,64 @@ class PHPMailer
/** /**
* Word-wrap the message body to this number of chars. * Word-wrap the message body to this number of chars.
* Set to 0 to not wrap. A useful value here is 78, for RFC2822 section 2.1.1 compliance. * Set to 0 to not wrap. A useful value here is 78, for RFC2822 section 2.1.1 compliance.
* @type integer * @var integer
*/ */
public $WordWrap = 0; public $WordWrap = 0;
/** /**
* Which method to use to send mail. * Which method to use to send mail.
* Options: "mail", "sendmail", or "smtp". * Options: "mail", "sendmail", or "smtp".
* @type string * @var string
*/ */
public $Mailer = 'mail'; public $Mailer = 'mail';
/** /**
* The path to the sendmail program. * The path to the sendmail program.
* @type string * @var string
*/ */
public $Sendmail = '/usr/sbin/sendmail'; public $Sendmail = '/usr/sbin/sendmail';
/** /**
* Whether mail() uses a fully sendmail-compatible MTA. * Whether mail() uses a fully sendmail-compatible MTA.
* One which supports sendmail's "-oi -f" options. * One which supports sendmail's "-oi -f" options.
* @type boolean * @var boolean
*/ */
public $UseSendmailOptions = true; public $UseSendmailOptions = true;
/** /**
* Path to PHPMailer plugins. * Path to PHPMailer plugins.
* Useful if the SMTP class is not in the PHP include path. * Useful if the SMTP class is not in the PHP include path.
* @type string * @var string
* @deprecated Should not be needed now there is an autoloader. * @deprecated Should not be needed now there is an autoloader.
*/ */
public $PluginDir = ''; public $PluginDir = '';
/** /**
* The email address that a reading confirmation should be sent to. * The email address that a reading confirmation should be sent to, also known as read receipt.
* @type string * @var string
*/ */
public $ConfirmReadingTo = ''; public $ConfirmReadingTo = '';
/** /**
* The hostname to use in Message-Id and Received headers * The hostname to use in the Message-ID header and as default HELO string.
* and as default HELO string. * If empty, PHPMailer attempts to find one with, in order,
* If empty, the value returned * $_SERVER['SERVER_NAME'], gethostname(), php_uname('n'), or the value
* by SERVER_NAME is used or 'localhost.localdomain'. * 'localhost.localdomain'.
* @type string * @var string
*/ */
public $Hostname = ''; public $Hostname = '';
/** /**
* An ID to be used in the Message-Id header. * An ID to be used in the Message-ID header.
* If empty, a unique id will be generated. * If empty, a unique id will be generated.
* @type string * @var string
*/ */
public $MessageID = ''; public $MessageID = '';
/** /**
* The message Date to be used in the Date header. * The message Date to be used in the Date header.
* If empty, the current date will be added. * If empty, the current date will be added.
* @type string * @var string
*/ */
public $MessageDate = ''; public $MessageDate = '';
...@@ -221,21 +221,22 @@ class PHPMailer ...@@ -221,21 +221,22 @@ class PHPMailer
* You can also specify encryption type, for example: * You can also specify encryption type, for example:
* (e.g. "tls://smtp1.example.com:587;ssl://smtp2.example.com:465"). * (e.g. "tls://smtp1.example.com:587;ssl://smtp2.example.com:465").
* Hosts will be tried in order. * Hosts will be tried in order.
* @type string * @var string
*/ */
public $Host = 'localhost'; public $Host = 'localhost';
/** /**
* The default SMTP server port. * The default SMTP server port.
* @type integer * @var integer
* @TODO Why is this needed when the SMTP class takes care of it? * @TODO Why is this needed when the SMTP class takes care of it?
*/ */
public $Port = 25; public $Port = 25;
/** /**
* The SMTP HELO of the message. * The SMTP HELO of the message.
* Default is $Hostname. * Default is $Hostname. If $Hostname is empty, PHPMailer attempts to find
* @type string * one with the same method described above for $Hostname.
* @var string
* @see PHPMailer::$Hostname * @see PHPMailer::$Hostname
*/ */
public $Helo = ''; public $Helo = '';
...@@ -243,7 +244,7 @@ class PHPMailer ...@@ -243,7 +244,7 @@ class PHPMailer
/** /**
* What kind of encryption to use on the SMTP connection. * What kind of encryption to use on the SMTP connection.
* Options: '', 'ssl' or 'tls' * Options: '', 'ssl' or 'tls'
* @type string * @var string
*/ */
public $SMTPSecure = ''; public $SMTPSecure = '';
...@@ -251,14 +252,14 @@ class PHPMailer ...@@ -251,14 +252,14 @@ class PHPMailer
* Whether to enable TLS encryption automatically if a server supports it, * Whether to enable TLS encryption automatically if a server supports it,
* even if `SMTPSecure` is not set to 'tls'. * even if `SMTPSecure` is not set to 'tls'.
* Be aware that in PHP >= 5.6 this requires that the server's certificates are valid. * Be aware that in PHP >= 5.6 this requires that the server's certificates are valid.
* @type boolean * @var boolean
*/ */
public $SMTPAutoTLS = true; public $SMTPAutoTLS = true;
/** /**
* Whether to use SMTP authentication. * Whether to use SMTP authentication.
* Uses the Username and Password properties. * Uses the Username and Password properties.
* @type boolean * @var boolean
* @see PHPMailer::$Username * @see PHPMailer::$Username
* @see PHPMailer::$Password * @see PHPMailer::$Password
*/ */
...@@ -266,47 +267,47 @@ class PHPMailer ...@@ -266,47 +267,47 @@ class PHPMailer
/** /**
* Options array passed to stream_context_create when connecting via SMTP. * Options array passed to stream_context_create when connecting via SMTP.
* @type array * @var array
*/ */
public $SMTPOptions = array(); public $SMTPOptions = array();
/** /**
* SMTP username. * SMTP username.
* @type string * @var string
*/ */
public $Username = ''; public $Username = '';
/** /**
* SMTP password. * SMTP password.
* @type string * @var string
*/ */
public $Password = ''; public $Password = '';
/** /**
* SMTP auth type. * SMTP auth type.
* Options are LOGIN (default), PLAIN, NTLM, CRAM-MD5 * Options are LOGIN (default), PLAIN, NTLM, CRAM-MD5
* @type string * @var string
*/ */
public $AuthType = ''; public $AuthType = '';
/** /**
* SMTP realm. * SMTP realm.
* Used for NTLM auth * Used for NTLM auth
* @type string * @var string
*/ */
public $Realm = ''; public $Realm = '';
/** /**
* SMTP workstation. * SMTP workstation.
* Used for NTLM auth * Used for NTLM auth
* @type string * @var string
*/ */
public $Workstation = ''; public $Workstation = '';
/** /**
* The SMTP server timeout in seconds. * The SMTP server timeout in seconds.
* Default of 5 minutes (300sec) is from RFC2821 section 4.5.3.2 * Default of 5 minutes (300sec) is from RFC2821 section 4.5.3.2
* @type integer * @var integer
*/ */
public $Timeout = 300; public $Timeout = 300;
...@@ -319,7 +320,7 @@ class PHPMailer ...@@ -319,7 +320,7 @@ class PHPMailer
* * `2` Data and commands * * `2` Data and commands
* * `3` As 2 plus connection status * * `3` As 2 plus connection status
* * `4` Low-level data output * * `4` Low-level data output
* @type integer * @var integer
* @see SMTP::$do_debug * @see SMTP::$do_debug
*/ */
public $SMTPDebug = 0; public $SMTPDebug = 0;
...@@ -335,7 +336,7 @@ class PHPMailer ...@@ -335,7 +336,7 @@ class PHPMailer
* <code> * <code>
* $mail->Debugoutput = function($str, $level) {echo "debug level $level; message: $str";}; * $mail->Debugoutput = function($str, $level) {echo "debug level $level; message: $str";};
* </code> * </code>
* @type string|callable * @var string|callable
* @see SMTP::$Debugoutput * @see SMTP::$Debugoutput
*/ */
public $Debugoutput = 'echo'; public $Debugoutput = 'echo';
...@@ -344,20 +345,20 @@ class PHPMailer ...@@ -344,20 +345,20 @@ class PHPMailer
* Whether to keep SMTP connection open after each message. * Whether to keep SMTP connection open after each message.
* If this is set to true then to close the connection * If this is set to true then to close the connection
* requires an explicit call to smtpClose(). * requires an explicit call to smtpClose().
* @type boolean * @var boolean
*/ */
public $SMTPKeepAlive = false; public $SMTPKeepAlive = false;
/** /**
* Whether to split multiple to addresses into multiple messages * Whether to split multiple to addresses into multiple messages
* or send them all in one message. * or send them all in one message.
* @type boolean * @var boolean
*/ */
public $SingleTo = false; public $SingleTo = false;
/** /**
* Storage for addresses when SingleTo is enabled. * Storage for addresses when SingleTo is enabled.
* @type array * @var array
* @TODO This should really not be public * @TODO This should really not be public
*/ */
public $SingleToArray = array(); public $SingleToArray = array();
...@@ -365,15 +366,15 @@ class PHPMailer ...@@ -365,15 +366,15 @@ class PHPMailer
/** /**
* Whether to generate VERP addresses on send. * Whether to generate VERP addresses on send.
* Only applicable when sending via SMTP. * Only applicable when sending via SMTP.
* @link http://en.wikipedia.org/wiki/Variable_envelope_return_path * @link https://en.wikipedia.org/wiki/Variable_envelope_return_path
* @link http://www.postfix.org/VERP_README.html Postfix VERP info * @link http://www.postfix.org/VERP_README.html Postfix VERP info
* @type boolean * @var boolean
*/ */
public $do_verp = false; public $do_verp = false;
/** /**
* Whether to allow sending messages with an empty body. * Whether to allow sending messages with an empty body.
* @type boolean * @var boolean
*/ */
public $AllowEmpty = false; public $AllowEmpty = false;
...@@ -381,40 +382,40 @@ class PHPMailer ...@@ -381,40 +382,40 @@ class PHPMailer
* The default line ending. * The default line ending.
* @note The default remains "\n". We force CRLF where we know * @note The default remains "\n". We force CRLF where we know
* it must be used via self::CRLF. * it must be used via self::CRLF.
* @type string * @var string
*/ */
public $LE = "\n"; public $LE = "\n";
/** /**
* DKIM selector. * DKIM selector.
* @type string * @var string
*/ */
public $DKIM_selector = ''; public $DKIM_selector = '';
/** /**
* DKIM Identity. * DKIM Identity.
* Usually the email address used as the source of the email * Usually the email address used as the source of the email
* @type string * @var string
*/ */
public $DKIM_identity = ''; public $DKIM_identity = '';
/** /**
* DKIM passphrase. * DKIM passphrase.
* Used if your key is encrypted. * Used if your key is encrypted.
* @type string * @var string
*/ */
public $DKIM_passphrase = ''; public $DKIM_passphrase = '';
/** /**
* DKIM signing domain name. * DKIM signing domain name.
* @example 'example.com' * @example 'example.com'
* @type string * @var string
*/ */
public $DKIM_domain = ''; public $DKIM_domain = '';
/** /**
* DKIM private key file path. * DKIM private key file path.
* @type string * @var string
*/ */
public $DKIM_private = ''; public $DKIM_private = '';
...@@ -434,59 +435,48 @@ class PHPMailer ...@@ -434,59 +435,48 @@ class PHPMailer
* string $subject the subject * string $subject the subject
* string $body the email body * string $body the email body
* string $from email address of sender * string $from email address of sender
* @type string * @var string
*/ */
public $action_function = ''; public $action_function = '';
/** /**
* What to put in the X-Mailer header. * What to put in the X-Mailer header.
* Options: An empty string for PHPMailer default, whitespace for none, or a string to use * Options: An empty string for PHPMailer default, whitespace for none, or a string to use
* @type string * @var string
*/ */
public $XMailer = ''; public $XMailer = '';
/** /**
* Only For XOAUTH - Google
* Options: An empty string for PHPMailer default, Enter the email used to get access token
* @type string
*/
// public $UserEmail = '';
// public $RefreshToken = '';
// public $ClientId = '';
// public $ClientSecret = '';
/**
* An instance of the SMTP sender class. * An instance of the SMTP sender class.
* @type SMTP * @var SMTP
* @access protected * @access protected
*/ */
protected $smtp = null; protected $smtp = null;
/** /**
* The array of 'to' addresses. * The array of 'to' names and addresses.
* @type array * @var array
* @access protected * @access protected
*/ */
protected $to = array(); protected $to = array();
/** /**
* The array of 'cc' addresses. * The array of 'cc' names and addresses.
* @type array * @var array
* @access protected * @access protected
*/ */
protected $cc = array(); protected $cc = array();
/** /**
* The array of 'bcc' addresses. * The array of 'bcc' names and addresses.
* @type array * @var array
* @access protected * @access protected
*/ */
protected $bcc = array(); protected $bcc = array();
/** /**
* The array of reply-to names and addresses. * The array of reply-to names and addresses.
* @type array * @var array
* @access protected * @access protected
*/ */
protected $ReplyTo = array(); protected $ReplyTo = array();
...@@ -494,77 +484,100 @@ class PHPMailer ...@@ -494,77 +484,100 @@ class PHPMailer
/** /**
* An array of all kinds of addresses. * An array of all kinds of addresses.
* Includes all of $to, $cc, $bcc * Includes all of $to, $cc, $bcc
* @type array * @var array
* @access protected * @access protected
* @see PHPMailer::$to @see PHPMailer::$cc @see PHPMailer::$bcc
*/ */
protected $all_recipients = array(); protected $all_recipients = array();
/** /**
* An array of names and addresses queued for validation.
* In send(), valid and non duplicate entries are moved to $all_recipients
* and one of $to, $cc, or $bcc.
* This array is used only for addresses with IDN.
* @var array
* @access protected
* @see PHPMailer::$to @see PHPMailer::$cc @see PHPMailer::$bcc
* @see PHPMailer::$all_recipients
*/
protected $RecipientsQueue = array();
/**
* An array of reply-to names and addresses queued for validation.
* In send(), valid and non duplicate entries are moved to $ReplyTo.
* This array is used only for addresses with IDN.
* @var array
* @access protected
* @see PHPMailer::$ReplyTo
*/
protected $ReplyToQueue = array();
/**
* The array of attachments. * The array of attachments.
* @type array * @var array
* @access protected * @access protected
*/ */
protected $attachment = array(); protected $attachment = array();
/** /**
* The array of custom headers. * The array of custom headers.
* @type array * @var array
* @access protected * @access protected
*/ */
protected $CustomHeader = array(); protected $CustomHeader = array();
/** /**
* The most recent Message-ID (including angular brackets). * The most recent Message-ID (including angular brackets).
* @type string * @var string
* @access protected * @access protected
*/ */
protected $lastMessageID = ''; protected $lastMessageID = '';
/** /**
* The message's MIME type. * The message's MIME type.
* @type string * @var string
* @access protected * @access protected
*/ */
protected $message_type = ''; protected $message_type = '';
/** /**
* The array of MIME boundary strings. * The array of MIME boundary strings.
* @type array * @var array
* @access protected * @access protected
*/ */
protected $boundary = array(); protected $boundary = array();
/** /**
* The array of available languages. * The array of available languages.
* @type array * @var array
* @access protected * @access protected
*/ */
protected $language = array(); protected $language = array();
/** /**
* The number of errors encountered. * The number of errors encountered.
* @type integer * @var integer
* @access protected * @access protected
*/ */
protected $error_count = 0; protected $error_count = 0;
/** /**
* The S/MIME certificate file path. * The S/MIME certificate file path.
* @type string * @var string
* @access protected * @access protected
*/ */
protected $sign_cert_file = ''; protected $sign_cert_file = '';
/** /**
* The S/MIME key file path. * The S/MIME key file path.
* @type string * @var string
* @access protected * @access protected
*/ */
protected $sign_key_file = ''; protected $sign_key_file = '';
/** /**
* The optional S/MIME extra certificates ("CA Chain") file path. * The optional S/MIME extra certificates ("CA Chain") file path.
* @type string * @var string
* @access protected * @access protected
*/ */
protected $sign_extracerts_file = ''; protected $sign_extracerts_file = '';
...@@ -572,21 +585,21 @@ class PHPMailer ...@@ -572,21 +585,21 @@ class PHPMailer
/** /**
* The S/MIME password for the key. * The S/MIME password for the key.
* Used only if the key is encrypted. * Used only if the key is encrypted.
* @type string * @var string
* @access protected * @access protected
*/ */
protected $sign_key_pass = ''; protected $sign_key_pass = '';
/** /**
* Whether to throw exceptions for errors. * Whether to throw exceptions for errors.
* @type boolean * @var boolean
* @access protected * @access protected
*/ */
protected $exceptions = false; protected $exceptions = false;
/** /**
* Unique ID used for message ID and boundaries. * Unique ID used for message ID and boundaries.
* @type string * @var string
* @access protected * @access protected
*/ */
protected $uniqueid = ''; protected $uniqueid = '';
...@@ -613,7 +626,7 @@ class PHPMailer ...@@ -613,7 +626,7 @@ class PHPMailer
/** /**
* The maximum line length allowed by RFC 2822 section 2.1.1 * The maximum line length allowed by RFC 2822 section 2.1.1
* @type integer * @var integer
*/ */
const MAX_LINE_LENGTH = 998; const MAX_LINE_LENGTH = 998;
...@@ -775,55 +788,101 @@ class PHPMailer ...@@ -775,55 +788,101 @@ class PHPMailer
/** /**
* Add a "To" address. * Add a "To" address.
* @param string $address * @param string $address The email address to send to
* @param string $name * @param string $name
* @return boolean true on success, false if address already used * @return boolean true on success, false if address already used or invalid in some way
*/ */
public function addAddress($address, $name = '') public function addAddress($address, $name = '')
{ {
return $this->addAnAddress('to', $address, $name); return $this->addOrEnqueueAnAddress('to', $address, $name);
} }
/** /**
* Add a "CC" address. * Add a "CC" address.
* @note: This function works with the SMTP mailer on win32, not with the "mail" mailer. * @note: This function works with the SMTP mailer on win32, not with the "mail" mailer.
* @param string $address * @param string $address The email address to send to
* @param string $name * @param string $name
* @return boolean true on success, false if address already used * @return boolean true on success, false if address already used or invalid in some way
*/ */
public function addCC($address, $name = '') public function addCC($address, $name = '')
{ {
return $this->addAnAddress('cc', $address, $name); return $this->addOrEnqueueAnAddress('cc', $address, $name);
} }
/** /**
* Add a "BCC" address. * Add a "BCC" address.
* @note: This function works with the SMTP mailer on win32, not with the "mail" mailer. * @note: This function works with the SMTP mailer on win32, not with the "mail" mailer.
* @param string $address * @param string $address The email address to send to
* @param string $name * @param string $name
* @return boolean true on success, false if address already used * @return boolean true on success, false if address already used or invalid in some way
*/ */
public function addBCC($address, $name = '') public function addBCC($address, $name = '')
{ {
return $this->addAnAddress('bcc', $address, $name); return $this->addOrEnqueueAnAddress('bcc', $address, $name);
} }
/** /**
* Add a "Reply-to" address. * Add a "Reply-To" address.
* @param string $address * @param string $address The email address to reply to
* @param string $name * @param string $name
* @return boolean * @return boolean true on success, false if address already used or invalid in some way
*/ */
public function addReplyTo($address, $name = '') public function addReplyTo($address, $name = '')
{ {
return $this->addAnAddress('Reply-To', $address, $name); return $this->addOrEnqueueAnAddress('Reply-To', $address, $name);
} }
/** /**
* Add an address to one of the recipient arrays. * Add an address to one of the recipient arrays or to the ReplyTo array. Because PHPMailer
* Addresses that have been added already return false, but do not throw exceptions * can't validate addresses with an IDN without knowing the PHPMailer::$CharSet (that can still
* @param string $kind One of 'to', 'cc', 'bcc', 'ReplyTo' * be modified after calling this function), addition of such addresses is delayed until send().
* @param string $address The email address to send to * Addresses that have been added already return false, but do not throw exceptions.
* @param string $kind One of 'to', 'cc', 'bcc', or 'ReplyTo'
* @param string $address The email address to send, resp. to reply to
* @param string $name
* @throws phpmailerException
* @return boolean true on success, false if address already used or invalid in some way
* @access protected
*/
protected function addOrEnqueueAnAddress($kind, $address, $name)
{
$address = trim($address);
$name = trim(preg_replace('/[\r\n]+/', '', $name)); //Strip breaks and trim
if (($pos = strrpos($address, '@')) === false) {
// At-sign is misssing.
$error_message = $this->lang('invalid_address') . $address;
$this->setError($error_message);
$this->edebug($error_message);
if ($this->exceptions) {
throw new phpmailerException($error_message);
}
return false;
}
$params = array($kind, $address, $name);
// Enqueue addresses with IDN until we know the PHPMailer::$CharSet.
if ($this->has8bitChars(substr($address, ++$pos)) and $this->idnSupported()) {
if ($kind != 'Reply-To') {
if (!array_key_exists($address, $this->RecipientsQueue)) {
$this->RecipientsQueue[$address] = $params;
return true;
}
} else {
if (!array_key_exists($address, $this->ReplyToQueue)) {
$this->ReplyToQueue[$address] = $params;
return true;
}
}
return false;
}
// Immediately add standard addresses without IDN.
return call_user_func_array(array($this, 'addAnAddress'), $params);
}
/**
* Add an address to one of the recipient arrays or to the ReplyTo array.
* Addresses that have been added already return false, but do not throw exceptions.
* @param string $kind One of 'to', 'cc', 'bcc', or 'ReplyTo'
* @param string $address The email address to send, resp. to reply to
* @param string $name * @param string $name
* @throws phpmailerException * @throws phpmailerException
* @return boolean true on success, false if address already used or invalid in some way * @return boolean true on success, false if address already used or invalid in some way
...@@ -831,26 +890,26 @@ class PHPMailer ...@@ -831,26 +890,26 @@ class PHPMailer
*/ */
protected function addAnAddress($kind, $address, $name = '') protected function addAnAddress($kind, $address, $name = '')
{ {
if (!preg_match('/^(to|cc|bcc|Reply-To)$/', $kind)) { if (!in_array($kind, array('to', 'cc', 'bcc', 'Reply-To'))) {
$this->setError($this->lang('Invalid recipient array') . ': ' . $kind); $error_message = $this->lang('Invalid recipient kind: ') . $kind;
$this->edebug($this->lang('Invalid recipient array') . ': ' . $kind); $this->setError($error_message);
$this->edebug($error_message);
if ($this->exceptions) { if ($this->exceptions) {
throw new phpmailerException('Invalid recipient array: ' . $kind); throw new phpmailerException($error_message);
} }
return false; return false;
} }
$address = trim($address);
$name = trim(preg_replace('/[\r\n]+/', '', $name)); //Strip breaks and trim
if (!$this->validateAddress($address)) { if (!$this->validateAddress($address)) {
$this->setError($this->lang('invalid_address') . ': ' . $address); $error_message = $this->lang('invalid_address') . $address;
$this->edebug($this->lang('invalid_address') . ': ' . $address); $this->setError($error_message);
$this->edebug($error_message);
if ($this->exceptions) { if ($this->exceptions) {
throw new phpmailerException($this->lang('invalid_address') . ': ' . $address); throw new phpmailerException($error_message);
} }
return false; return false;
} }
if ($kind != 'Reply-To') { if ($kind != 'Reply-To') {
if (!isset($this->all_recipients[strtolower($address)])) { if (!array_key_exists(strtolower($address), $this->all_recipients)) {
array_push($this->$kind, array($address, $name)); array_push($this->$kind, array($address, $name));
$this->all_recipients[strtolower($address)] = true; $this->all_recipients[strtolower($address)] = true;
return true; return true;
...@@ -931,11 +990,15 @@ class PHPMailer ...@@ -931,11 +990,15 @@ class PHPMailer
{ {
$address = trim($address); $address = trim($address);
$name = trim(preg_replace('/[\r\n]+/', '', $name)); //Strip breaks and trim $name = trim(preg_replace('/[\r\n]+/', '', $name)); //Strip breaks and trim
if (!$this->validateAddress($address)) { // Don't validate now addresses with IDN. Will be done in send().
$this->setError($this->lang('invalid_address') . ': ' . $address); if (($pos = strrpos($address, '@')) === false or
$this->edebug($this->lang('invalid_address') . ': ' . $address); (!$this->has8bitChars(substr($address, ++$pos)) or !$this->idnSupported()) and
!$this->validateAddress($address)) {
$error_message = $this->lang('invalid_address') . $address;
$this->setError($error_message);
$this->edebug($error_message);
if ($this->exceptions) { if ($this->exceptions) {
throw new phpmailerException($this->lang('invalid_address') . ': ' . $address); throw new phpmailerException($error_message);
} }
return false; return false;
} }
...@@ -965,10 +1028,10 @@ class PHPMailer ...@@ -965,10 +1028,10 @@ class PHPMailer
* Check that a string looks like an email address. * Check that a string looks like an email address.
* @param string $address The email address to check * @param string $address The email address to check
* @param string $patternselect A selector for the validation pattern to use : * @param string $patternselect A selector for the validation pattern to use :
* * `auto` Pick strictest one automatically; * * `auto` Pick best pattern automatically;
* * `pcre8` Use the squiloople.com pattern, requires PCRE > 8.0, PHP >= 5.3.2, 5.2.14; * * `pcre8` Use the squiloople.com pattern, requires PCRE > 8.0, PHP >= 5.3.2, 5.2.14;
* * `pcre` Use old PCRE implementation; * * `pcre` Use old PCRE implementation;
* * `php` Use PHP built-in FILTER_VALIDATE_EMAIL; same as pcre8 but does not allow 'dotless' domains; * * `php` Use PHP built-in FILTER_VALIDATE_EMAIL;
* * `html5` Use the pattern given by the HTML5 spec for 'email' type form input elements. * * `html5` Use the pattern given by the HTML5 spec for 'email' type form input elements.
* * `noregex` Don't use a regex: super fast, really dumb. * * `noregex` Don't use a regex: super fast, really dumb.
* @return boolean * @return boolean
...@@ -977,6 +1040,10 @@ class PHPMailer ...@@ -977,6 +1040,10 @@ class PHPMailer
*/ */
public static function validateAddress($address, $patternselect = 'auto') public static function validateAddress($address, $patternselect = 'auto')
{ {
//Reject line breaks in addresses; it's valid RFC5322, but not RFC5321
if (strpos($address, "\n") !== false or strpos($address, "\r") !== false) {
return false;
}
if (!$patternselect or $patternselect == 'auto') { if (!$patternselect or $patternselect == 'auto') {
//Check this constant first so it works when extension_loaded() is disabled by safe mode //Check this constant first so it works when extension_loaded() is disabled by safe mode
//Constant was added in PHP 5.2.4 //Constant was added in PHP 5.2.4
...@@ -1057,6 +1124,48 @@ class PHPMailer ...@@ -1057,6 +1124,48 @@ class PHPMailer
} }
/** /**
* Tells whether IDNs (Internationalized Domain Names) are supported or not. This requires the
* "intl" and "mbstring" PHP extensions.
* @return bool "true" if required functions for IDN support are present
*/
public function idnSupported()
{
// @TODO: Write our own "idn_to_ascii" function for PHP <= 5.2.
return function_exists('idn_to_ascii') and function_exists('mb_convert_encoding');
}
/**
* Converts IDN in given email address to its ASCII form, also known as punycode, if possible.
* Important: Address must be passed in same encoding as currently set in PHPMailer::$CharSet.
* This function silently returns unmodified address if:
* - No conversion is necessary (i.e. domain name is not an IDN, or is already in ASCII form)
* - Conversion to punycode is impossible (e.g. required PHP functions are not available)
* or fails for any reason (e.g. domain has characters not allowed in an IDN)
* @see PHPMailer::$CharSet
* @param string $address The email address to convert
* @return string The encoded address in ASCII form
*/
public function punyencodeAddress($address)
{
// Verify we have required functions, CharSet, and at-sign.
if ($this->idnSupported() and
!empty($this->CharSet) and
($pos = strrpos($address, '@')) !== false) {
$domain = substr($address, ++$pos);
// Verify CharSet string is a valid one, and domain properly encoded in this CharSet.
if ($this->has8bitChars($domain) and @mb_check_encoding($domain, $this->CharSet)) {
$domain = mb_convert_encoding($domain, 'UTF-8', $this->CharSet);
if (($punycode = defined('INTL_IDNA_VARIANT_UTS46') ?
idn_to_ascii($domain, 0, INTL_IDNA_VARIANT_UTS46) :
idn_to_ascii($domain)) !== false) {
return substr($address, 0, $pos) . $punycode;
}
}
}
return $address;
}
/**
* Create a message and send it. * Create a message and send it.
* Uses the sending method specified by $Mailer. * Uses the sending method specified by $Mailer.
* @throws phpmailerException * @throws phpmailerException
...@@ -1087,17 +1196,41 @@ class PHPMailer ...@@ -1087,17 +1196,41 @@ class PHPMailer
public function preSend() public function preSend()
{ {
try { try {
$this->error_count = 0; // Reset errors
$this->mailHeader = ''; $this->mailHeader = '';
// Dequeue recipient and Reply-To addresses with IDN
foreach (array_merge($this->RecipientsQueue, $this->ReplyToQueue) as $params) {
$params[1] = $this->punyencodeAddress($params[1]);
call_user_func_array(array($this, 'addAnAddress'), $params);
}
if ((count($this->to) + count($this->cc) + count($this->bcc)) < 1) { if ((count($this->to) + count($this->cc) + count($this->bcc)) < 1) {
throw new phpmailerException($this->lang('provide_address'), self::STOP_CRITICAL); throw new phpmailerException($this->lang('provide_address'), self::STOP_CRITICAL);
} }
// Validate From, Sender, and ConfirmReadingTo addresses
foreach (array('From', 'Sender', 'ConfirmReadingTo') as $address_kind) {
$this->$address_kind = trim($this->$address_kind);
if (empty($this->$address_kind)) {
continue;
}
$this->$address_kind = $this->punyencodeAddress($this->$address_kind);
if (!$this->validateAddress($this->$address_kind)) {
$error_message = $this->lang('invalid_address') . $this->$address_kind;
$this->setError($error_message);
$this->edebug($error_message);
if ($this->exceptions) {
throw new phpmailerException($error_message);
}
return false;
}
}
// Set whether the message is multipart/alternative // Set whether the message is multipart/alternative
if (!empty($this->AltBody)) { if (!empty($this->AltBody)) {
$this->ContentType = 'multipart/alternative'; $this->ContentType = 'multipart/alternative';
} }
$this->error_count = 0; // Reset errors
$this->setMessageType(); $this->setMessageType();
// Refuse to send an empty message unless we are specifically allowing it // Refuse to send an empty message unless we are specifically allowing it
if (!$this->AllowEmpty and empty($this->Body)) { if (!$this->AllowEmpty and empty($this->Body)) {
...@@ -1238,7 +1371,15 @@ class PHPMailer ...@@ -1238,7 +1371,15 @@ class PHPMailer
fputs($mail, $header); fputs($mail, $header);
fputs($mail, $body); fputs($mail, $body);
$result = pclose($mail); $result = pclose($mail);
$this->doCallback(($result == 0), $this->to, $this->cc, $this->bcc, $this->Subject, $body, $this->From); $this->doCallback(
($result == 0),
$this->to,
$this->cc,
$this->bcc,
$this->Subject,
$body,
$this->From
);
if ($result != 0) { if ($result != 0) {
throw new phpmailerException($this->lang('execute') . $this->Sendmail, self::STOP_CRITICAL); throw new phpmailerException($this->lang('execute') . $this->Sendmail, self::STOP_CRITICAL);
} }
...@@ -1524,7 +1665,7 @@ class PHPMailer ...@@ -1524,7 +1665,7 @@ class PHPMailer
'file_open' => 'File Error: Could not open file: ', 'file_open' => 'File Error: Could not open file: ',
'from_failed' => 'The following From address failed: ', 'from_failed' => 'The following From address failed: ',
'instantiate' => 'Could not instantiate mail function.', 'instantiate' => 'Could not instantiate mail function.',
'invalid_address' => 'Invalid address', 'invalid_address' => 'Invalid address: ',
'mailer_not_supported' => ' mailer is not supported.', 'mailer_not_supported' => ' mailer is not supported.',
'provide_address' => 'You must provide at least one recipient email address.', 'provide_address' => 'You must provide at least one recipient email address.',
'recipients_failed' => 'SMTP Error: The following recipients failed: ', 'recipients_failed' => 'SMTP Error: The following recipients failed: ',
...@@ -1789,7 +1930,6 @@ class PHPMailer ...@@ -1789,7 +1930,6 @@ class PHPMailer
} }
$result .= $this->headerLine('Date', $this->MessageDate); $result .= $this->headerLine('Date', $this->MessageDate);
// To be created automatically by mail() // To be created automatically by mail()
if ($this->SingleTo) { if ($this->SingleTo) {
if ($this->Mailer != 'mail') { if ($this->Mailer != 'mail') {
...@@ -1835,7 +1975,7 @@ class PHPMailer ...@@ -1835,7 +1975,7 @@ class PHPMailer
if ($this->MessageID != '') { if ($this->MessageID != '') {
$this->lastMessageID = $this->MessageID; $this->lastMessageID = $this->MessageID;
} else { } else {
$this->lastMessageID = sprintf('<%s@%s>', $this->uniqueid, $this->ServerHostname()); $this->lastMessageID = sprintf('<%s@%s>', $this->uniqueid, $this->serverHostname());
} }
$result .= $this->headerLine('Message-ID', $this->lastMessageID); $result .= $this->headerLine('Message-ID', $this->lastMessageID);
if (!is_null($this->Priority)) { if (!is_null($this->Priority)) {
...@@ -1844,7 +1984,7 @@ class PHPMailer ...@@ -1844,7 +1984,7 @@ class PHPMailer
if ($this->XMailer == '') { if ($this->XMailer == '') {
$result .= $this->headerLine( $result .= $this->headerLine(
'X-Mailer', 'X-Mailer',
'PHPMailer ' . $this->Version . ' (https://github.com/PHPMailer/PHPMailer/)' 'PHPMailer ' . $this->Version . ' (https://github.com/PHPMailer/PHPMailer)'
); );
} else { } else {
$myXmailer = trim($this->XMailer); $myXmailer = trim($this->XMailer);
...@@ -1854,7 +1994,7 @@ class PHPMailer ...@@ -1854,7 +1994,7 @@ class PHPMailer
} }
if ($this->ConfirmReadingTo != '') { if ($this->ConfirmReadingTo != '') {
$result .= $this->headerLine('Disposition-Notification-To', '<' . trim($this->ConfirmReadingTo) . '>'); $result .= $this->headerLine('Disposition-Notification-To', '<' . $this->ConfirmReadingTo . '>');
} }
// Add custom headers // Add custom headers
...@@ -2335,7 +2475,7 @@ class PHPMailer ...@@ -2335,7 +2475,7 @@ class PHPMailer
$type = $attachment[4]; $type = $attachment[4];
$disposition = $attachment[6]; $disposition = $attachment[6];
$cid = $attachment[7]; $cid = $attachment[7];
if ($disposition == 'inline' && isset($cidUniq[$cid])) { if ($disposition == 'inline' && array_key_exists($cid, $cidUniq)) {
continue; continue;
} }
$cidUniq[$cid] = true; $cidUniq[$cid] = true;
...@@ -2426,7 +2566,6 @@ class PHPMailer ...@@ -2426,7 +2566,6 @@ class PHPMailer
* @param string $path The full path to the file * @param string $path The full path to the file
* @param string $encoding The encoding to use; one of 'base64', '7bit', '8bit', 'binary', 'quoted-printable' * @param string $encoding The encoding to use; one of 'base64', '7bit', '8bit', 'binary', 'quoted-printable'
* @throws phpmailerException * @throws phpmailerException
* @see EncodeFile(encodeFile
* @access protected * @access protected
* @return string * @return string
*/ */
...@@ -2723,7 +2862,6 @@ class PHPMailer ...@@ -2723,7 +2862,6 @@ class PHPMailer
return str_replace(' ', '_', $encoded); return str_replace(' ', '_', $encoded);
} }
/** /**
* Add a string or binary attachment (non-filesystem). * Add a string or binary attachment (non-filesystem).
* This method can be used to attach ascii or binary data, * This method can be used to attach ascii or binary data,
...@@ -2886,6 +3024,22 @@ class PHPMailer ...@@ -2886,6 +3024,22 @@ class PHPMailer
} }
/** /**
* Clear queued addresses of given kind.
* @access protected
* @param string $kind 'to', 'cc', or 'bcc'
* @return void
*/
public function clearQueuedAddresses($kind)
{
$RecipientsQueue = $this->RecipientsQueue;
foreach ($RecipientsQueue as $address => $params) {
if ($params[0] == $kind) {
unset($this->RecipientsQueue[$address]);
}
}
}
/**
* Clear all To recipients. * Clear all To recipients.
* @return void * @return void
*/ */
...@@ -2895,6 +3049,7 @@ class PHPMailer ...@@ -2895,6 +3049,7 @@ class PHPMailer
unset($this->all_recipients[strtolower($to[0])]); unset($this->all_recipients[strtolower($to[0])]);
} }
$this->to = array(); $this->to = array();
$this->clearQueuedAddresses('to');
} }
/** /**
...@@ -2907,6 +3062,7 @@ class PHPMailer ...@@ -2907,6 +3062,7 @@ class PHPMailer
unset($this->all_recipients[strtolower($cc[0])]); unset($this->all_recipients[strtolower($cc[0])]);
} }
$this->cc = array(); $this->cc = array();
$this->clearQueuedAddresses('cc');
} }
/** /**
...@@ -2919,6 +3075,7 @@ class PHPMailer ...@@ -2919,6 +3075,7 @@ class PHPMailer
unset($this->all_recipients[strtolower($bcc[0])]); unset($this->all_recipients[strtolower($bcc[0])]);
} }
$this->bcc = array(); $this->bcc = array();
$this->clearQueuedAddresses('bcc');
} }
/** /**
...@@ -2928,6 +3085,7 @@ class PHPMailer ...@@ -2928,6 +3085,7 @@ class PHPMailer
public function clearReplyTos() public function clearReplyTos()
{ {
$this->ReplyTo = array(); $this->ReplyTo = array();
$this->ReplyToQueue = array();
} }
/** /**
...@@ -2940,6 +3098,7 @@ class PHPMailer ...@@ -2940,6 +3098,7 @@ class PHPMailer
$this->cc = array(); $this->cc = array();
$this->bcc = array(); $this->bcc = array();
$this->all_recipients = array(); $this->all_recipients = array();
$this->RecipientsQueue = array();
} }
/** /**
...@@ -3096,8 +3255,7 @@ class PHPMailer ...@@ -3096,8 +3255,7 @@ class PHPMailer
} }
/** /**
* Returns all custom headers * Returns all custom headers.
*
* @return array * @return array
*/ */
public function getCustomHeaders() public function getCustomHeaders()
...@@ -3114,13 +3272,13 @@ class PHPMailer ...@@ -3114,13 +3272,13 @@ class PHPMailer
* @param string $message HTML message string * @param string $message HTML message string
* @param string $basedir baseline directory for path * @param string $basedir baseline directory for path
* @param boolean|callable $advanced Whether to use the internal HTML to text converter * @param boolean|callable $advanced Whether to use the internal HTML to text converter
* or your own custom converter @see html2text() * or your own custom converter @see PHPMailer::html2text()
* @return string $message * @return string $message
*/ */
public function msgHTML($message, $basedir = '', $advanced = false) public function msgHTML($message, $basedir = '', $advanced = false)
{ {
preg_match_all('/(src|background)=["\'](.*)["\']/Ui', $message, $images); preg_match_all('/(src|background)=["\'](.*)["\']/Ui', $message, $images);
if (isset($images[2])) { if (array_key_exists(2, $images)) {
foreach ($images[2] as $imgindex => $url) { foreach ($images[2] as $imgindex => $url) {
// Convert data URIs into embedded images // Convert data URIs into embedded images
if (preg_match('#^data:(image[^;,]*)(;base64)?,#', $url, $match)) { if (preg_match('#^data:(image[^;,]*)(;base64)?,#', $url, $match)) {
...@@ -3444,7 +3602,6 @@ class PHPMailer ...@@ -3444,7 +3602,6 @@ class PHPMailer
return preg_replace('/(\r\n|\r|\n)/ms', $breaktype, $text); return preg_replace('/(\r\n|\r|\n)/ms', $breaktype, $text);
} }
/** /**
* Set the public and private key files and password for S/MIME signing. * Set the public and private key files and password for S/MIME signing.
* @access public * @access public
...@@ -3613,7 +3770,10 @@ class PHPMailer ...@@ -3613,7 +3770,10 @@ class PHPMailer
"\tbh=" . $DKIMb64 . ";\r\n" . "\tbh=" . $DKIMb64 . ";\r\n" .
"\tb="; "\tb=";
$toSign = $this->DKIM_HeaderC( $toSign = $this->DKIM_HeaderC(
$from_header . "\r\n" . $to_header . "\r\n" . $subject_header . "\r\n" . $dkimhdrs $from_header . "\r\n" .
$to_header . "\r\n" .
$subject_header . "\r\n" .
$dkimhdrs
); );
$signed = $this->DKIM_Sign($toSign); $signed = $this->DKIM_Sign($toSign);
return $dkimhdrs . $signed . "\r\n"; return $dkimhdrs . $signed . "\r\n";
...@@ -3633,6 +3793,7 @@ class PHPMailer ...@@ -3633,6 +3793,7 @@ class PHPMailer
/** /**
* Allows for public read access to 'to' property. * Allows for public read access to 'to' property.
* @note: Before the send() call, queued addresses (i.e. with IDN) are not yet included.
* @access public * @access public
* @return array * @return array
*/ */
...@@ -3643,6 +3804,7 @@ class PHPMailer ...@@ -3643,6 +3804,7 @@ class PHPMailer
/** /**
* Allows for public read access to 'cc' property. * Allows for public read access to 'cc' property.
* @note: Before the send() call, queued addresses (i.e. with IDN) are not yet included.
* @access public * @access public
* @return array * @return array
*/ */
...@@ -3653,6 +3815,7 @@ class PHPMailer ...@@ -3653,6 +3815,7 @@ class PHPMailer
/** /**
* Allows for public read access to 'bcc' property. * Allows for public read access to 'bcc' property.
* @note: Before the send() call, queued addresses (i.e. with IDN) are not yet included.
* @access public * @access public
* @return array * @return array
*/ */
...@@ -3663,6 +3826,7 @@ class PHPMailer ...@@ -3663,6 +3826,7 @@ class PHPMailer
/** /**
* Allows for public read access to 'ReplyTo' property. * Allows for public read access to 'ReplyTo' property.
* @note: Before the send() call, queued addresses (i.e. with IDN) are not yet included.
* @access public * @access public
* @return array * @return array
*/ */
...@@ -3673,6 +3837,7 @@ class PHPMailer ...@@ -3673,6 +3837,7 @@ class PHPMailer
/** /**
* Allows for public read access to 'all_recipients' property. * Allows for public read access to 'all_recipients' property.
* @note: Before the send() call, queued addresses (i.e. with IDN) are not yet included.
* @access public * @access public
* @return array * @return array
*/ */
......
...@@ -28,25 +28,25 @@ class SMTP ...@@ -28,25 +28,25 @@ class SMTP
{ {
/** /**
* The PHPMailer SMTP version number. * The PHPMailer SMTP version number.
* @type string * @var string
*/ */
const VERSION = '5.2.13'; const VERSION = '5.2.14';
/** /**
* SMTP line break constant. * SMTP line break constant.
* @type string * @var string
*/ */
const CRLF = "\r\n"; const CRLF = "\r\n";
/** /**
* The SMTP port to use if one is not specified. * The SMTP port to use if one is not specified.
* @type integer * @var integer
*/ */
const DEFAULT_SMTP_PORT = 25; const DEFAULT_SMTP_PORT = 25;
/** /**
* The maximum line length allowed by RFC 2822 section 2.1.1 * The maximum line length allowed by RFC 2822 section 2.1.1
* @type integer * @var integer
*/ */
const MAX_LINE_LENGTH = 998; const MAX_LINE_LENGTH = 998;
...@@ -77,15 +77,15 @@ class SMTP ...@@ -77,15 +77,15 @@ class SMTP
/** /**
* The PHPMailer SMTP Version number. * The PHPMailer SMTP Version number.
* @type string * @var string
* @deprecated Use the `VERSION` constant instead * @deprecated Use the `VERSION` constant instead
* @see SMTP::VERSION * @see SMTP::VERSION
*/ */
public $Version = '5.2.13'; public $Version = '5.2.14';
/** /**
* SMTP server port number. * SMTP server port number.
* @type integer * @var integer
* @deprecated This is only ever used as a default value, so use the `DEFAULT_SMTP_PORT` constant instead * @deprecated This is only ever used as a default value, so use the `DEFAULT_SMTP_PORT` constant instead
* @see SMTP::DEFAULT_SMTP_PORT * @see SMTP::DEFAULT_SMTP_PORT
*/ */
...@@ -93,7 +93,7 @@ class SMTP ...@@ -93,7 +93,7 @@ class SMTP
/** /**
* SMTP reply line ending. * SMTP reply line ending.
* @type string * @var string
* @deprecated Use the `CRLF` constant instead * @deprecated Use the `CRLF` constant instead
* @see SMTP::CRLF * @see SMTP::CRLF
*/ */
...@@ -107,7 +107,7 @@ class SMTP ...@@ -107,7 +107,7 @@ class SMTP
* * self::DEBUG_SERVER (`2`) Client commands and server responses * * self::DEBUG_SERVER (`2`) Client commands and server responses
* * self::DEBUG_CONNECTION (`3`) As DEBUG_SERVER plus connection status * * self::DEBUG_CONNECTION (`3`) As DEBUG_SERVER plus connection status
* * self::DEBUG_LOWLEVEL (`4`) Low-level data output, all messages * * self::DEBUG_LOWLEVEL (`4`) Low-level data output, all messages
* @type integer * @var integer
*/ */
public $do_debug = self::DEBUG_OFF; public $do_debug = self::DEBUG_OFF;
...@@ -122,7 +122,7 @@ class SMTP ...@@ -122,7 +122,7 @@ class SMTP
* <code> * <code>
* $smtp->Debugoutput = function($str, $level) {echo "debug level $level; message: $str";}; * $smtp->Debugoutput = function($str, $level) {echo "debug level $level; message: $str";};
* </code> * </code>
* @type string|callable * @var string|callable
*/ */
public $Debugoutput = 'echo'; public $Debugoutput = 'echo';
...@@ -130,7 +130,7 @@ class SMTP ...@@ -130,7 +130,7 @@ class SMTP
* Whether to use VERP. * Whether to use VERP.
* @link http://en.wikipedia.org/wiki/Variable_envelope_return_path * @link http://en.wikipedia.org/wiki/Variable_envelope_return_path
* @link http://www.postfix.org/VERP_README.html Info on VERP * @link http://www.postfix.org/VERP_README.html Info on VERP
* @type boolean * @var boolean
*/ */
public $do_verp = false; public $do_verp = false;
...@@ -139,26 +139,26 @@ class SMTP ...@@ -139,26 +139,26 @@ class SMTP
* Default of 5 minutes (300sec) is from RFC2821 section 4.5.3.2 * Default of 5 minutes (300sec) is from RFC2821 section 4.5.3.2
* This needs to be quite high to function correctly with hosts using greetdelay as an anti-spam measure. * This needs to be quite high to function correctly with hosts using greetdelay as an anti-spam measure.
* @link http://tools.ietf.org/html/rfc2821#section-4.5.3.2 * @link http://tools.ietf.org/html/rfc2821#section-4.5.3.2
* @type integer * @var integer
*/ */
public $Timeout = 300; public $Timeout = 300;
/** /**
* How long to wait for commands to complete, in seconds. * How long to wait for commands to complete, in seconds.
* Default of 5 minutes (300sec) is from RFC2821 section 4.5.3.2 * Default of 5 minutes (300sec) is from RFC2821 section 4.5.3.2
* @type integer * @var integer
*/ */
public $Timelimit = 300; public $Timelimit = 300;
/** /**
* The socket for the server connection. * The socket for the server connection.
* @type resource * @var resource
*/ */
protected $smtp_conn; protected $smtp_conn;
/** /**
* Error information, if any, for the last SMTP command. * Error information, if any, for the last SMTP command.
* @type array * @var array
*/ */
protected $error = array( protected $error = array(
'error' => '', 'error' => '',
...@@ -170,7 +170,7 @@ class SMTP ...@@ -170,7 +170,7 @@ class SMTP
/** /**
* The reply the server sent to us for HELO. * The reply the server sent to us for HELO.
* If null, no HELO string has yet been received. * If null, no HELO string has yet been received.
* @type string|null * @var string|null
*/ */
protected $helo_rply = null; protected $helo_rply = null;
...@@ -181,13 +181,13 @@ class SMTP ...@@ -181,13 +181,13 @@ class SMTP
* represents the server name. In case of HELO it is the only element of the array. * represents the server name. In case of HELO it is the only element of the array.
* Other values can be boolean TRUE or an array containing extension options. * Other values can be boolean TRUE or an array containing extension options.
* If null, no HELO/EHLO string has yet been received. * If null, no HELO/EHLO string has yet been received.
* @type array|null * @var array|null
*/ */
protected $server_caps = null; protected $server_caps = null;
/** /**
* The most recent reply received from the server. * The most recent reply received from the server.
* @type string * @var string
*/ */
protected $last_reply = ''; protected $last_reply = '';
...@@ -814,15 +814,15 @@ class SMTP ...@@ -814,15 +814,15 @@ class SMTP
* Sets the TO argument to $toaddr. * Sets the TO argument to $toaddr.
* Returns true if the recipient was accepted false if it was rejected. * Returns true if the recipient was accepted false if it was rejected.
* Implements from rfc 821: RCPT <SP> TO:<forward-path> <CRLF> * Implements from rfc 821: RCPT <SP> TO:<forward-path> <CRLF>
* @param string $toaddr The address the message is being sent to * @param string $address The address the message is being sent to
* @access public * @access public
* @return boolean * @return boolean
*/ */
public function recipient($toaddr) public function recipient($address)
{ {
return $this->sendCommand( return $this->sendCommand(
'RCPT TO', 'RCPT TO',
'RCPT TO:<' . $toaddr . '>', 'RCPT TO:<' . $address . '>',
array(250, 251) array(250, 251)
); );
} }
...@@ -853,6 +853,11 @@ class SMTP ...@@ -853,6 +853,11 @@ class SMTP
$this->setError("Called $command without being connected"); $this->setError("Called $command without being connected");
return false; return false;
} }
//Reject line breaks in all commands
if (strpos($commandstring, "\n") !== false or strpos($commandstring, "\r") !== false) {
$this->setError("Command '$command' contained line breaks");
return false;
}
$this->client_send($commandstring . self::CRLF); $this->client_send($commandstring . self::CRLF);
$this->last_reply = $this->get_lines(); $this->last_reply = $this->get_lines();
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment