39 lines
1.0 KiB
PHP
39 lines
1.0 KiB
PHP
<?php
|
|
|
|
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 $requirementsChecker;
|
|
|
|
public function __construct(RequirementsChecker $requirementsChecker = null) {
|
|
if (!$requirementsChecker) {
|
|
$requirementsChecker = new RequirementsChecker(new WooCommerceHelper());
|
|
}
|
|
$this->requirementsChecker = $requirementsChecker;
|
|
}
|
|
|
|
/**
|
|
* @param DynamicSegment $dynamic_segment
|
|
*
|
|
* @return int
|
|
*/
|
|
public function getSubscribersCount(DynamicSegment $dynamicSegment) {
|
|
$orm = Subscriber::selectExpr('count(distinct ' . Subscriber::$_table . '.id) as cnt');
|
|
if ($this->requirementsChecker->shouldSkipSegment($dynamicSegment)) {
|
|
return 0;
|
|
}
|
|
foreach ($dynamicSegment->getFilters() as $filter) {
|
|
$orm = $filter->toSql($orm);
|
|
}
|
|
return $orm->findOne()->cnt;
|
|
}
|
|
|
|
}
|