- Moves mailer logic into Mailer Task class
This commit is contained in:
@ -21,7 +21,7 @@ class SendingQueue {
|
|||||||
|
|
||||||
function __construct($timer = false) {
|
function __construct($timer = false) {
|
||||||
$this->mailer_task = new MailerTask();
|
$this->mailer_task = new MailerTask();
|
||||||
$this->newsletter_task = new NewsletterTask();
|
$this->newsletter_task = new NewsletterTask($this->mailer_task);
|
||||||
$this->timer = ($timer) ? $timer : microtime(true);
|
$this->timer = ($timer) ? $timer : microtime(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -40,8 +40,6 @@ class SendingQueue {
|
|||||||
}
|
}
|
||||||
// get subscribers
|
// get subscribers
|
||||||
$queue->subscribers = SubscribersTask::get($queue->subscribers);
|
$queue->subscribers = SubscribersTask::get($queue->subscribers);
|
||||||
// configure mailer with newsletter data (from/reply-to)
|
|
||||||
$mailer = $this->mailer_task->configureMailer($newsletter);
|
|
||||||
foreach(array_chunk($queue->subscribers['to_process'], self::BATCH_SIZE)
|
foreach(array_chunk($queue->subscribers['to_process'], self::BATCH_SIZE)
|
||||||
as $subscribers_to_process_ids
|
as $subscribers_to_process_ids
|
||||||
) {
|
) {
|
||||||
@ -62,7 +60,6 @@ class SendingQueue {
|
|||||||
}
|
}
|
||||||
$queue = $this->processQueue(
|
$queue = $this->processQueue(
|
||||||
$queue,
|
$queue,
|
||||||
$mailer,
|
|
||||||
$newsletter,
|
$newsletter,
|
||||||
$found_subscribers
|
$found_subscribers
|
||||||
);
|
);
|
||||||
@ -70,7 +67,7 @@ class SendingQueue {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function processQueue($queue, $mailer, $newsletter, $subscribers) {
|
function processQueue($queue, $newsletter, $subscribers) {
|
||||||
// determine if processing is done in bulk or individually
|
// determine if processing is done in bulk or individually
|
||||||
$processing_method = $this->mailer_task->getProcessingMethod();
|
$processing_method = $this->mailer_task->getProcessingMethod();
|
||||||
$prepared_newsletters = array();
|
$prepared_newsletters = array();
|
||||||
@ -89,7 +86,6 @@ class SendingQueue {
|
|||||||
}
|
}
|
||||||
// format subscriber name/address according to mailer settings
|
// format subscriber name/address according to mailer settings
|
||||||
$prepared_subscribers[] = $this->mailer_task->prepareSubscriberForSending(
|
$prepared_subscribers[] = $this->mailer_task->prepareSubscriberForSending(
|
||||||
$mailer,
|
|
||||||
$subscriber
|
$subscriber
|
||||||
);
|
);
|
||||||
$prepared_subscribers_ids[] = $subscriber['id'];
|
$prepared_subscribers_ids[] = $subscriber['id'];
|
||||||
@ -102,7 +98,7 @@ class SendingQueue {
|
|||||||
if($processing_method === 'individual') {
|
if($processing_method === 'individual') {
|
||||||
$queue = $this->sendNewsletters(
|
$queue = $this->sendNewsletters(
|
||||||
$queue,
|
$queue,
|
||||||
$mailer,
|
$newsletter,
|
||||||
$prepared_subscribers_ids,
|
$prepared_subscribers_ids,
|
||||||
$prepared_newsletters[0],
|
$prepared_newsletters[0],
|
||||||
$prepared_subscribers[0],
|
$prepared_subscribers[0],
|
||||||
@ -116,7 +112,7 @@ class SendingQueue {
|
|||||||
if($processing_method === 'bulk') {
|
if($processing_method === 'bulk') {
|
||||||
$queue = $this->sendNewsletters(
|
$queue = $this->sendNewsletters(
|
||||||
$queue,
|
$queue,
|
||||||
$mailer,
|
$newsletter,
|
||||||
$prepared_subscribers_ids,
|
$prepared_subscribers_ids,
|
||||||
$prepared_newsletters,
|
$prepared_newsletters,
|
||||||
$prepared_subscribers,
|
$prepared_subscribers,
|
||||||
@ -127,24 +123,25 @@ class SendingQueue {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function sendNewsletters(
|
function sendNewsletters(
|
||||||
$queue, $mailer, $subscribers_ids, $newsletters, $subscribers, $statistics
|
$queue, $newsletter_object, $prepared_subscribers_ids, $prepared_newsletters,
|
||||||
|
$prepared_subscribers, $statistics
|
||||||
) {
|
) {
|
||||||
// send newsletter
|
// send newsletter
|
||||||
$send_result = $this->mailer_task->send(
|
$send_result = $this->mailer_task->send(
|
||||||
$mailer,
|
$newsletter_object,
|
||||||
$newsletters,
|
$prepared_newsletters,
|
||||||
$subscribers
|
$prepared_subscribers
|
||||||
);
|
);
|
||||||
if(!$send_result) {
|
if(!$send_result) {
|
||||||
// update failed/to process list
|
// update failed/to process list
|
||||||
$queue->subscribers = SubscribersTask::updateFailedList(
|
$queue->subscribers = SubscribersTask::updateFailedList(
|
||||||
$subscribers_ids,
|
$prepared_subscribers_ids,
|
||||||
$queue->subscribers
|
$queue->subscribers
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
// update processed/to process list
|
// update processed/to process list
|
||||||
$queue->subscribers = SubscribersTask::updateProcessedList(
|
$queue->subscribers = SubscribersTask::updateProcessedList(
|
||||||
$subscribers_ids,
|
$prepared_subscribers_ids,
|
||||||
$queue->subscribers
|
$queue->subscribers
|
||||||
);
|
);
|
||||||
// log statistics
|
// log statistics
|
||||||
@ -154,7 +151,7 @@ class SendingQueue {
|
|||||||
$subscribers_to_process_count = count($queue->subscribers['to_process']);
|
$subscribers_to_process_count = count($queue->subscribers['to_process']);
|
||||||
}
|
}
|
||||||
$queue = $this->updateQueue($queue);
|
$queue = $this->updateQueue($queue);
|
||||||
if ($subscribers_to_process_count) {
|
if($subscribers_to_process_count) {
|
||||||
$this->mailer_task->checkSendingLimit();
|
$this->mailer_task->checkSendingLimit();
|
||||||
}
|
}
|
||||||
CronHelper::checkExecutionTimer($this->timer);
|
CronHelper::checkExecutionTimer($this->timer);
|
||||||
|
@ -13,9 +13,10 @@ class Mailer {
|
|||||||
function __construct() {
|
function __construct() {
|
||||||
$this->mta_config = $this->getMailerConfig();
|
$this->mta_config = $this->getMailerConfig();
|
||||||
$this->mta_log = $this->getMailerLog();
|
$this->mta_log = $this->getMailerLog();
|
||||||
|
$this->mailer = $this->configureMailer();
|
||||||
}
|
}
|
||||||
|
|
||||||
function configureMailer(array $newsletter) {
|
function configureMailer(array $newsletter = null, $mailer = false) {
|
||||||
$sender['address'] = (!empty($newsletter['sender_address'])) ?
|
$sender['address'] = (!empty($newsletter['sender_address'])) ?
|
||||||
$newsletter['sender_address'] :
|
$newsletter['sender_address'] :
|
||||||
false;
|
false;
|
||||||
@ -34,7 +35,13 @@ class Mailer {
|
|||||||
if(!$reply_to['address']) {
|
if(!$reply_to['address']) {
|
||||||
$reply_to = false;
|
$reply_to = false;
|
||||||
}
|
}
|
||||||
$mailer = new MailerFactory($method = false, $sender, $reply_to);
|
if (!$mailer) {
|
||||||
|
$mailer = new MailerFactory($method = false, $sender, $reply_to);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$mailer->mailer_instance->sender = $mailer->getSender($sender);
|
||||||
|
$mailer->mailer_instance->reply_to = $mailer->getReplyTo($reply_to);
|
||||||
|
}
|
||||||
return $mailer;
|
return $mailer;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -69,16 +76,15 @@ class Mailer {
|
|||||||
'individual';
|
'individual';
|
||||||
}
|
}
|
||||||
|
|
||||||
function prepareSubscriberForSending($mailer, $subscriber) {
|
function prepareSubscriberForSending(array $subscriber) {
|
||||||
return ($mailer instanceof \MailPoet\Mailer\Mailer) ?
|
return $this->mailer->transformSubscriber($subscriber);
|
||||||
$mailer->transformSubscriber($subscriber) :
|
|
||||||
false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function send($mailer, $newsletter, $subscriber) {
|
function send(array $newsletter_object, $prepared_newsletters,
|
||||||
return ($mailer instanceof \MailPoet\Mailer\Mailer) ?
|
$prepared_subscribers
|
||||||
$mailer->mailer_instance->send($newsletter, $subscriber) :
|
) {
|
||||||
false;
|
$mailer = $this->configureMailer($newsletter_object, $this->mailer);
|
||||||
|
return $mailer->mailer_instance->send($prepared_newsletters, $prepared_subscribers);
|
||||||
}
|
}
|
||||||
|
|
||||||
function checkSendingLimit() {
|
function checkSendingLimit() {
|
||||||
|
Reference in New Issue
Block a user