init
This commit is contained in:
157
vendor/yiisoft/yii2-debug/panels/MailPanel.php
vendored
Normal file
157
vendor/yiisoft/yii2-debug/panels/MailPanel.php
vendored
Normal file
@@ -0,0 +1,157 @@
|
||||
<?php
|
||||
/**
|
||||
* @link http://www.yiiframework.com/
|
||||
* @copyright Copyright (c) 2008 Yii Software LLC
|
||||
* @license http://www.yiiframework.com/license/
|
||||
*/
|
||||
|
||||
namespace yii\debug\panels;
|
||||
|
||||
use Yii;
|
||||
use yii\base\Event;
|
||||
use yii\debug\models\search\Mail;
|
||||
use yii\debug\Panel;
|
||||
use yii\mail\BaseMailer;
|
||||
use yii\helpers\FileHelper;
|
||||
use yii\mail\MessageInterface;
|
||||
|
||||
/**
|
||||
* Debugger panel that collects and displays the generated emails.
|
||||
*
|
||||
* @property array $messages Messages. This property is read-only.
|
||||
*
|
||||
* @author Mark Jebri <mark.github@yandex.ru>
|
||||
* @since 2.0
|
||||
*/
|
||||
class MailPanel extends Panel
|
||||
{
|
||||
/**
|
||||
* @var string path where all emails will be saved. should be an alias.
|
||||
*/
|
||||
public $mailPath = '@runtime/debug/mail';
|
||||
|
||||
/**
|
||||
* @var array current request sent messages
|
||||
*/
|
||||
private $_messages = [];
|
||||
|
||||
|
||||
/**
|
||||
* @inheritdoc
|
||||
*/
|
||||
public function init()
|
||||
{
|
||||
parent::init();
|
||||
Event::on(BaseMailer::className(), BaseMailer::EVENT_AFTER_SEND, function ($event) {
|
||||
|
||||
/* @var $message MessageInterface */
|
||||
$message = $event->message;
|
||||
$messageData = [
|
||||
'isSuccessful' => $event->isSuccessful,
|
||||
'from' => $this->convertParams($message->getFrom()),
|
||||
'to' => $this->convertParams($message->getTo()),
|
||||
'reply' => $this->convertParams($message->getReplyTo()),
|
||||
'cc' => $this->convertParams($message->getCc()),
|
||||
'bcc' => $this->convertParams($message->getBcc()),
|
||||
'subject' => $message->getSubject(),
|
||||
'charset' => $message->getCharset(),
|
||||
];
|
||||
|
||||
// add more information when message is a SwiftMailer message
|
||||
if ($message instanceof \yii\swiftmailer\Message) {
|
||||
/* @var $swiftMessage \Swift_Message */
|
||||
$swiftMessage = $message->getSwiftMessage();
|
||||
|
||||
$body = $swiftMessage->getBody();
|
||||
if (empty($body)) {
|
||||
$parts = $swiftMessage->getChildren();
|
||||
foreach ($parts as $part) {
|
||||
if (!($part instanceof \Swift_Mime_Attachment)) {
|
||||
/* @var $part \Swift_Mime_MimePart */
|
||||
if ($part->getContentType() === 'text/plain') {
|
||||
$messageData['charset'] = $part->getCharset();
|
||||
$body = $part->getBody();
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
$messageData['body'] = $body;
|
||||
$messageData['time'] = $swiftMessage->getDate();
|
||||
$messageData['headers'] = $swiftMessage->getHeaders();
|
||||
|
||||
}
|
||||
|
||||
// store message as file
|
||||
$fileName = $event->sender->generateMessageFileName();
|
||||
FileHelper::createDirectory(Yii::getAlias($this->mailPath));
|
||||
file_put_contents(Yii::getAlias($this->mailPath) . '/' . $fileName, $message->toString());
|
||||
$messageData['file'] = $fileName;
|
||||
|
||||
$this->_messages[] = $messageData;
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* @inheritdoc
|
||||
*/
|
||||
public function getName()
|
||||
{
|
||||
return 'Mail';
|
||||
}
|
||||
|
||||
/**
|
||||
* @inheritdoc
|
||||
*/
|
||||
public function getSummary()
|
||||
{
|
||||
return Yii::$app->view->render('panels/mail/summary', ['panel' => $this, 'mailCount' => count($this->data)]);
|
||||
}
|
||||
|
||||
/**
|
||||
* @inheritdoc
|
||||
*/
|
||||
public function getDetail()
|
||||
{
|
||||
$searchModel = new Mail();
|
||||
$dataProvider = $searchModel->search(Yii::$app->request->get(), $this->data);
|
||||
|
||||
return Yii::$app->view->render('panels/mail/detail', [
|
||||
'panel' => $this,
|
||||
'dataProvider' => $dataProvider,
|
||||
'searchModel' => $searchModel
|
||||
]);
|
||||
}
|
||||
|
||||
/**
|
||||
* @inheritdoc
|
||||
*/
|
||||
public function save()
|
||||
{
|
||||
return $this->getMessages();
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns info about messages of current request. Each element is array holding
|
||||
* message info, such as: time, reply, bc, cc, from, to and other.
|
||||
* @return array messages
|
||||
*/
|
||||
public function getMessages()
|
||||
{
|
||||
return $this->_messages;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param mixed $attr
|
||||
* @return string
|
||||
*/
|
||||
private function convertParams($attr)
|
||||
{
|
||||
if (is_array($attr)) {
|
||||
$attr = implode(', ', array_keys($attr));
|
||||
}
|
||||
|
||||
return $attr;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user