Delete newsletter data from woocommerce purchase stats using a repository
[MAILPOET-5845]
This commit is contained in:
@@ -21,7 +21,6 @@ use MailPoet\Entities\SendingQueueEntity;
|
|||||||
use MailPoet\Entities\StatisticsClickEntity;
|
use MailPoet\Entities\StatisticsClickEntity;
|
||||||
use MailPoet\Entities\StatisticsNewsletterEntity;
|
use MailPoet\Entities\StatisticsNewsletterEntity;
|
||||||
use MailPoet\Entities\StatisticsOpenEntity;
|
use MailPoet\Entities\StatisticsOpenEntity;
|
||||||
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;
|
||||||
@@ -32,6 +31,7 @@ use MailPoet\Newsletter\Sending\SendingQueuesRepository;
|
|||||||
use MailPoet\Statistics\StatisticsClicksRepository;
|
use MailPoet\Statistics\StatisticsClicksRepository;
|
||||||
use MailPoet\Statistics\StatisticsNewslettersRepository;
|
use MailPoet\Statistics\StatisticsNewslettersRepository;
|
||||||
use MailPoet\Statistics\StatisticsOpensRepository;
|
use MailPoet\Statistics\StatisticsOpensRepository;
|
||||||
|
use MailPoet\Statistics\StatisticsWooCommercePurchasesRepository;
|
||||||
use MailPoet\Util\Helpers;
|
use MailPoet\Util\Helpers;
|
||||||
use MailPoet\WP\Functions as WPFunctions;
|
use MailPoet\WP\Functions as WPFunctions;
|
||||||
use MailPoetVendor\Carbon\Carbon;
|
use MailPoetVendor\Carbon\Carbon;
|
||||||
@@ -54,6 +54,7 @@ class NewslettersRepository extends Repository {
|
|||||||
private StatisticsClicksRepository $statisticsClicksRepository;
|
private StatisticsClicksRepository $statisticsClicksRepository;
|
||||||
private StatisticsNewslettersRepository $statisticsNewslettersRepository;
|
private StatisticsNewslettersRepository $statisticsNewslettersRepository;
|
||||||
private StatisticsOpensRepository $statisticsOpensRepository;
|
private StatisticsOpensRepository $statisticsOpensRepository;
|
||||||
|
private StatisticsWooCommercePurchasesRepository $statisticsWooCommercePurchasesRepository;
|
||||||
private WPFunctions $wp;
|
private WPFunctions $wp;
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
@@ -68,6 +69,7 @@ class NewslettersRepository extends Repository {
|
|||||||
StatisticsClicksRepository $statisticsClicksRepository,
|
StatisticsClicksRepository $statisticsClicksRepository,
|
||||||
StatisticsNewslettersRepository $statisticsNewslettersRepository,
|
StatisticsNewslettersRepository $statisticsNewslettersRepository,
|
||||||
StatisticsOpensRepository $statisticsOpensRepository,
|
StatisticsOpensRepository $statisticsOpensRepository,
|
||||||
|
StatisticsWooCommercePurchasesRepository $statisticsWooCommercePurchasesRepository,
|
||||||
WPFunctions $wp
|
WPFunctions $wp
|
||||||
) {
|
) {
|
||||||
parent::__construct($entityManager);
|
parent::__construct($entityManager);
|
||||||
@@ -82,6 +84,7 @@ class NewslettersRepository extends Repository {
|
|||||||
$this->statisticsClicksRepository = $statisticsClicksRepository;
|
$this->statisticsClicksRepository = $statisticsClicksRepository;
|
||||||
$this->statisticsNewslettersRepository = $statisticsNewslettersRepository;
|
$this->statisticsNewslettersRepository = $statisticsNewslettersRepository;
|
||||||
$this->statisticsOpensRepository = $statisticsOpensRepository;
|
$this->statisticsOpensRepository = $statisticsOpensRepository;
|
||||||
|
$this->statisticsWooCommercePurchasesRepository = $statisticsWooCommercePurchasesRepository;
|
||||||
$this->wp = $wp;
|
$this->wp = $wp;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -419,11 +422,7 @@ class NewslettersRepository extends Repository {
|
|||||||
$this->statisticsClicksRepository->deleteByNewsletterIds($ids);
|
$this->statisticsClicksRepository->deleteByNewsletterIds($ids);
|
||||||
|
|
||||||
// Update WooCommerce statistics and remove newsletter and click id
|
// Update WooCommerce statistics and remove newsletter and click id
|
||||||
$statisticsPurchasesTable = $entityManager->getClassMetadata(StatisticsWooCommercePurchaseEntity::class)->getTableName();
|
$this->statisticsWooCommercePurchasesRepository->removeNewsletterDataByNewsletterIds($ids);
|
||||||
$entityManager->getConnection()->executeStatement("
|
|
||||||
UPDATE $statisticsPurchasesTable s
|
|
||||||
SET s.`newsletter_id` = 0 WHERE s.`newsletter_id` IN (:ids)
|
|
||||||
", ['ids' => $ids], ['ids' => Connection::PARAM_INT_ARRAY]);
|
|
||||||
|
|
||||||
// Delete newsletter posts, options, links, and segments
|
// Delete newsletter posts, options, links, and segments
|
||||||
$this->newsletterPostsRepository->deleteByNewsletterIds($ids);
|
$this->newsletterPostsRepository->deleteByNewsletterIds($ids);
|
||||||
|
@@ -112,4 +112,21 @@ class StatisticsWooCommercePurchasesRepository extends Repository {
|
|||||||
}, $data);
|
}, $data);
|
||||||
return $data;
|
return $data;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** @param int[] $ids */
|
||||||
|
public function removeNewsletterDataByNewsletterIds(array $ids): void {
|
||||||
|
$this->entityManager->createQueryBuilder()
|
||||||
|
->update(StatisticsWooCommercePurchaseEntity::class, 'swp')
|
||||||
|
->set('swp.newsletter', 0)
|
||||||
|
->where('swp.newsletter IN (:ids)')
|
||||||
|
->setParameter('ids', $ids)
|
||||||
|
->getQuery()
|
||||||
|
->execute();
|
||||||
|
|
||||||
|
// update was done via DQL, make sure the entities are also refreshed in the entity manager
|
||||||
|
$this->refreshAll(function (StatisticsWooCommercePurchaseEntity $entity) use ($ids) {
|
||||||
|
$newsletter = $entity->getNewsletter();
|
||||||
|
return $newsletter && in_array($newsletter->getId(), $ids, true);
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user