updated sending queue endpoint + react (pause/resume/send)
This commit is contained in:
@ -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();
|
||||||
|
@ -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 }
|
||||||
|
);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -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
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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'),
|
||||||
|
Reference in New Issue
Block a user