2017-04-21 01:41:43 +03:00
|
|
|
<?php
|
2019-06-07 02:16:13 +03:00
|
|
|
declare(strict_types=1);
|
|
|
|
|
2017-04-24 19:22:24 +03:00
|
|
|
namespace common\emails;
|
2017-04-21 01:41:43 +03:00
|
|
|
|
|
|
|
use Yii;
|
|
|
|
use yii\base\InvalidConfigException;
|
|
|
|
use yii\mail\MailerInterface;
|
|
|
|
use yii\mail\MessageInterface;
|
|
|
|
|
|
|
|
abstract class Template {
|
|
|
|
|
2024-12-02 15:10:55 +05:00
|
|
|
public function __construct(
|
|
|
|
private readonly MailerInterface $mailer,
|
|
|
|
) {
|
2017-04-21 01:41:43 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
abstract public function getSubject(): string;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return array|string
|
|
|
|
* @throws InvalidConfigException
|
|
|
|
*/
|
2024-12-02 15:10:55 +05:00
|
|
|
public function getFrom(): array|string {
|
2019-06-16 23:59:19 +03:00
|
|
|
$fromEmail = Yii::$app->params['fromEmail'] ?? '';
|
2017-04-21 01:41:43 +03:00
|
|
|
if (!$fromEmail) {
|
|
|
|
throw new InvalidConfigException('Please specify fromEmail app in app params');
|
|
|
|
}
|
|
|
|
|
|
|
|
return [$fromEmail => 'Ely.by Accounts'];
|
|
|
|
}
|
|
|
|
|
2024-12-02 15:10:55 +05:00
|
|
|
/**
|
|
|
|
* @return array<string, mixed>
|
|
|
|
*/
|
2017-04-21 01:41:43 +03:00
|
|
|
public function getParams(): array {
|
|
|
|
return [];
|
|
|
|
}
|
|
|
|
|
2019-06-16 23:59:19 +03:00
|
|
|
/**
|
2024-12-02 15:10:55 +05:00
|
|
|
* @param array|string $to see \yii\mail\MessageInterface::setTo to know the format.
|
2019-06-16 23:59:19 +03:00
|
|
|
*
|
|
|
|
* @throws \common\emails\exceptions\CannotSendEmailException
|
|
|
|
*/
|
2024-12-02 15:10:55 +05:00
|
|
|
public function send(array|string $to): void {
|
2019-06-16 23:59:19 +03:00
|
|
|
if (!$this->createMessage($to)->send()) {
|
|
|
|
throw new exceptions\CannotSendEmailException();
|
2017-04-21 01:41:43 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2024-12-02 15:10:55 +05:00
|
|
|
* @return string|array{
|
|
|
|
* html?: string,
|
|
|
|
* text?: string,
|
|
|
|
* }
|
2017-04-21 01:41:43 +03:00
|
|
|
*/
|
2024-12-02 15:10:55 +05:00
|
|
|
abstract protected function getView(): string|array;
|
2017-04-21 01:41:43 +03:00
|
|
|
|
2019-06-16 23:59:19 +03:00
|
|
|
final protected function getMailer(): MailerInterface {
|
|
|
|
return $this->mailer;
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function createMessage($for): MessageInterface {
|
2017-04-21 01:41:43 +03:00
|
|
|
return $this->getMailer()
|
|
|
|
->compose($this->getView(), $this->getParams())
|
2019-06-16 23:59:19 +03:00
|
|
|
->setTo($for)
|
2017-04-21 01:41:43 +03:00
|
|
|
->setFrom($this->getFrom())
|
|
|
|
->setSubject($this->getSubject());
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|