Delete newsletter posts using a repository

[MAILPOET-5845]
This commit is contained in:
Jan Jakes
2024-01-18 13:09:20 +01:00
committed by Aschepikov
parent 1221a64d3d
commit bca9101921
2 changed files with 20 additions and 5 deletions

View File

@@ -12,4 +12,20 @@ class NewsletterPostsRepository extends Repository {
protected function getEntityClassName() { protected function getEntityClassName() {
return NewsletterPostEntity::class; return NewsletterPostEntity::class;
} }
/** @param int[] $ids */
public function deleteByNewsletterIds(array $ids): void {
$this->entityManager->createQueryBuilder()
->delete(NewsletterPostEntity::class, 'p')
->where('p.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 (NewsletterPostEntity $entity) use ($ids) {
$newsletter = $entity->getNewsletter();
return $newsletter && in_array($newsletter->getId(), $ids, true);
});
}
} }

View File

@@ -38,6 +38,7 @@ use MailPoetVendor\Doctrine\ORM\Query\Expr\Join;
*/ */
class NewslettersRepository extends Repository { class NewslettersRepository extends Repository {
private LoggerFactory $loggerFactory; private LoggerFactory $loggerFactory;
private NewsletterPostsRepository $newsletterPostsRepository;
private StatisticsClicksRepository $statisticsClicksRepository; private StatisticsClicksRepository $statisticsClicksRepository;
private StatisticsNewslettersRepository $statisticsNewslettersRepository; private StatisticsNewslettersRepository $statisticsNewslettersRepository;
private StatisticsOpensRepository $statisticsOpensRepository; private StatisticsOpensRepository $statisticsOpensRepository;
@@ -45,6 +46,7 @@ class NewslettersRepository extends Repository {
public function __construct( public function __construct(
EntityManager $entityManager, EntityManager $entityManager,
NewsletterPostsRepository $newsletterPostsRepository,
StatisticsClicksRepository $statisticsClicksRepository, StatisticsClicksRepository $statisticsClicksRepository,
StatisticsNewslettersRepository $statisticsNewslettersRepository, StatisticsNewslettersRepository $statisticsNewslettersRepository,
StatisticsOpensRepository $statisticsOpensRepository, StatisticsOpensRepository $statisticsOpensRepository,
@@ -52,6 +54,7 @@ class NewslettersRepository extends Repository {
) { ) {
parent::__construct($entityManager); parent::__construct($entityManager);
$this->loggerFactory = LoggerFactory::getInstance(); $this->loggerFactory = LoggerFactory::getInstance();
$this->newsletterPostsRepository = $newsletterPostsRepository;
$this->statisticsClicksRepository = $statisticsClicksRepository; $this->statisticsClicksRepository = $statisticsClicksRepository;
$this->statisticsNewslettersRepository = $statisticsNewslettersRepository; $this->statisticsNewslettersRepository = $statisticsNewslettersRepository;
$this->statisticsOpensRepository = $statisticsOpensRepository; $this->statisticsOpensRepository = $statisticsOpensRepository;
@@ -399,11 +402,7 @@ class NewslettersRepository extends Repository {
", ['ids' => $ids], ['ids' => Connection::PARAM_INT_ARRAY]); ", ['ids' => $ids], ['ids' => Connection::PARAM_INT_ARRAY]);
// Delete newsletter posts // Delete newsletter posts
$postsTable = $entityManager->getClassMetadata(NewsletterPostEntity::class)->getTableName(); $this->newsletterPostsRepository->deleteByNewsletterIds($ids);
$entityManager->getConnection()->executeStatement("
DELETE np FROM $postsTable np
WHERE np.`newsletter_id` IN (:ids)
", ['ids' => $ids], ['ids' => Connection::PARAM_INT_ARRAY]);
// Delete newsletter options // Delete newsletter options
$optionsTable = $entityManager->getClassMetadata(NewsletterOptionEntity::class)->getTableName(); $optionsTable = $entityManager->getClassMetadata(NewsletterOptionEntity::class)->getTableName();