Check requirements when counting subscribers

[MAILPOET-2486]
This commit is contained in:
Pavel Dohnal
2019-10-29 11:59:02 +01:00
committed by Jack Kitterhing
parent 5c706aaacf
commit 4f1ef835dc
2 changed files with 40 additions and 1 deletions

View File

@@ -2,11 +2,23 @@
namespace MailPoet\DynamicSegments\Persistence\Loading;
use MailPoet\DynamicSegments\RequirementsChecker;
use MailPoet\Models\DynamicSegment;
use MailPoet\Models\Subscriber;
use MailPoet\WooCommerce\Helper as WooCommerceHelper;
class SubscribersCount {
/** @var RequirementsChecker */
private $requirements_checker;
function __construct(RequirementsChecker $requirements_checker = null) {
if (!$requirements_checker) {
$requirements_checker = new RequirementsChecker(new WooCommerceHelper());
}
$this->requirements_checker = $requirements_checker;
}
/**
* @param DynamicSegment $dynamic_segment
*
@@ -14,6 +26,9 @@ class SubscribersCount {
*/
function getSubscribersCount(DynamicSegment $dynamic_segment) {
$orm = Subscriber::selectExpr('count(distinct ' . Subscriber::$_table . '.id) as cnt');
if ($this->requirements_checker->shouldSkipSegment($dynamic_segment)) {
return 0;
}
foreach ($dynamic_segment->getFilters() as $filter) {
$orm = $filter->toSql($orm);
}