mirror of
https://github.com/kamilwylegala/cakephp2-php8.git
synced 2024-12-24 14:37:25 +00:00
7cfa0116f4
This statement does not serve a purpose anymore. In a long forgotten world it indicated the main version number of PHP which the code in the file was compatible to. http://pear.php.net/manual/en/standards.sample.php But since PHP 5.1 and later this is only marginally true. Thus I propose to remove it from CakePHP.
78 lines
2.6 KiB
PHP
78 lines
2.6 KiB
PHP
<?php
|
|
/**
|
|
* Send mail using mail() function
|
|
*
|
|
* CakePHP(tm) : Rapid Development Framework (http://cakephp.org)
|
|
* Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
|
|
*
|
|
* Licensed under The MIT License
|
|
* For full copyright and license information, please see the LICENSE.txt
|
|
* Redistributions of files must retain the above copyright notice.
|
|
*
|
|
* @copyright Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
|
|
* @link http://cakephp.org CakePHP(tm) Project
|
|
* @package Cake.Network.Email
|
|
* @since CakePHP(tm) v 2.0.0
|
|
* @license http://www.opensource.org/licenses/mit-license.php MIT License
|
|
*/
|
|
|
|
/**
|
|
* Send mail using mail() function
|
|
*
|
|
* @package Cake.Network.Email
|
|
*/
|
|
class MailTransport extends AbstractTransport {
|
|
|
|
/**
|
|
* Send mail
|
|
*
|
|
* @param CakeEmail $email CakeEmail
|
|
* @return array
|
|
* @throws SocketException When mail cannot be sent.
|
|
*/
|
|
public function send(CakeEmail $email) {
|
|
$eol = PHP_EOL;
|
|
if (isset($this->_config['eol'])) {
|
|
$eol = $this->_config['eol'];
|
|
}
|
|
$headers = $email->getHeaders(array('from', 'sender', 'replyTo', 'readReceipt', 'returnPath', 'to', 'cc', 'bcc'));
|
|
$to = $headers['To'];
|
|
unset($headers['To']);
|
|
foreach ($headers as $key => $header) {
|
|
$headers[$key] = str_replace(array("\r", "\n"), '', $header);
|
|
}
|
|
$headers = $this->_headersToString($headers, $eol);
|
|
$subject = str_replace(array("\r", "\n"), '', $email->subject());
|
|
$to = str_replace(array("\r", "\n"), '', $to);
|
|
|
|
$message = implode($eol, $email->message());
|
|
|
|
$params = isset($this->_config['additionalParameters']) ? $this->_config['additionalParameters'] : null;
|
|
$this->_mail($to, $subject, $message, $headers, $params);
|
|
return array('headers' => $headers, 'message' => $message);
|
|
}
|
|
|
|
/**
|
|
* Wraps internal function mail() and throws exception instead of errors if anything goes wrong
|
|
*
|
|
* @param string $to email's recipient
|
|
* @param string $subject email's subject
|
|
* @param string $message email's body
|
|
* @param string $headers email's custom headers
|
|
* @param string $params additional params for sending email, will be ignored when in safe_mode
|
|
* @throws SocketException if mail could not be sent
|
|
* @return void
|
|
*/
|
|
protected function _mail($to, $subject, $message, $headers, $params = null) {
|
|
if (ini_get('safe_mode')) {
|
|
//@codingStandardsIgnoreStart
|
|
if (!@mail($to, $subject, $message, $headers)) {
|
|
throw new SocketException(__d('cake_dev', 'Could not send email.'));
|
|
}
|
|
} elseif (!@mail($to, $subject, $message, $headers, $params)) {
|
|
//@codingStandardsIgnoreEnd
|
|
throw new SocketException(__d('cake_dev', 'Could not send email.'));
|
|
}
|
|
}
|
|
|
|
}
|