Delete newsletter links using a repository
[MAILPOET-5845]
This commit is contained in:
@ -40,4 +40,20 @@ class NewsletterLinkRepository extends Repository {
|
|||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** @param int[] $ids */
|
||||||
|
public function deleteByNewsletterIds(array $ids): void {
|
||||||
|
$this->entityManager->createQueryBuilder()
|
||||||
|
->delete(NewsletterLinkEntity::class, 'l')
|
||||||
|
->where('l.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 (NewsletterLinkEntity $entity) use ($ids) {
|
||||||
|
$newsletter = $entity->getNewsletter();
|
||||||
|
return $newsletter && in_array($newsletter->getId(), $ids, true);
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -7,6 +7,7 @@ use MailPoet\AutomaticEmails\WooCommerce\Events\AbandonedCart;
|
|||||||
use MailPoet\AutomaticEmails\WooCommerce\Events\FirstPurchase;
|
use MailPoet\AutomaticEmails\WooCommerce\Events\FirstPurchase;
|
||||||
use MailPoet\AutomaticEmails\WooCommerce\Events\PurchasedInCategory;
|
use MailPoet\AutomaticEmails\WooCommerce\Events\PurchasedInCategory;
|
||||||
use MailPoet\AutomaticEmails\WooCommerce\Events\PurchasedProduct;
|
use MailPoet\AutomaticEmails\WooCommerce\Events\PurchasedProduct;
|
||||||
|
use MailPoet\Cron\Workers\StatsNotifications\NewsletterLinkRepository;
|
||||||
use MailPoet\Doctrine\Repository;
|
use MailPoet\Doctrine\Repository;
|
||||||
use MailPoet\Entities\NewsletterEntity;
|
use MailPoet\Entities\NewsletterEntity;
|
||||||
use MailPoet\Entities\NewsletterLinkEntity;
|
use MailPoet\Entities\NewsletterLinkEntity;
|
||||||
@ -39,6 +40,7 @@ use MailPoetVendor\Doctrine\ORM\Query\Expr\Join;
|
|||||||
*/
|
*/
|
||||||
class NewslettersRepository extends Repository {
|
class NewslettersRepository extends Repository {
|
||||||
private LoggerFactory $loggerFactory;
|
private LoggerFactory $loggerFactory;
|
||||||
|
private NewsletterLinkRepository $newsletterLinkRepository;
|
||||||
private NewsletterOptionsRepository $newsletterOptionsRepository;
|
private NewsletterOptionsRepository $newsletterOptionsRepository;
|
||||||
private NewsletterPostsRepository $newsletterPostsRepository;
|
private NewsletterPostsRepository $newsletterPostsRepository;
|
||||||
private StatisticsClicksRepository $statisticsClicksRepository;
|
private StatisticsClicksRepository $statisticsClicksRepository;
|
||||||
@ -48,6 +50,7 @@ class NewslettersRepository extends Repository {
|
|||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
EntityManager $entityManager,
|
EntityManager $entityManager,
|
||||||
|
NewsletterLinkRepository $newsletterLinkRepository,
|
||||||
NewsletterOptionsRepository $newsletterOptionsRepository,
|
NewsletterOptionsRepository $newsletterOptionsRepository,
|
||||||
NewsletterPostsRepository $newsletterPostsRepository,
|
NewsletterPostsRepository $newsletterPostsRepository,
|
||||||
StatisticsClicksRepository $statisticsClicksRepository,
|
StatisticsClicksRepository $statisticsClicksRepository,
|
||||||
@ -57,6 +60,7 @@ class NewslettersRepository extends Repository {
|
|||||||
) {
|
) {
|
||||||
parent::__construct($entityManager);
|
parent::__construct($entityManager);
|
||||||
$this->loggerFactory = LoggerFactory::getInstance();
|
$this->loggerFactory = LoggerFactory::getInstance();
|
||||||
|
$this->newsletterLinkRepository = $newsletterLinkRepository;
|
||||||
$this->newsletterOptionsRepository = $newsletterOptionsRepository;
|
$this->newsletterOptionsRepository = $newsletterOptionsRepository;
|
||||||
$this->newsletterPostsRepository = $newsletterPostsRepository;
|
$this->newsletterPostsRepository = $newsletterPostsRepository;
|
||||||
$this->statisticsClicksRepository = $statisticsClicksRepository;
|
$this->statisticsClicksRepository = $statisticsClicksRepository;
|
||||||
@ -405,16 +409,10 @@ 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 and options
|
// Delete newsletter posts, options, and links
|
||||||
$this->newsletterPostsRepository->deleteByNewsletterIds($ids);
|
$this->newsletterPostsRepository->deleteByNewsletterIds($ids);
|
||||||
$this->newsletterOptionsRepository->deleteByNewsletterIds($ids);
|
$this->newsletterOptionsRepository->deleteByNewsletterIds($ids);
|
||||||
|
$this->newsletterLinkRepository->deleteByNewsletterIds($ids);
|
||||||
// Delete newsletter links
|
|
||||||
$linksTable = $entityManager->getClassMetadata(NewsletterLinkEntity::class)->getTableName();
|
|
||||||
$entityManager->getConnection()->executeStatement("
|
|
||||||
DELETE nl FROM $linksTable nl
|
|
||||||
WHERE nl.`newsletter_id` IN (:ids)
|
|
||||||
", ['ids' => $ids], ['ids' => Connection::PARAM_INT_ARRAY]);
|
|
||||||
|
|
||||||
// Delete stats notifications tasks
|
// Delete stats notifications tasks
|
||||||
$scheduledTasksTable = $entityManager->getClassMetadata(ScheduledTaskEntity::class)->getTableName();
|
$scheduledTasksTable = $entityManager->getClassMetadata(ScheduledTaskEntity::class)->getTableName();
|
||||||
|
Reference in New Issue
Block a user