|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* @link http://www.yiiframework.com/
|
|
|
|
* @copyright Copyright (c) 2008 Yii Software LLC
|
|
|
|
* @license http://www.yiiframework.com/license/
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace yii\mail;
|
|
|
|
|
|
|
|
use yii\base\InvalidParamException;
|
|
|
|
use yii\base\Object;
|
|
|
|
use yii\helpers\FileHelper;
|
|
|
|
use Yii;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* BaseMessage represent the single email message.
|
|
|
|
* It functionality depends on application component 'email',
|
|
|
|
* which should provide the actual email sending functionality as well as
|
|
|
|
* default message configuration.
|
|
|
|
*
|
|
|
|
* @see BaseMailer
|
|
|
|
*
|
|
|
|
* @property \yii\mail\BaseMailer $mailer mailer component instance. This property is read-only.
|
|
|
|
*
|
|
|
|
* @author Paul Klimov <klimov.paul@gmail.com>
|
|
|
|
* @since 2.0
|
|
|
|
*/
|
|
|
|
abstract class BaseMessage extends Object implements MessageInterface
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @return \yii\mail\BaseMailer mailer component instance.
|
|
|
|
*/
|
|
|
|
public function getMailer()
|
|
|
|
{
|
|
|
|
return Yii::$app->getComponent('mail');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @inheritdoc
|
|
|
|
*/
|
|
|
|
public function send()
|
|
|
|
{
|
|
|
|
return $this->getMailer()->send($this);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @inheritdoc
|
|
|
|
*/
|
|
|
|
public function renderHtml($view, $params = [])
|
|
|
|
{
|
|
|
|
$this->html($this->getMailer()->render($view, $params, $this->getMailer()->htmlLayout));
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @inheritdoc
|
|
|
|
*/
|
|
|
|
public function renderText($view, $params = [])
|
|
|
|
{
|
|
|
|
$this->text($this->getMailer()->render($view, $params, $this->getMailer()->textLayout));
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @inheritdoc
|
|
|
|
*/
|
|
|
|
public function body($view, $params = [])
|
|
|
|
{
|
|
|
|
if (is_array($view)) {
|
|
|
|
$this->renderHtml($view['html'], $params);
|
|
|
|
$this->renderText($view['text'], $params);
|
|
|
|
} else {
|
|
|
|
$html = $this->getMailer()->render($view, $params, $this->getMailer()->htmlLayout);
|
|
|
|
$this->html($html);
|
|
|
|
$this->text(strip_tags($html));
|
|
|
|
}
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* PHP magic method that returns the string representation of this object.
|
|
|
|
* @return string the string representation of this object.
|
|
|
|
*/
|
|
|
|
public function __toString()
|
|
|
|
{
|
|
|
|
// __toString cannot throw exception
|
|
|
|
// use trigger_error to bypass this limitation
|
|
|
|
try {
|
|
|
|
return $this->toString();
|
|
|
|
} catch (\Exception $e) {
|
|
|
|
trigger_error($e->getMessage());
|
|
|
|
return '';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|