Refactor pause/resume to doctrine
[MAILPOET-3876]
This commit is contained in:
@ -8,10 +8,12 @@ use MailPoet\API\JSON\Response;
|
|||||||
use MailPoet\Config\AccessControl;
|
use MailPoet\Config\AccessControl;
|
||||||
use MailPoet\Cron\Triggers\WordPress;
|
use MailPoet\Cron\Triggers\WordPress;
|
||||||
use MailPoet\Entities\NewsletterEntity;
|
use MailPoet\Entities\NewsletterEntity;
|
||||||
|
use MailPoet\Entities\SendingQueueEntity;
|
||||||
use MailPoet\Models\Newsletter;
|
use MailPoet\Models\Newsletter;
|
||||||
use MailPoet\Models\SendingQueue as SendingQueueModel;
|
use MailPoet\Models\SendingQueue as SendingQueueModel;
|
||||||
use MailPoet\Newsletter\NewslettersRepository;
|
use MailPoet\Newsletter\NewslettersRepository;
|
||||||
use MailPoet\Newsletter\Scheduler\Scheduler;
|
use MailPoet\Newsletter\Scheduler\Scheduler;
|
||||||
|
use MailPoet\Newsletter\Sending\SendingQueuesRepository;
|
||||||
use MailPoet\Segments\SubscribersFinder;
|
use MailPoet\Segments\SubscribersFinder;
|
||||||
use MailPoet\Services\Bridge;
|
use MailPoet\Services\Bridge;
|
||||||
use MailPoet\Tasks\Sending as SendingTask;
|
use MailPoet\Tasks\Sending as SendingTask;
|
||||||
@ -34,9 +36,13 @@ class SendingQueue extends APIEndpoint {
|
|||||||
/** @var Bridge */
|
/** @var Bridge */
|
||||||
private $bridge;
|
private $bridge;
|
||||||
|
|
||||||
|
/** @var SendingQueuesRepository */
|
||||||
|
private $sendingQueuesRepository;
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
SubscribersFeature $subscribersFeature,
|
SubscribersFeature $subscribersFeature,
|
||||||
NewslettersRepository $newsletterRepository,
|
NewslettersRepository $newsletterRepository,
|
||||||
|
SendingQueuesRepository $sendingQueuesRepository,
|
||||||
Bridge $bridge,
|
Bridge $bridge,
|
||||||
SubscribersFinder $subscribersFinder
|
SubscribersFinder $subscribersFinder
|
||||||
) {
|
) {
|
||||||
@ -44,6 +50,7 @@ class SendingQueue extends APIEndpoint {
|
|||||||
$this->subscribersFinder = $subscribersFinder;
|
$this->subscribersFinder = $subscribersFinder;
|
||||||
$this->newsletterRepository = $newsletterRepository;
|
$this->newsletterRepository = $newsletterRepository;
|
||||||
$this->bridge = $bridge;
|
$this->bridge = $bridge;
|
||||||
|
$this->sendingQueuesRepository = $sendingQueuesRepository;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function add($data = []) {
|
public function add($data = []) {
|
||||||
@ -65,7 +72,7 @@ class SendingQueue extends APIEndpoint {
|
|||||||
APIError::NOT_FOUND => __('This newsletter does not exist.', 'mailpoet'),
|
APIError::NOT_FOUND => __('This newsletter does not exist.', 'mailpoet'),
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
$newsletterEntity = $this->newsletterRepository->findOneById($newsletter->id);
|
$newsletterEntity = $this->newsletterRepository->findOneById($newsletterId);
|
||||||
if (!$newsletterEntity instanceof NewsletterEntity) {
|
if (!$newsletterEntity instanceof NewsletterEntity) {
|
||||||
return $this->errorResponse([
|
return $this->errorResponse([
|
||||||
APIError::NOT_FOUND => __('This newsletter does not exist.', 'mailpoet'),
|
APIError::NOT_FOUND => __('This newsletter does not exist.', 'mailpoet'),
|
||||||
@ -177,20 +184,18 @@ class SendingQueue extends APIEndpoint {
|
|||||||
? (int)$data['newsletter_id']
|
? (int)$data['newsletter_id']
|
||||||
: false
|
: false
|
||||||
);
|
);
|
||||||
$newsletter = Newsletter::findOne($newsletterId);
|
$newsletter = $this->newsletterRepository->findOneById($newsletterId);
|
||||||
|
|
||||||
if ($newsletter instanceof Newsletter) {
|
if ($newsletter instanceof NewsletterEntity) {
|
||||||
$queue = $newsletter->getQueue();
|
$queue = $newsletter->getLatestQueue();
|
||||||
|
|
||||||
if ($queue === false) {
|
if (!$queue instanceof SendingQueueEntity) {
|
||||||
return $this->errorResponse([
|
return $this->errorResponse([
|
||||||
APIError::UNKNOWN => __('This newsletter has not been sent yet.', 'mailpoet'),
|
APIError::UNKNOWN => __('This newsletter has not been sent yet.', 'mailpoet'),
|
||||||
]);
|
]);
|
||||||
} else {
|
} else {
|
||||||
$queue->pause();
|
$this->sendingQueuesRepository->pause($queue);
|
||||||
return $this->successResponse(
|
return $this->successResponse();
|
||||||
$newsletter->getQueue()->asArray()
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
return $this->errorResponse([
|
return $this->errorResponse([
|
||||||
@ -209,19 +214,18 @@ class SendingQueue extends APIEndpoint {
|
|||||||
? (int)$data['newsletter_id']
|
? (int)$data['newsletter_id']
|
||||||
: false
|
: false
|
||||||
);
|
);
|
||||||
$newsletter = Newsletter::findOne($newsletterId);
|
$newsletter = $this->newsletterRepository->findOneById($newsletterId);
|
||||||
if ($newsletter instanceof Newsletter) {
|
|
||||||
$queue = $newsletter->getQueue();
|
|
||||||
|
|
||||||
if ($queue === false) {
|
if ($newsletter instanceof NewsletterEntity) {
|
||||||
|
$queue = $newsletter->getLatestQueue();
|
||||||
|
|
||||||
|
if (!$queue instanceof SendingQueueEntity) {
|
||||||
return $this->errorResponse([
|
return $this->errorResponse([
|
||||||
APIError::UNKNOWN => __('This newsletter has not been sent yet.', 'mailpoet'),
|
APIError::UNKNOWN => __('This newsletter has not been sent yet.', 'mailpoet'),
|
||||||
]);
|
]);
|
||||||
} else {
|
} else {
|
||||||
$queue->resume();
|
$this->sendingQueuesRepository->resume($queue);
|
||||||
return $this->successResponse(
|
return $this->successResponse();
|
||||||
$newsletter->getQueue()->asArray()
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
return $this->errorResponse([
|
return $this->errorResponse([
|
||||||
|
@ -7,6 +7,7 @@ use MailPoet\Entities\NewsletterEntity;
|
|||||||
use MailPoet\Entities\ScheduledTaskEntity;
|
use MailPoet\Entities\ScheduledTaskEntity;
|
||||||
use MailPoet\Entities\SendingQueueEntity;
|
use MailPoet\Entities\SendingQueueEntity;
|
||||||
use MailPoet\Entities\SubscriberEntity;
|
use MailPoet\Entities\SubscriberEntity;
|
||||||
|
use MailPoet\WP\Functions as WPFunctions;
|
||||||
use MailPoetVendor\Doctrine\ORM\EntityManager;
|
use MailPoetVendor\Doctrine\ORM\EntityManager;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -16,12 +17,17 @@ class SendingQueuesRepository extends Repository {
|
|||||||
/** @var ScheduledTaskSubscribersRepository */
|
/** @var ScheduledTaskSubscribersRepository */
|
||||||
private $scheduledTaskSubscribersRepository;
|
private $scheduledTaskSubscribersRepository;
|
||||||
|
|
||||||
|
/** @var WPFunctions */
|
||||||
|
private $wp;
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
EntityManager $entityManager,
|
EntityManager $entityManager,
|
||||||
|
WPFunctions $wp,
|
||||||
ScheduledTaskSubscribersRepository $scheduledTaskSubscribersRepository
|
ScheduledTaskSubscribersRepository $scheduledTaskSubscribersRepository
|
||||||
) {
|
) {
|
||||||
parent::__construct($entityManager);
|
parent::__construct($entityManager);
|
||||||
$this->scheduledTaskSubscribersRepository = $scheduledTaskSubscribersRepository;
|
$this->scheduledTaskSubscribersRepository = $scheduledTaskSubscribersRepository;
|
||||||
|
$this->wp = $wp;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function getEntityClassName() {
|
protected function getEntityClassName() {
|
||||||
@ -77,4 +83,31 @@ class SendingQueuesRepository extends Repository {
|
|||||||
}
|
}
|
||||||
return $qb->getQuery()->getResult();
|
return $qb->getQuery()->getResult();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function pause(SendingQueueEntity $queue): void {
|
||||||
|
if ($queue->getCountProcessed() !== $queue->getCountTotal()) {
|
||||||
|
$task = $queue->getTask();
|
||||||
|
if ($task instanceof ScheduledTaskEntity) {
|
||||||
|
$task->setStatus(ScheduledTaskEntity::STATUS_PAUSED);
|
||||||
|
$this->flush();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function resume(SendingQueueEntity $queue): void {
|
||||||
|
$task = $queue->getTask();
|
||||||
|
if (!$task instanceof ScheduledTaskEntity) return;
|
||||||
|
|
||||||
|
if ($queue->getCountProcessed() === $queue->getCountTotal()) {
|
||||||
|
$task->setProcessedAt($this->wp->currentTime('mysql'));
|
||||||
|
$task->setStatus(ScheduledTaskEntity::STATUS_COMPLETED);
|
||||||
|
$this->flush();
|
||||||
|
} else {
|
||||||
|
$newsletter = $queue->getNewsletter();
|
||||||
|
if (!$newsletter instanceof NewsletterEntity) return;
|
||||||
|
$newsletter->setStatus(NewsletterEntity::STATUS_SENDING);
|
||||||
|
$task->setStatus(null);
|
||||||
|
$this->flush();
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user