1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
<?php
/**
* BEdita, API-first content management framework
* Copyright 2017 ChannelWeb Srl, Chialab Srl
*
* This file is part of BEdita: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published
* by the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* See LICENSE.LGPL or <http://gnu.org/licenses/lgpl-3.0.html> for more details.
*/
namespace BEdita\Core\Mailer;
use Cake\Mailer\Email as CakeEmail;
/**
* Email class to send serialized emails.
*
* This class extends the CakePHP's core {@see Cake\Mailer\Email} class by adding a {@see self::sendRaw()}
* method to send raw emails, after the object has been unserialized.
*
* @since 4.0.0
*/
class Email extends CakeEmail
{
/**
* Send a raw email.
*
* This method assumes that `_message`, `_textMessage` and `_htmlMessage` private attributes
* have already been set somehow, for instance after calling `createFromArray()`.
*
* @return array
*/
public function sendRaw()
{
if (empty($this->_from)) {
throw new \BadMethodCallException('From is not specified.');
}
if (empty($this->_to) && empty($this->_cc) && empty($this->_bcc)) {
throw new \BadMethodCallException('You need specify one destination on to, cc or bcc.');
}
$transport = $this->getTransport();
if (!$transport) {
$msg = 'Cannot send email, transport was not defined. Did you call transport() or define ' .
'a transport in the set profile?';
throw new \BadMethodCallException($msg);
}
$contents = $transport->send($this);
$this->_logDelivery($contents);
return $contents;
}
/**
* Get boundary used by a mail.
*
* @param \Cake\Mailer\Email $email Email instance.
* @return string|null
*/
public static function getBoundary(CakeEmail $email)
{
return $email->_boundary;
}
}