- Moves mailer logic into Mailer Task class

This commit is contained in:
Vlad
2016-06-21 10:14:19 -04:00
parent efc9bac760
commit e5f3fabcda
2 changed files with 28 additions and 25 deletions

View File

@ -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);

View File

@ -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() {