Check requirements when counting subscribers
[MAILPOET-2486]
This commit is contained in:
committed by
Jack Kitterhing
parent
5c706aaacf
commit
4f1ef835dc
@@ -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);
|
||||
}
|
||||
|
Reference in New Issue
Block a user