Edit File by line
/home/zeestwma/ceyloniy.../wp-inclu.../PHPMaile...
File: SMTP.php
<?php
[0] Fix | Delete
[1] Fix | Delete
/**
[2] Fix | Delete
* PHPMailer RFC821 SMTP email transport class.
[3] Fix | Delete
* PHP Version 5.5.
[4] Fix | Delete
*
[5] Fix | Delete
* @see https://github.com/PHPMailer/PHPMailer/ The PHPMailer GitHub project
[6] Fix | Delete
*
[7] Fix | Delete
* @author Marcus Bointon (Synchro/coolbru) <phpmailer@synchromedia.co.uk>
[8] Fix | Delete
* @author Jim Jagielski (jimjag) <jimjag@gmail.com>
[9] Fix | Delete
* @author Andy Prevost (codeworxtech) <codeworxtech@users.sourceforge.net>
[10] Fix | Delete
* @author Brent R. Matzelle (original founder)
[11] Fix | Delete
* @copyright 2012 - 2020 Marcus Bointon
[12] Fix | Delete
* @copyright 2010 - 2012 Jim Jagielski
[13] Fix | Delete
* @copyright 2004 - 2009 Andy Prevost
[14] Fix | Delete
* @license https://www.gnu.org/licenses/old-licenses/lgpl-2.1.html GNU Lesser General Public License
[15] Fix | Delete
* @note This program is distributed in the hope that it will be useful - WITHOUT
[16] Fix | Delete
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
[17] Fix | Delete
* FITNESS FOR A PARTICULAR PURPOSE.
[18] Fix | Delete
*/
[19] Fix | Delete
[20] Fix | Delete
namespace PHPMailer\PHPMailer;
[21] Fix | Delete
[22] Fix | Delete
/**
[23] Fix | Delete
* PHPMailer RFC821 SMTP email transport class.
[24] Fix | Delete
* Implements RFC 821 SMTP commands and provides some utility methods for sending mail to an SMTP server.
[25] Fix | Delete
*
[26] Fix | Delete
* @author Chris Ryan
[27] Fix | Delete
* @author Marcus Bointon <phpmailer@synchromedia.co.uk>
[28] Fix | Delete
*/
[29] Fix | Delete
class SMTP
[30] Fix | Delete
{
[31] Fix | Delete
/**
[32] Fix | Delete
* The PHPMailer SMTP version number.
[33] Fix | Delete
*
[34] Fix | Delete
* @var string
[35] Fix | Delete
*/
[36] Fix | Delete
const VERSION = '7.0.0';
[37] Fix | Delete
[38] Fix | Delete
/**
[39] Fix | Delete
* SMTP line break constant.
[40] Fix | Delete
*
[41] Fix | Delete
* @var string
[42] Fix | Delete
*/
[43] Fix | Delete
const LE = "\r\n";
[44] Fix | Delete
[45] Fix | Delete
/**
[46] Fix | Delete
* The SMTP port to use if one is not specified.
[47] Fix | Delete
*
[48] Fix | Delete
* @var int
[49] Fix | Delete
*/
[50] Fix | Delete
const DEFAULT_PORT = 25;
[51] Fix | Delete
[52] Fix | Delete
/**
[53] Fix | Delete
* The SMTPs port to use if one is not specified.
[54] Fix | Delete
*
[55] Fix | Delete
* @var int
[56] Fix | Delete
*/
[57] Fix | Delete
const DEFAULT_SECURE_PORT = 465;
[58] Fix | Delete
[59] Fix | Delete
/**
[60] Fix | Delete
* The maximum line length allowed by RFC 5321 section 4.5.3.1.6,
[61] Fix | Delete
* *excluding* a trailing CRLF break.
[62] Fix | Delete
*
[63] Fix | Delete
* @see https://www.rfc-editor.org/rfc/rfc5321#section-4.5.3.1.6
[64] Fix | Delete
*
[65] Fix | Delete
* @var int
[66] Fix | Delete
*/
[67] Fix | Delete
const MAX_LINE_LENGTH = 998;
[68] Fix | Delete
[69] Fix | Delete
/**
[70] Fix | Delete
* The maximum line length allowed for replies in RFC 5321 section 4.5.3.1.5,
[71] Fix | Delete
* *including* a trailing CRLF line break.
[72] Fix | Delete
*
[73] Fix | Delete
* @see https://www.rfc-editor.org/rfc/rfc5321#section-4.5.3.1.5
[74] Fix | Delete
*
[75] Fix | Delete
* @var int
[76] Fix | Delete
*/
[77] Fix | Delete
const MAX_REPLY_LENGTH = 512;
[78] Fix | Delete
[79] Fix | Delete
/**
[80] Fix | Delete
* Debug level for no output.
[81] Fix | Delete
*
[82] Fix | Delete
* @var int
[83] Fix | Delete
*/
[84] Fix | Delete
const DEBUG_OFF = 0;
[85] Fix | Delete
[86] Fix | Delete
/**
[87] Fix | Delete
* Debug level to show client -> server messages.
[88] Fix | Delete
*
[89] Fix | Delete
* @var int
[90] Fix | Delete
*/
[91] Fix | Delete
const DEBUG_CLIENT = 1;
[92] Fix | Delete
[93] Fix | Delete
/**
[94] Fix | Delete
* Debug level to show client -> server and server -> client messages.
[95] Fix | Delete
*
[96] Fix | Delete
* @var int
[97] Fix | Delete
*/
[98] Fix | Delete
const DEBUG_SERVER = 2;
[99] Fix | Delete
[100] Fix | Delete
/**
[101] Fix | Delete
* Debug level to show connection status, client -> server and server -> client messages.
[102] Fix | Delete
*
[103] Fix | Delete
* @var int
[104] Fix | Delete
*/
[105] Fix | Delete
const DEBUG_CONNECTION = 3;
[106] Fix | Delete
[107] Fix | Delete
/**
[108] Fix | Delete
* Debug level to show all messages.
[109] Fix | Delete
*
[110] Fix | Delete
* @var int
[111] Fix | Delete
*/
[112] Fix | Delete
const DEBUG_LOWLEVEL = 4;
[113] Fix | Delete
[114] Fix | Delete
/**
[115] Fix | Delete
* Debug output level.
[116] Fix | Delete
* Options:
[117] Fix | Delete
* * self::DEBUG_OFF (`0`) No debug output, default
[118] Fix | Delete
* * self::DEBUG_CLIENT (`1`) Client commands
[119] Fix | Delete
* * self::DEBUG_SERVER (`2`) Client commands and server responses
[120] Fix | Delete
* * self::DEBUG_CONNECTION (`3`) As DEBUG_SERVER plus connection status
[121] Fix | Delete
* * self::DEBUG_LOWLEVEL (`4`) Low-level data output, all messages.
[122] Fix | Delete
*
[123] Fix | Delete
* @var int
[124] Fix | Delete
*/
[125] Fix | Delete
public $do_debug = self::DEBUG_OFF;
[126] Fix | Delete
[127] Fix | Delete
/**
[128] Fix | Delete
* How to handle debug output.
[129] Fix | Delete
* Options:
[130] Fix | Delete
* * `echo` Output plain-text as-is, appropriate for CLI
[131] Fix | Delete
* * `html` Output escaped, line breaks converted to `<br>`, appropriate for browser output
[132] Fix | Delete
* * `error_log` Output to error log as configured in php.ini
[133] Fix | Delete
* Alternatively, you can provide a callable expecting two params: a message string and the debug level:
[134] Fix | Delete
*
[135] Fix | Delete
* ```php
[136] Fix | Delete
* $smtp->Debugoutput = function($str, $level) {echo "debug level $level; message: $str";};
[137] Fix | Delete
* ```
[138] Fix | Delete
*
[139] Fix | Delete
* Alternatively, you can pass in an instance of a PSR-3 compatible logger, though only `debug`
[140] Fix | Delete
* level output is used:
[141] Fix | Delete
*
[142] Fix | Delete
* ```php
[143] Fix | Delete
* $mail->Debugoutput = new myPsr3Logger;
[144] Fix | Delete
* ```
[145] Fix | Delete
*
[146] Fix | Delete
* @var string|callable|\Psr\Log\LoggerInterface
[147] Fix | Delete
*/
[148] Fix | Delete
public $Debugoutput = 'echo';
[149] Fix | Delete
[150] Fix | Delete
/**
[151] Fix | Delete
* Whether to use VERP.
[152] Fix | Delete
*
[153] Fix | Delete
* @see https://en.wikipedia.org/wiki/Variable_envelope_return_path
[154] Fix | Delete
* @see https://www.postfix.org/VERP_README.html Info on VERP
[155] Fix | Delete
*
[156] Fix | Delete
* @var bool
[157] Fix | Delete
*/
[158] Fix | Delete
public $do_verp = false;
[159] Fix | Delete
[160] Fix | Delete
/**
[161] Fix | Delete
* Whether to use SMTPUTF8.
[162] Fix | Delete
*
[163] Fix | Delete
* @see https://www.rfc-editor.org/rfc/rfc6531
[164] Fix | Delete
*
[165] Fix | Delete
* @var bool
[166] Fix | Delete
*/
[167] Fix | Delete
public $do_smtputf8 = false;
[168] Fix | Delete
[169] Fix | Delete
/**
[170] Fix | Delete
* The timeout value for connection, in seconds.
[171] Fix | Delete
* Default of 5 minutes (300sec) is from RFC2821 section 4.5.3.2.
[172] Fix | Delete
* This needs to be quite high to function correctly with hosts using greetdelay as an anti-spam measure.
[173] Fix | Delete
*
[174] Fix | Delete
* @see https://www.rfc-editor.org/rfc/rfc2821#section-4.5.3.2
[175] Fix | Delete
*
[176] Fix | Delete
* @var int
[177] Fix | Delete
*/
[178] Fix | Delete
public $Timeout = 300;
[179] Fix | Delete
[180] Fix | Delete
/**
[181] Fix | Delete
* How long to wait for commands to complete, in seconds.
[182] Fix | Delete
* Default of 5 minutes (300sec) is from RFC2821 section 4.5.3.2.
[183] Fix | Delete
*
[184] Fix | Delete
* @var int
[185] Fix | Delete
*/
[186] Fix | Delete
public $Timelimit = 300;
[187] Fix | Delete
[188] Fix | Delete
/**
[189] Fix | Delete
* Patterns to extract an SMTP transaction id from reply to a DATA command.
[190] Fix | Delete
* The first capture group in each regex will be used as the ID.
[191] Fix | Delete
* MS ESMTP returns the message ID, which may not be correct for internal tracking.
[192] Fix | Delete
*
[193] Fix | Delete
* @var string[]
[194] Fix | Delete
*/
[195] Fix | Delete
protected $smtp_transaction_id_patterns = [
[196] Fix | Delete
'exim' => '/[\d]{3} OK id=(.*)/',
[197] Fix | Delete
'sendmail' => '/[\d]{3} 2\.0\.0 (.*) Message/',
[198] Fix | Delete
'postfix' => '/[\d]{3} 2\.0\.0 Ok: queued as (.*)/',
[199] Fix | Delete
'Microsoft_ESMTP' => '/[0-9]{3} 2\.[\d]\.0 (.*)@(?:.*) Queued mail for delivery/',
[200] Fix | Delete
'Amazon_SES' => '/[\d]{3} Ok (.*)/',
[201] Fix | Delete
'SendGrid' => '/[\d]{3} Ok: queued as (.*)/',
[202] Fix | Delete
'CampaignMonitor' => '/[\d]{3} 2\.0\.0 OK:([a-zA-Z\d]{48})/',
[203] Fix | Delete
'Haraka' => '/[\d]{3} Message Queued \((.*)\)/',
[204] Fix | Delete
'ZoneMTA' => '/[\d]{3} Message queued as (.*)/',
[205] Fix | Delete
'Mailjet' => '/[\d]{3} OK queued as (.*)/',
[206] Fix | Delete
'Gsmtp' => '/[\d]{3} 2\.0\.0 OK (.*) - gsmtp/',
[207] Fix | Delete
];
[208] Fix | Delete
[209] Fix | Delete
/**
[210] Fix | Delete
* Allowed SMTP XCLIENT attributes.
[211] Fix | Delete
* Must be allowed by the SMTP server. EHLO response is not checked.
[212] Fix | Delete
*
[213] Fix | Delete
* @see https://www.postfix.org/XCLIENT_README.html
[214] Fix | Delete
*
[215] Fix | Delete
* @var array
[216] Fix | Delete
*/
[217] Fix | Delete
public static $xclient_allowed_attributes = [
[218] Fix | Delete
'NAME', 'ADDR', 'PORT', 'PROTO', 'HELO', 'LOGIN', 'DESTADDR', 'DESTPORT'
[219] Fix | Delete
];
[220] Fix | Delete
[221] Fix | Delete
/**
[222] Fix | Delete
* The last transaction ID issued in response to a DATA command,
[223] Fix | Delete
* if one was detected.
[224] Fix | Delete
*
[225] Fix | Delete
* @var string|bool|null
[226] Fix | Delete
*/
[227] Fix | Delete
protected $last_smtp_transaction_id;
[228] Fix | Delete
[229] Fix | Delete
/**
[230] Fix | Delete
* The socket for the server connection.
[231] Fix | Delete
*
[232] Fix | Delete
* @var ?resource
[233] Fix | Delete
*/
[234] Fix | Delete
protected $smtp_conn;
[235] Fix | Delete
[236] Fix | Delete
/**
[237] Fix | Delete
* Error information, if any, for the last SMTP command.
[238] Fix | Delete
*
[239] Fix | Delete
* @var array
[240] Fix | Delete
*/
[241] Fix | Delete
protected $error = [
[242] Fix | Delete
'error' => '',
[243] Fix | Delete
'detail' => '',
[244] Fix | Delete
'smtp_code' => '',
[245] Fix | Delete
'smtp_code_ex' => '',
[246] Fix | Delete
];
[247] Fix | Delete
[248] Fix | Delete
/**
[249] Fix | Delete
* The reply the server sent to us for HELO.
[250] Fix | Delete
* If null, no HELO string has yet been received.
[251] Fix | Delete
*
[252] Fix | Delete
* @var string|null
[253] Fix | Delete
*/
[254] Fix | Delete
protected $helo_rply;
[255] Fix | Delete
[256] Fix | Delete
/**
[257] Fix | Delete
* The set of SMTP extensions sent in reply to EHLO command.
[258] Fix | Delete
* Indexes of the array are extension names.
[259] Fix | Delete
* Value at index 'HELO' or 'EHLO' (according to command that was sent)
[260] Fix | Delete
* represents the server name. In case of HELO it is the only element of the array.
[261] Fix | Delete
* Other values can be boolean TRUE or an array containing extension options.
[262] Fix | Delete
* If null, no HELO/EHLO string has yet been received.
[263] Fix | Delete
*
[264] Fix | Delete
* @var array|null
[265] Fix | Delete
*/
[266] Fix | Delete
protected $server_caps;
[267] Fix | Delete
[268] Fix | Delete
/**
[269] Fix | Delete
* The most recent reply received from the server.
[270] Fix | Delete
*
[271] Fix | Delete
* @var string
[272] Fix | Delete
*/
[273] Fix | Delete
protected $last_reply = '';
[274] Fix | Delete
[275] Fix | Delete
/**
[276] Fix | Delete
* Output debugging info via a user-selected method.
[277] Fix | Delete
*
[278] Fix | Delete
* @param string $str Debug string to output
[279] Fix | Delete
* @param int $level The debug level of this message; see DEBUG_* constants
[280] Fix | Delete
*
[281] Fix | Delete
* @see SMTP::$Debugoutput
[282] Fix | Delete
* @see SMTP::$do_debug
[283] Fix | Delete
*/
[284] Fix | Delete
protected function edebug($str, $level = 0)
[285] Fix | Delete
{
[286] Fix | Delete
if ($level > $this->do_debug) {
[287] Fix | Delete
return;
[288] Fix | Delete
}
[289] Fix | Delete
//Is this a PSR-3 logger?
[290] Fix | Delete
if ($this->Debugoutput instanceof \Psr\Log\LoggerInterface) {
[291] Fix | Delete
//Remove trailing line breaks potentially added by calls to SMTP::client_send()
[292] Fix | Delete
$this->Debugoutput->debug(rtrim($str, "\r\n"));
[293] Fix | Delete
[294] Fix | Delete
return;
[295] Fix | Delete
}
[296] Fix | Delete
//Avoid clash with built-in function names
[297] Fix | Delete
if (is_callable($this->Debugoutput) && !in_array($this->Debugoutput, ['error_log', 'html', 'echo'])) {
[298] Fix | Delete
call_user_func($this->Debugoutput, $str, $level);
[299] Fix | Delete
[300] Fix | Delete
return;
[301] Fix | Delete
}
[302] Fix | Delete
switch ($this->Debugoutput) {
[303] Fix | Delete
case 'error_log':
[304] Fix | Delete
//Don't output, just log
[305] Fix | Delete
/** @noinspection ForgottenDebugOutputInspection */
[306] Fix | Delete
error_log($str);
[307] Fix | Delete
break;
[308] Fix | Delete
case 'html':
[309] Fix | Delete
//Cleans up output a bit for a better looking, HTML-safe output
[310] Fix | Delete
echo gmdate('Y-m-d H:i:s'), ' ', htmlentities(
[311] Fix | Delete
preg_replace('/[\r\n]+/', '', $str),
[312] Fix | Delete
ENT_QUOTES,
[313] Fix | Delete
'UTF-8'
[314] Fix | Delete
), "<br>\n";
[315] Fix | Delete
break;
[316] Fix | Delete
case 'echo':
[317] Fix | Delete
default:
[318] Fix | Delete
//Normalize line breaks
[319] Fix | Delete
$str = preg_replace('/\r\n|\r/m', "\n", $str);
[320] Fix | Delete
echo gmdate('Y-m-d H:i:s'),
[321] Fix | Delete
"\t",
[322] Fix | Delete
//Trim trailing space
[323] Fix | Delete
trim(
[324] Fix | Delete
//Indent for readability, except for trailing break
[325] Fix | Delete
str_replace(
[326] Fix | Delete
"\n",
[327] Fix | Delete
"\n \t ",
[328] Fix | Delete
trim($str)
[329] Fix | Delete
)
[330] Fix | Delete
),
[331] Fix | Delete
"\n";
[332] Fix | Delete
}
[333] Fix | Delete
}
[334] Fix | Delete
[335] Fix | Delete
/**
[336] Fix | Delete
* Connect to an SMTP server.
[337] Fix | Delete
*
[338] Fix | Delete
* @param string $host SMTP server IP or host name
[339] Fix | Delete
* @param int $port The port number to connect to
[340] Fix | Delete
* @param int $timeout How long to wait for the connection to open
[341] Fix | Delete
* @param array $options An array of options for stream_context_create()
[342] Fix | Delete
*
[343] Fix | Delete
* @return bool
[344] Fix | Delete
*/
[345] Fix | Delete
public function connect($host, $port = null, $timeout = 30, $options = [])
[346] Fix | Delete
{
[347] Fix | Delete
//Clear errors to avoid confusion
[348] Fix | Delete
$this->setError('');
[349] Fix | Delete
//Make sure we are __not__ connected
[350] Fix | Delete
if ($this->connected()) {
[351] Fix | Delete
//Already connected, generate error
[352] Fix | Delete
$this->setError('Already connected to a server');
[353] Fix | Delete
[354] Fix | Delete
return false;
[355] Fix | Delete
}
[356] Fix | Delete
if (empty($port)) {
[357] Fix | Delete
$port = self::DEFAULT_PORT;
[358] Fix | Delete
}
[359] Fix | Delete
//Connect to the SMTP server
[360] Fix | Delete
$this->edebug(
[361] Fix | Delete
"Connection: opening to $host:$port, timeout=$timeout, options=" .
[362] Fix | Delete
(count($options) > 0 ? var_export($options, true) : 'array()'),
[363] Fix | Delete
self::DEBUG_CONNECTION
[364] Fix | Delete
);
[365] Fix | Delete
[366] Fix | Delete
$this->smtp_conn = $this->getSMTPConnection($host, $port, $timeout, $options);
[367] Fix | Delete
[368] Fix | Delete
if ($this->smtp_conn === false) {
[369] Fix | Delete
//Error info already set inside `getSMTPConnection()`
[370] Fix | Delete
return false;
[371] Fix | Delete
}
[372] Fix | Delete
[373] Fix | Delete
$this->edebug('Connection: opened', self::DEBUG_CONNECTION);
[374] Fix | Delete
[375] Fix | Delete
//Get any announcement
[376] Fix | Delete
$this->last_reply = $this->get_lines();
[377] Fix | Delete
$this->edebug('SERVER -> CLIENT: ' . $this->last_reply, self::DEBUG_SERVER);
[378] Fix | Delete
$responseCode = (int)substr($this->last_reply, 0, 3);
[379] Fix | Delete
if ($responseCode === 220) {
[380] Fix | Delete
return true;
[381] Fix | Delete
}
[382] Fix | Delete
//Anything other than a 220 response means something went wrong
[383] Fix | Delete
//RFC 5321 says the server will wait for us to send a QUIT in response to a 554 error
[384] Fix | Delete
//https://www.rfc-editor.org/rfc/rfc5321#section-3.1
[385] Fix | Delete
if ($responseCode === 554) {
[386] Fix | Delete
$this->quit();
[387] Fix | Delete
}
[388] Fix | Delete
//This will handle 421 responses which may not wait for a QUIT (e.g. if the server is being shut down)
[389] Fix | Delete
$this->edebug('Connection: closing due to error', self::DEBUG_CONNECTION);
[390] Fix | Delete
$this->close();
[391] Fix | Delete
return false;
[392] Fix | Delete
}
[393] Fix | Delete
[394] Fix | Delete
/**
[395] Fix | Delete
* Create connection to the SMTP server.
[396] Fix | Delete
*
[397] Fix | Delete
* @param string $host SMTP server IP or host name
[398] Fix | Delete
* @param int $port The port number to connect to
[399] Fix | Delete
* @param int $timeout How long to wait for the connection to open
[400] Fix | Delete
* @param array $options An array of options for stream_context_create()
[401] Fix | Delete
*
[402] Fix | Delete
* @return false|resource
[403] Fix | Delete
*/
[404] Fix | Delete
protected function getSMTPConnection($host, $port = null, $timeout = 30, $options = [])
[405] Fix | Delete
{
[406] Fix | Delete
static $streamok;
[407] Fix | Delete
//This is enabled by default since 5.0.0 but some providers disable it
[408] Fix | Delete
//Check this once and cache the result
[409] Fix | Delete
if (null === $streamok) {
[410] Fix | Delete
$streamok = function_exists('stream_socket_client');
[411] Fix | Delete
}
[412] Fix | Delete
[413] Fix | Delete
$errno = 0;
[414] Fix | Delete
$errstr = '';
[415] Fix | Delete
if ($streamok) {
[416] Fix | Delete
$socket_context = stream_context_create($options);
[417] Fix | Delete
set_error_handler(function () {
[418] Fix | Delete
call_user_func_array([$this, 'errorHandler'], func_get_args());
[419] Fix | Delete
});
[420] Fix | Delete
$connection = stream_socket_client(
[421] Fix | Delete
$host . ':' . $port,
[422] Fix | Delete
$errno,
[423] Fix | Delete
$errstr,
[424] Fix | Delete
$timeout,
[425] Fix | Delete
STREAM_CLIENT_CONNECT,
[426] Fix | Delete
$socket_context
[427] Fix | Delete
);
[428] Fix | Delete
} else {
[429] Fix | Delete
//Fall back to fsockopen which should work in more places, but is missing some features
[430] Fix | Delete
$this->edebug(
[431] Fix | Delete
'Connection: stream_socket_client not available, falling back to fsockopen',
[432] Fix | Delete
self::DEBUG_CONNECTION
[433] Fix | Delete
);
[434] Fix | Delete
set_error_handler(function () {
[435] Fix | Delete
call_user_func_array([$this, 'errorHandler'], func_get_args());
[436] Fix | Delete
});
[437] Fix | Delete
$connection = fsockopen(
[438] Fix | Delete
$host,
[439] Fix | Delete
$port,
[440] Fix | Delete
$errno,
[441] Fix | Delete
$errstr,
[442] Fix | Delete
$timeout
[443] Fix | Delete
);
[444] Fix | Delete
}
[445] Fix | Delete
restore_error_handler();
[446] Fix | Delete
[447] Fix | Delete
//Verify we connected properly
[448] Fix | Delete
if (!is_resource($connection)) {
[449] Fix | Delete
$this->setError(
[450] Fix | Delete
'Failed to connect to server',
[451] Fix | Delete
'',
[452] Fix | Delete
(string) $errno,
[453] Fix | Delete
$errstr
[454] Fix | Delete
);
[455] Fix | Delete
$this->edebug(
[456] Fix | Delete
'SMTP ERROR: ' . $this->error['error']
[457] Fix | Delete
. ": $errstr ($errno)",
[458] Fix | Delete
self::DEBUG_CLIENT
[459] Fix | Delete
);
[460] Fix | Delete
[461] Fix | Delete
return false;
[462] Fix | Delete
}
[463] Fix | Delete
[464] Fix | Delete
//SMTP server can take longer to respond, give longer timeout for first read
[465] Fix | Delete
//Windows does not have support for this timeout function
[466] Fix | Delete
if (strpos(PHP_OS, 'WIN') !== 0) {
[467] Fix | Delete
$max = (int)ini_get('max_execution_time');
[468] Fix | Delete
//Don't bother if unlimited, or if set_time_limit is disabled
[469] Fix | Delete
if (0 !== $max && $timeout > $max && strpos(ini_get('disable_functions'), 'set_time_limit') === false) {
[470] Fix | Delete
@set_time_limit($timeout);
[471] Fix | Delete
}
[472] Fix | Delete
stream_set_timeout($connection, $timeout, 0);
[473] Fix | Delete
}
[474] Fix | Delete
[475] Fix | Delete
return $connection;
[476] Fix | Delete
}
[477] Fix | Delete
[478] Fix | Delete
/**
[479] Fix | Delete
* Initiate a TLS (encrypted) session.
[480] Fix | Delete
*
[481] Fix | Delete
* @return bool
[482] Fix | Delete
*/
[483] Fix | Delete
public function startTLS()
[484] Fix | Delete
{
[485] Fix | Delete
if (!$this->sendCommand('STARTTLS', 'STARTTLS', 220)) {
[486] Fix | Delete
return false;
[487] Fix | Delete
}
[488] Fix | Delete
[489] Fix | Delete
//Allow the best TLS version(s) we can
[490] Fix | Delete
$crypto_method = STREAM_CRYPTO_METHOD_TLS_CLIENT;
[491] Fix | Delete
[492] Fix | Delete
//PHP 5.6.7 dropped inclusion of TLS 1.1 and 1.2 in STREAM_CRYPTO_METHOD_TLS_CLIENT
[493] Fix | Delete
//so add them back in manually if we can
[494] Fix | Delete
if (defined('STREAM_CRYPTO_METHOD_TLSv1_2_CLIENT')) {
[495] Fix | Delete
$crypto_method |= STREAM_CRYPTO_METHOD_TLSv1_2_CLIENT;
[496] Fix | Delete
$crypto_method |= STREAM_CRYPTO_METHOD_TLSv1_1_CLIENT;
[497] Fix | Delete
}
[498] Fix | Delete
[499] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function