Delete newsletter segments 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\Segment\NewsletterSegmentRepository;
|
||||||
use MailPoet\Newsletter\Sending\ScheduledTasksRepository;
|
use MailPoet\Newsletter\Sending\ScheduledTasksRepository;
|
||||||
use MailPoet\Newsletter\Sending\ScheduledTaskSubscribersRepository;
|
use MailPoet\Newsletter\Sending\ScheduledTaskSubscribersRepository;
|
||||||
use MailPoet\Newsletter\Sending\SendingQueuesRepository;
|
use MailPoet\Newsletter\Sending\SendingQueuesRepository;
|
||||||
@@ -46,6 +47,7 @@ class NewslettersRepository extends Repository {
|
|||||||
private NewsletterLinkRepository $newsletterLinkRepository;
|
private NewsletterLinkRepository $newsletterLinkRepository;
|
||||||
private NewsletterOptionsRepository $newsletterOptionsRepository;
|
private NewsletterOptionsRepository $newsletterOptionsRepository;
|
||||||
private NewsletterPostsRepository $newsletterPostsRepository;
|
private NewsletterPostsRepository $newsletterPostsRepository;
|
||||||
|
private NewsletterSegmentRepository $newsletterSegmentRepository;
|
||||||
private ScheduledTasksRepository $scheduledTasksRepository;
|
private ScheduledTasksRepository $scheduledTasksRepository;
|
||||||
private ScheduledTaskSubscribersRepository $scheduledTaskSubscribersRepository;
|
private ScheduledTaskSubscribersRepository $scheduledTaskSubscribersRepository;
|
||||||
private SendingQueuesRepository $sendingQueuesRepository;
|
private SendingQueuesRepository $sendingQueuesRepository;
|
||||||
@@ -59,6 +61,7 @@ class NewslettersRepository extends Repository {
|
|||||||
NewsletterLinkRepository $newsletterLinkRepository,
|
NewsletterLinkRepository $newsletterLinkRepository,
|
||||||
NewsletterOptionsRepository $newsletterOptionsRepository,
|
NewsletterOptionsRepository $newsletterOptionsRepository,
|
||||||
NewsletterPostsRepository $newsletterPostsRepository,
|
NewsletterPostsRepository $newsletterPostsRepository,
|
||||||
|
NewsletterSegmentRepository $newsletterSegmentRepository,
|
||||||
ScheduledTasksRepository $scheduledTasksRepository,
|
ScheduledTasksRepository $scheduledTasksRepository,
|
||||||
ScheduledTaskSubscribersRepository $scheduledTaskSubscribersRepository,
|
ScheduledTaskSubscribersRepository $scheduledTaskSubscribersRepository,
|
||||||
SendingQueuesRepository $sendingQueuesRepository,
|
SendingQueuesRepository $sendingQueuesRepository,
|
||||||
@@ -72,6 +75,7 @@ class NewslettersRepository extends Repository {
|
|||||||
$this->newsletterLinkRepository = $newsletterLinkRepository;
|
$this->newsletterLinkRepository = $newsletterLinkRepository;
|
||||||
$this->newsletterOptionsRepository = $newsletterOptionsRepository;
|
$this->newsletterOptionsRepository = $newsletterOptionsRepository;
|
||||||
$this->newsletterPostsRepository = $newsletterPostsRepository;
|
$this->newsletterPostsRepository = $newsletterPostsRepository;
|
||||||
|
$this->newsletterSegmentRepository = $newsletterSegmentRepository;
|
||||||
$this->scheduledTasksRepository = $scheduledTasksRepository;
|
$this->scheduledTasksRepository = $scheduledTasksRepository;
|
||||||
$this->scheduledTaskSubscribersRepository = $scheduledTaskSubscribersRepository;
|
$this->scheduledTaskSubscribersRepository = $scheduledTaskSubscribersRepository;
|
||||||
$this->sendingQueuesRepository = $sendingQueuesRepository;
|
$this->sendingQueuesRepository = $sendingQueuesRepository;
|
||||||
@@ -421,10 +425,11 @@ class NewslettersRepository extends Repository {
|
|||||||
SET s.`newsletter_id` = 0 WHERE s.`newsletter_id` IN (:ids)
|
SET s.`newsletter_id` = 0 WHERE s.`newsletter_id` IN (:ids)
|
||||||
", ['ids' => $ids], ['ids' => Connection::PARAM_INT_ARRAY]);
|
", ['ids' => $ids], ['ids' => Connection::PARAM_INT_ARRAY]);
|
||||||
|
|
||||||
// Delete newsletter posts, options, and links
|
// Delete newsletter posts, options, links, and segments
|
||||||
$this->newsletterPostsRepository->deleteByNewsletterIds($ids);
|
$this->newsletterPostsRepository->deleteByNewsletterIds($ids);
|
||||||
$this->newsletterOptionsRepository->deleteByNewsletterIds($ids);
|
$this->newsletterOptionsRepository->deleteByNewsletterIds($ids);
|
||||||
$this->newsletterLinkRepository->deleteByNewsletterIds($ids);
|
$this->newsletterLinkRepository->deleteByNewsletterIds($ids);
|
||||||
|
$this->newsletterSegmentRepository->deleteByNewsletterIds($ids);
|
||||||
|
|
||||||
// Delete stats notifications tasks
|
// Delete stats notifications tasks
|
||||||
$scheduledTasksTable = $entityManager->getClassMetadata(ScheduledTaskEntity::class)->getTableName();
|
$scheduledTasksTable = $entityManager->getClassMetadata(ScheduledTaskEntity::class)->getTableName();
|
||||||
@@ -460,13 +465,6 @@ class NewslettersRepository extends Repository {
|
|||||||
$this->scheduledTasksRepository->deleteByIds($taskIds);
|
$this->scheduledTasksRepository->deleteByIds($taskIds);
|
||||||
$this->sendingQueuesRepository->deleteByNewsletterIds($ids);
|
$this->sendingQueuesRepository->deleteByNewsletterIds($ids);
|
||||||
|
|
||||||
// Delete newsletter segments
|
|
||||||
$newsletterSegmentsTable = $entityManager->getClassMetadata(NewsletterSegmentEntity::class)->getTableName();
|
|
||||||
$entityManager->getConnection()->executeStatement("
|
|
||||||
DELETE ns FROM $newsletterSegmentsTable ns
|
|
||||||
WHERE ns.`newsletter_id` IN (:ids)
|
|
||||||
", ['ids' => $ids], ['ids' => Connection::PARAM_INT_ARRAY]);
|
|
||||||
|
|
||||||
// Fetch WP Posts IDs and delete them
|
// Fetch WP Posts IDs and delete them
|
||||||
/** @var int[] $wpPostsIds */
|
/** @var int[] $wpPostsIds */
|
||||||
$wpPostsIds = $entityManager->createQueryBuilder()->select('wpp.id')
|
$wpPostsIds = $entityManager->createQueryBuilder()->select('wpp.id')
|
||||||
|
@@ -65,4 +65,20 @@ class NewsletterSegmentRepository extends Repository {
|
|||||||
}
|
}
|
||||||
return $nameMap;
|
return $nameMap;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** @param int[] $ids */
|
||||||
|
public function deleteByNewsletterIds(array $ids): void {
|
||||||
|
$this->entityManager->createQueryBuilder()
|
||||||
|
->delete(NewsletterSegmentEntity::class, 's')
|
||||||
|
->where('s.newsletter IN (:ids)')
|
||||||
|
->setParameter('ids', $ids)
|
||||||
|
->getQuery()
|
||||||
|
->execute();
|
||||||
|
|
||||||
|
// delete was done via DQL, make sure the entities are also detached from the entity manager
|
||||||
|
$this->detachAll(function (NewsletterSegmentEntity $entity) use ($ids) {
|
||||||
|
$newsletter = $entity->getNewsletter();
|
||||||
|
return $newsletter && in_array($newsletter->getId(), $ids, true);
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user