updated sending queue endpoint + react (pause/resume/send)

This commit is contained in:
Jonathan Labreuille
2016-08-09 14:23:41 +02:00
parent 4950e47297
commit 12b46736c5
4 changed files with 144 additions and 141 deletions

View File

@ -8,7 +8,9 @@ const _QueueMixin = {
MailPoet.Ajax.post({ MailPoet.Ajax.post({
endpoint: 'sendingQueue', endpoint: 'sendingQueue',
action: 'pause', action: 'pause',
data: newsletter.id data: {
id: newsletter.id
}
}).done(function() { }).done(function() {
jQuery('#resume_'+newsletter.id).show(); jQuery('#resume_'+newsletter.id).show();
jQuery('#pause_'+newsletter.id).hide(); jQuery('#pause_'+newsletter.id).hide();
@ -18,7 +20,9 @@ const _QueueMixin = {
MailPoet.Ajax.post({ MailPoet.Ajax.post({
endpoint: 'sendingQueue', endpoint: 'sendingQueue',
action: 'resume', action: 'resume',
data: newsletter.id data: {
id: newsletter.id
}
}).done(function() { }).done(function() {
jQuery('#pause_'+newsletter.id).show(); jQuery('#pause_'+newsletter.id).show();
jQuery('#resume_'+newsletter.id).hide(); jQuery('#resume_'+newsletter.id).hide();

View File

@ -101,27 +101,31 @@ define(
return MailPoet.Ajax.post({ return MailPoet.Ajax.post({
endpoint: 'sendingQueue', endpoint: 'sendingQueue',
action: 'add', action: 'add',
data: _.extend({}, this.state.item, { data: {
newsletter_id: this.props.params.id, id: this.props.params.id
}), }
}); });
} else { } else {
return response; return response;
} }
}).done((response) => { }).done((response) => {
this.setState({ loading: false }); this.setState({ loading: false });
// redirect to listing based on newsletter type
if(response.result === true) { this.context.router.push(`/${ this.state.item.type || '' }`);
this.context.router.push(`/${ this.state.item.type || '' }`); // display success message depending on newsletter type
MailPoet.Notice.success(response.data.message); if (this.state.item.type === 'welcome') {
MailPoet.Notice.success(MailPoet.I18n.t('welcomeEmailActivated'));
} else if (this.state.item.type === 'notification') {
MailPoet.Notice.success(MailPoet.I18n.t('postNotificationActivated'));
} else { } else {
if(response.errors) { MailPoet.Notice.success(MailPoet.I18n.t('newsletterBeingSent'));
MailPoet.Notice.error(response.errors); }
} else { }).fail((response) => {
MailPoet.Notice.error( if (response.errors.length > 0) {
MailPoet.I18n.t('newsletterSendingError').replace("%$1s", '?page=mailpoet-settings') MailPoet.Notice.error(
); response.errors.map(function(error) { return error.message; }),
} { scroll: true }
);
} }
}); });
} }

View File

@ -1,5 +1,7 @@
<?php <?php
namespace MailPoet\API\Endpoints; namespace MailPoet\API\Endpoints;
use MailPoet\API\Endpoint as APIEndpoint;
use MailPoet\API\Error as APIError;
use MailPoet\Mailer\Mailer; use MailPoet\Mailer\Mailer;
use MailPoet\Models\Newsletter; use MailPoet\Models\Newsletter;
@ -14,29 +16,30 @@ use MailPoet\Util\Helpers;
if(!defined('ABSPATH')) exit; if(!defined('ABSPATH')) exit;
class SendingQueue { class SendingQueue extends APIEndpoint {
function add($data) { function add($data = array()) {
$id = (isset($data['id']) ? (int)$data['id'] : null);
// check that the newsletter exists
$newsletter = Newsletter::filter('filterWithOptions')
->findOne($data['id']);
if($newsletter === false) {
return $this->errorResponse(array(
APIError::NOT_FOUND => __('This newsletter does not exist.')
));
}
// check that the sending method has been configured properly // check that the sending method has been configured properly
try { try {
new Mailer(false); new Mailer(false);
} catch(\Exception $e) { } catch(\Exception $e) {
return array( return $this->errorResponse(array(
'result' => false, $e->getCode() => $e->getMessage()
'errors' => array($e->getMessage()) ));
);
}
// check that the newsletter exists
$newsletter = Newsletter::filter('filterWithOptions')
->findOne($data['newsletter_id']);
if($newsletter === false) {
return array(
'result' => false,
'errors' => array(__('This newsletter does not exist'))
);
} }
// Automated newsletters (welcome & post notification)
if($newsletter->type === Newsletter::TYPE_WELCOME || if($newsletter->type === Newsletter::TYPE_WELCOME ||
$newsletter->type === Newsletter::TYPE_NOTIFICATION $newsletter->type === Newsletter::TYPE_NOTIFICATION
) { ) {
@ -45,133 +48,127 @@ class SendingQueue {
$errors = $result->getErrors(); $errors = $result->getErrors();
if(!empty($errors)) { if(!empty($errors)) {
return array( return $this->errorResponse($errors);
'result' => false,
'errors' => $errors
);
} else { } else {
$message = ($newsletter->type === Newsletter::TYPE_WELCOME) ? return $this->successResponse(
__('Your Welcome Email has been activated') : Newsletter::findOne($newsletter->id)->asArray()
__('Your Post Notification has been activated');
return array(
'result' => true,
'data' => array(
'message' => $message
)
); );
} }
} } else {
// Standard newsletters
$queue = SendingQueueModel::whereNull('status') $queue = SendingQueueModel::whereNull('status')
->where('newsletter_id', $newsletter->id) ->where('newsletter_id', $newsletter->id)
->findOne(); ->findOne();
if(!empty($queue)) { if(!empty($queue)) {
return array( return $this->errorResponse(array(
'result' => false, APIError::NOT_FOUND => __('This newsletter is already being sent.')
'errors' => array(__('This newsletter is already being sent')) ));
); }
}
$queue = SendingQueueModel::where('newsletter_id', $newsletter->id) $queue = SendingQueueModel::where('newsletter_id', $newsletter->id)
->where('status', SendingQueueModel::STATUS_SCHEDULED) ->where('status', SendingQueueModel::STATUS_SCHEDULED)
->findOne(); ->findOne();
if(!$queue) { if(!$queue) {
$queue = SendingQueueModel::create(); $queue = SendingQueueModel::create();
$queue->newsletter_id = $newsletter->id; $queue->newsletter_id = $newsletter->id;
} }
if((bool)$newsletter->isScheduled) { if((bool)$newsletter->isScheduled) {
// set newsletter status // set newsletter status
$newsletter->setStatus(Newsletter::STATUS_SCHEDULED); $newsletter->setStatus(Newsletter::STATUS_SCHEDULED);
// set queue status // set queue status
$queue->status = SendingQueueModel::STATUS_SCHEDULED; $queue->status = SendingQueueModel::STATUS_SCHEDULED;
$queue->scheduled_at = Scheduler::scheduleFromTimestamp( $queue->scheduled_at = Scheduler::scheduleFromTimestamp(
$newsletter->scheduledAt $newsletter->scheduledAt
); );
$queue->subscribers = null; $queue->subscribers = null;
$queue->count_total = $queue->count_to_process = 0; $queue->count_total = $queue->count_to_process = 0;
} else {
$segments = $newsletter->segments()->findArray();
$segment_ids = array_map(function($segment) {
return $segment['id'];
}, $segments);
$subscribers = Subscriber::getSubscribedInSegments($segment_ids)
->findArray();
$subscribers = Helpers::arrayColumn($subscribers, 'subscriber_id');
$subscribers = array_unique($subscribers);
if(!count($subscribers)) {
return $this->errorResponse(array(
APIError::UNKNOWN => __('There are no subscribers in that list!')
));
}
$queue->status = null;
$queue->scheduled_at = null;
$queue->subscribers = serialize(
array(
'to_process' => $subscribers
)
);
$queue->count_total = $queue->count_to_process = count($subscribers);
$message = __('The newsletter has been scheduled'); // set newsletter status
} else { $newsletter->setStatus(Newsletter::STATUS_SENDING);
$segments = $newsletter->segments()->findArray(); }
$segment_ids = array_map(function($segment) { $queue->save();
return $segment['id'];
}, $segments); $errors = $queue->getErrors();
$subscribers = Subscriber::getSubscribedInSegments($segment_ids) if(!empty($errors)) {
->findArray(); return $this->errorResponse($errors);
$subscribers = Helpers::arrayColumn($subscribers, 'subscriber_id'); } else {
$subscribers = array_unique($subscribers); return $this->successResponse(
if(!count($subscribers)) { Newsletter::findOne($newsletter->id)->asArray()
return array(
'result' => false,
'errors' => array(__('There are no subscribers in that list!'))
); );
} }
$queue->status = null;
$queue->scheduled_at = null;
$queue->subscribers = serialize(
array(
'to_process' => $subscribers
)
);
$queue->count_total = $queue->count_to_process = count($subscribers);
// set newsletter status
$newsletter->setStatus(Newsletter::STATUS_SENDING);
$message = __('The newsletter is being sent...');
} }
$queue->save(); }
$errors = $queue->getErrors(); function pause($data = array()) {
if(!empty($errors)) { $id = (isset($data['id']) ? (int)$data['id'] : null);
return array( $newsletter = Newsletter::findOne($id);
'result' => false,
'errors' => $errors if($newsletter === false) {
); return $this->errorResponse(array(
APIError::NOT_FOUND => __('This newsletter does not exist.')
));
} else { } else {
return array( $queue = $newsletter->getQueue();
'result' => true,
'data' => array( if($queue === false) {
'message' => $message return $this->errorResponse(array(
) APIError::UNKNOWN => __('This newsletter has not been sent yet.')
); ));
} else {
$queue->pause();
return $this->successResponse(
Newsletter::findOne($newsletter->id)->asArray()
);
}
} }
} }
function pause($newsletter_id) { function resume($data = array()) {
$newsletter = Newsletter::findOne($newsletter_id); $id = (isset($data['id']) ? (int)$data['id'] : null);
$result = false; $newsletter = Newsletter::findOne($id);
if($newsletter !== false) { if($newsletter === false) {
return $this->errorResponse(array(
APIError::NOT_FOUND => __('This newsletter does not exist.')
));
} else {
$queue = $newsletter->getQueue(); $queue = $newsletter->getQueue();
if($queue !== false) { if($queue === false) {
$result = $queue->pause(); return $this->errorResponse(array(
APIError::UNKNOWN => __('This newsletter has not been sent yet.')
));
} else {
$queue->resume();
return $this->successResponse(
Newsletter::findOne($newsletter->id)->asArray()
);
} }
} }
return array(
'result' => $result
);
}
function resume($newsletter_id) {
$newsletter = Newsletter::findOne($newsletter_id);
$result = false;
if($newsletter !== false) {
$queue = $newsletter->getQueue();
if($queue !== false) {
$result = $queue->resume();
}
}
return array(
'result' => $result
);
} }
} }

View File

@ -210,19 +210,17 @@
'saturdayMin': __('S'), 'saturdayMin': __('S'),
'next': __('Next'), 'next': __('Next'),
'previous': __('Previous'), 'previous': __('Previous'),
'newsletterBeingSent': __('The newsletter is being sent...'),
'welcomeEmailActivated': __('Your Welcome Email is now activated!'), 'welcomeEmailActivated': __('Your Welcome Email is now activated!'),
'welcomeEmailActivationFailed': __('Your Welcome Email could not be activated, please check the settings'), 'welcomeEmailActivationFailed': __('Your Welcome Email could not be activated, please check the settings'),
'postNotificationActivated': __('Your post notification is now active!'), 'postNotificationActivated': __('Your post notification is now active!'),
'postNotificationActivationFailed': __('Your post notification could not be activated, check the settings'), 'postNotificationActivationFailed': __('Your post notification could not be activated, check the settings'),
'welcomeEventSegment': __('This newsletter is sent when someone subscribes to the list: "%$1s"'), 'welcomeEventSegment': __('This newsletter is sent when someone subscribes to the list: "%$1s"'),
'welcomeEventWPUserAnyRole': __('This newsletter is sent when a new WordPress user is added to your site'), 'welcomeEventWPUserAnyRole': __('This newsletter is sent when a new WordPress user is added to your site'),
'welcomeEventWPUserWithRole': __('This newsletter is sent when a new WordPress user with the role "%$1s" is added to your site'), 'welcomeEventWPUserWithRole': __('This newsletter is sent when a new WordPress user with the role "%$1s" is added to your site'),
'sendingDelayHours': __('%$1d hour(s) later'), 'sendingDelayHours': __('%$1d hour(s) later'),
'sendingDelayDays': __('%$1d day(s) later'), 'sendingDelayDays': __('%$1d day(s) later'),
'sendingDelayWeeks': __('%$1d week(s) later'), 'sendingDelayWeeks': __('%$1d week(s) later'),
'sendDaily': __('Send daily at %$1s'), 'sendDaily': __('Send daily at %$1s'),
'sendWeekly': __('Send weekly on %$1s at %$2s'), 'sendWeekly': __('Send weekly on %$1s at %$2s'),
'sendMonthly': __('Send monthly on the %$1s at %$2s'), 'sendMonthly': __('Send monthly on the %$1s at %$2s'),