Delete scheduled tasks subscribers using a repository
[MAILPOET-5845]
This commit is contained in:
@@ -25,6 +25,7 @@ use MailPoet\Entities\StatisticsWooCommercePurchaseEntity;
|
|||||||
use MailPoet\Entities\StatsNotificationEntity;
|
use MailPoet\Entities\StatsNotificationEntity;
|
||||||
use MailPoet\Logging\LoggerFactory;
|
use MailPoet\Logging\LoggerFactory;
|
||||||
use MailPoet\Newsletter\Options\NewsletterOptionsRepository;
|
use MailPoet\Newsletter\Options\NewsletterOptionsRepository;
|
||||||
|
use MailPoet\Newsletter\Sending\ScheduledTaskSubscribersRepository;
|
||||||
use MailPoet\Statistics\StatisticsClicksRepository;
|
use MailPoet\Statistics\StatisticsClicksRepository;
|
||||||
use MailPoet\Statistics\StatisticsNewslettersRepository;
|
use MailPoet\Statistics\StatisticsNewslettersRepository;
|
||||||
use MailPoet\Statistics\StatisticsOpensRepository;
|
use MailPoet\Statistics\StatisticsOpensRepository;
|
||||||
@@ -43,6 +44,7 @@ class NewslettersRepository extends Repository {
|
|||||||
private NewsletterLinkRepository $newsletterLinkRepository;
|
private NewsletterLinkRepository $newsletterLinkRepository;
|
||||||
private NewsletterOptionsRepository $newsletterOptionsRepository;
|
private NewsletterOptionsRepository $newsletterOptionsRepository;
|
||||||
private NewsletterPostsRepository $newsletterPostsRepository;
|
private NewsletterPostsRepository $newsletterPostsRepository;
|
||||||
|
private ScheduledTaskSubscribersRepository $scheduledTaskSubscribersRepository;
|
||||||
private StatisticsClicksRepository $statisticsClicksRepository;
|
private StatisticsClicksRepository $statisticsClicksRepository;
|
||||||
private StatisticsNewslettersRepository $statisticsNewslettersRepository;
|
private StatisticsNewslettersRepository $statisticsNewslettersRepository;
|
||||||
private StatisticsOpensRepository $statisticsOpensRepository;
|
private StatisticsOpensRepository $statisticsOpensRepository;
|
||||||
@@ -53,6 +55,7 @@ class NewslettersRepository extends Repository {
|
|||||||
NewsletterLinkRepository $newsletterLinkRepository,
|
NewsletterLinkRepository $newsletterLinkRepository,
|
||||||
NewsletterOptionsRepository $newsletterOptionsRepository,
|
NewsletterOptionsRepository $newsletterOptionsRepository,
|
||||||
NewsletterPostsRepository $newsletterPostsRepository,
|
NewsletterPostsRepository $newsletterPostsRepository,
|
||||||
|
ScheduledTaskSubscribersRepository $scheduledTaskSubscribersRepository,
|
||||||
StatisticsClicksRepository $statisticsClicksRepository,
|
StatisticsClicksRepository $statisticsClicksRepository,
|
||||||
StatisticsNewslettersRepository $statisticsNewslettersRepository,
|
StatisticsNewslettersRepository $statisticsNewslettersRepository,
|
||||||
StatisticsOpensRepository $statisticsOpensRepository,
|
StatisticsOpensRepository $statisticsOpensRepository,
|
||||||
@@ -63,6 +66,7 @@ class NewslettersRepository extends Repository {
|
|||||||
$this->newsletterLinkRepository = $newsletterLinkRepository;
|
$this->newsletterLinkRepository = $newsletterLinkRepository;
|
||||||
$this->newsletterOptionsRepository = $newsletterOptionsRepository;
|
$this->newsletterOptionsRepository = $newsletterOptionsRepository;
|
||||||
$this->newsletterPostsRepository = $newsletterPostsRepository;
|
$this->newsletterPostsRepository = $newsletterPostsRepository;
|
||||||
|
$this->scheduledTaskSubscribersRepository = $scheduledTaskSubscribersRepository;
|
||||||
$this->statisticsClicksRepository = $statisticsClicksRepository;
|
$this->statisticsClicksRepository = $statisticsClicksRepository;
|
||||||
$this->statisticsNewslettersRepository = $statisticsNewslettersRepository;
|
$this->statisticsNewslettersRepository = $statisticsNewslettersRepository;
|
||||||
$this->statisticsOpensRepository = $statisticsOpensRepository;
|
$this->statisticsOpensRepository = $statisticsOpensRepository;
|
||||||
@@ -434,17 +438,19 @@ class NewslettersRepository extends Repository {
|
|||||||
", ['ids' => $ids], ['ids' => Connection::PARAM_INT_ARRAY]);
|
", ['ids' => $ids], ['ids' => Connection::PARAM_INT_ARRAY]);
|
||||||
|
|
||||||
// Delete scheduled tasks and scheduled task subscribers
|
// Delete scheduled tasks and scheduled task subscribers
|
||||||
|
/** @var string[] $taskIds */
|
||||||
|
$taskIds = $this->entityManager->createQueryBuilder()
|
||||||
|
->select('IDENTITY(q.task)')
|
||||||
|
->from(SendingQueueEntity::class, 'q')
|
||||||
|
->where('q.newsletter IN (:ids)')
|
||||||
|
->setParameter('ids', $ids)
|
||||||
|
->getQuery()
|
||||||
|
->getSingleColumnResult();
|
||||||
|
$taskIds = array_map('intval', $taskIds);
|
||||||
|
|
||||||
|
$this->scheduledTaskSubscribersRepository->deleteByTaskIds($taskIds);
|
||||||
|
|
||||||
$sendingQueueTable = $entityManager->getClassMetadata(SendingQueueEntity::class)->getTableName();
|
$sendingQueueTable = $entityManager->getClassMetadata(SendingQueueEntity::class)->getTableName();
|
||||||
$scheduledTaskSubscribersTable = $entityManager->getClassMetadata(ScheduledTaskSubscriberEntity::class)->getTableName();
|
|
||||||
|
|
||||||
// Delete scheduled tasks subscribers
|
|
||||||
$entityManager->getConnection()->executeStatement("
|
|
||||||
DELETE ts FROM $scheduledTaskSubscribersTable ts
|
|
||||||
JOIN $scheduledTasksTable t ON t.`id` = ts.`task_id`
|
|
||||||
JOIN $sendingQueueTable q ON q.`task_id` = t.`id`
|
|
||||||
WHERE q.`newsletter_id` IN (:ids)
|
|
||||||
", ['ids' => $ids], ['ids' => Connection::PARAM_INT_ARRAY]);
|
|
||||||
|
|
||||||
$entityManager->getConnection()->executeStatement("
|
$entityManager->getConnection()->executeStatement("
|
||||||
DELETE t FROM $scheduledTasksTable t
|
DELETE t FROM $scheduledTasksTable t
|
||||||
JOIN $sendingQueueTable q ON t.`id` = q.`task_id`
|
JOIN $sendingQueueTable q ON t.`id` = q.`task_id`
|
||||||
|
@@ -118,6 +118,22 @@ class ScheduledTaskSubscribersRepository extends Repository {
|
|||||||
$stmt->executeQuery();
|
$stmt->executeQuery();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** @param int[] $ids */
|
||||||
|
public function deleteByTaskIds(array $ids): void {
|
||||||
|
$this->entityManager->createQueryBuilder()
|
||||||
|
->delete(ScheduledTaskSubscriberEntity::class, 'sts')
|
||||||
|
->where('sts.task IN (:taskIds)')
|
||||||
|
->setParameter('taskIds', $ids)
|
||||||
|
->getQuery()
|
||||||
|
->execute();
|
||||||
|
|
||||||
|
// delete was done via DQL, make sure the entities are also detached from the entity manager
|
||||||
|
$this->detachAll(function (ScheduledTaskSubscriberEntity $entity) use ($ids) {
|
||||||
|
$task = $entity->getTask();
|
||||||
|
return $task && in_array($task->getId(), $ids, true);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
public function deleteByScheduledTask(ScheduledTaskEntity $scheduledTask): void {
|
public function deleteByScheduledTask(ScheduledTaskEntity $scheduledTask): void {
|
||||||
$this->entityManager->createQueryBuilder()
|
$this->entityManager->createQueryBuilder()
|
||||||
->delete(ScheduledTaskSubscriberEntity::class, 'sts')
|
->delete(ScheduledTaskSubscriberEntity::class, 'sts')
|
||||||
|
Reference in New Issue
Block a user