forked from nterms/yii2-mailqueue
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMailQueue.php
123 lines (105 loc) · 3.17 KB
/
MailQueue.php
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
<?php
/**
* MailQueue.php
* @author Saranga Abeykoon http://nterms.com
*/
namespace nterms\mailqueue;
use Yii;
use yii\swiftmailer\Mailer;
use nterms\mailqueue\Message;
use nterms\mailqueue\models\Queue;
/**
* MailQueue is a sub class of [yii\switmailer\Mailer](https://github.com/yiisoft/yii2-swiftmailer/blob/master/Mailer.php)
* which intends to replace it.
*
* Configuration is the same as in `yii\switmailer\Mailer` with some additional properties to control the mail queue
*
* ~~~
* 'components' => [
* ...
* 'mailqueue' => [
* 'class' => 'nterms\mailqueue\MailQueue',
* 'table' => '{{%mail_queue}}',
* 'mailsPerRound' => 10,
* 'maxAttempts' => 3,
* 'transport' => [
* 'class' => 'Swift_SmtpTransport',
* 'host' => 'localhost',
* 'username' => 'username',
* 'password' => 'password',
* 'port' => '587',
* 'encryption' => 'tls',
* ],
* ],
* ...
* ],
* ~~~
*
* @see http://www.yiiframework.com/doc-2.0/yii-swiftmailer-mailer.html
* @see http://www.yiiframework.com/doc-2.0/ext-swiftmailer-index.html
*
* This extension replaces `yii\switmailer\Message` with `nterms\mailqueue\Message'
* to enable queuing right from the message.
*
*/
class MailQueue extends Mailer
{
const NAME = 'mailqueue';
/**
* @var string message default class name.
*/
public $messageClass = 'nterms\mailqueue\Message';
/**
* @var string the name of the database table to store the mail queue.
*/
public $table = '{{%mail_queue}}';
/**
* @var integer the default value for the number of mails to be sent out per processing round.
*/
public $mailsPerRound = 10;
/**
* @var integer maximum number of attempts to try sending an email out.
*/
public $maxAttempts = 3;
/**
* @var string queue item class name
*/
public $itemClass = 'nterms\mailqueue\models\Queue';
/**
* Initializes the MailQueue component.
*/
public function init()
{
parent::init();
$this->messageConfig = array_merge(['queueItemClass' => $this->itemClass], $this->messageConfig);
}
/**
* Sends out the messages in email queue and update the database.
*
* @return boolean true if all messages are successfully sent out
*/
public function process()
{
if (Yii::$app->db->getTableSchema($this->table) == null) {
throw new \yii\base\InvalidConfigException('"' . $this->table . '" not found in database. Make sure the db migration is properly done and the table is created.');
}
$success = true;
$itemClass = $this->itemClass;
$items = $itemClass::find()->where(['and', ['sent_time' => NULL], ['<', 'attempts', $this->maxAttempts], ['<=', 'time_to_send', date('Y-m-d H:i:s')]])->orderBy(['created_at' => SORT_ASC])->limit($this->mailsPerRound);
foreach ($items->each() as $item) {
if ($message = $item->toMessage()) {
$attributes = ['attempts', 'last_attempt_time'];
if ($this->send($message)) {
$item->sent_time = new \yii\db\Expression('NOW()');
$attributes[] = 'sent_time';
} else {
$success = false;
}
$item->attempts++;
$item->last_attempt_time = new \yii\db\Expression('NOW()');
$item->updateAttributes($attributes);
}
}
return $success;
}
}