Move dynamic segments from Premium plugin
[MAILPOET-2382]
This commit is contained in:
committed by
Jack Kitterhing
parent
0af9f09f50
commit
70a89b7939
35
lib/DynamicSegments/Persistence/Loading/Loader.php
Normal file
35
lib/DynamicSegments/Persistence/Loading/Loader.php
Normal file
@@ -0,0 +1,35 @@
|
||||
<?php
|
||||
|
||||
namespace MailPoet\Premium\DynamicSegments\Persistence\Loading;
|
||||
|
||||
use MailPoet\Premium\DynamicSegments\Mappers\DBMapper;
|
||||
use MailPoet\Premium\Models\DynamicSegment;
|
||||
use MailPoet\Premium\Models\DynamicSegmentFilter;
|
||||
|
||||
class Loader {
|
||||
|
||||
/** @var DBMapper */
|
||||
private $mapper;
|
||||
|
||||
public function __construct(DBMapper $mapper) {
|
||||
$this->mapper = $mapper;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return DynamicSegment[]
|
||||
*/
|
||||
function load() {
|
||||
$segments = DynamicSegment::findAll();
|
||||
return $this->loadFilters($segments);
|
||||
}
|
||||
|
||||
private function loadFilters(array $segments) {
|
||||
$ids = array_map(function($segment) {
|
||||
return $segment->id;
|
||||
}, $segments);
|
||||
$filters = DynamicSegmentFilter::getAllBySegmentIds($ids);
|
||||
|
||||
return $this->mapper->mapSegments($segments, $filters);
|
||||
}
|
||||
|
||||
}
|
@@ -0,0 +1,35 @@
|
||||
<?php
|
||||
|
||||
namespace MailPoet\Premium\DynamicSegments\Persistence\Loading;
|
||||
|
||||
use MailPoet\Premium\DynamicSegments\Mappers\DBMapper;
|
||||
use MailPoet\Premium\Models\DynamicSegment;
|
||||
|
||||
class SingleSegmentLoader {
|
||||
|
||||
/** @var DBMapper */
|
||||
private $mapper;
|
||||
|
||||
public function __construct(DBMapper $mapper) {
|
||||
$this->mapper = $mapper;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param string|int $segment_id
|
||||
* @return DynamicSegment
|
||||
*/
|
||||
function load($segment_id) {
|
||||
|
||||
$segment = DynamicSegment::findOne($segment_id);
|
||||
if (!$segment instanceof DynamicSegment) {
|
||||
throw new \InvalidArgumentException('Segment not found');
|
||||
}
|
||||
|
||||
$filters = $segment->dynamicSegmentFilters()->findMany();
|
||||
|
||||
return $this->mapper->mapSegment($segment, $filters);
|
||||
}
|
||||
|
||||
|
||||
|
||||
}
|
23
lib/DynamicSegments/Persistence/Loading/SubscribersCount.php
Normal file
23
lib/DynamicSegments/Persistence/Loading/SubscribersCount.php
Normal file
@@ -0,0 +1,23 @@
|
||||
<?php
|
||||
|
||||
namespace MailPoet\Premium\DynamicSegments\Persistence\Loading;
|
||||
|
||||
use MailPoet\Models\Subscriber;
|
||||
use MailPoet\Premium\Models\DynamicSegment;
|
||||
|
||||
class SubscribersCount {
|
||||
|
||||
/**
|
||||
* @param DynamicSegment $dynamic_segment
|
||||
*
|
||||
* @return int
|
||||
*/
|
||||
function getSubscribersCount(DynamicSegment $dynamic_segment) {
|
||||
$orm = Subscriber::selectExpr('count(distinct ' . Subscriber::$_table . '.id) as cnt');
|
||||
foreach ($dynamic_segment->getFilters() as $filter) {
|
||||
$orm = $filter->toSql($orm);
|
||||
}
|
||||
return $orm->findOne()->cnt;
|
||||
}
|
||||
|
||||
}
|
29
lib/DynamicSegments/Persistence/Loading/SubscribersIds.php
Normal file
29
lib/DynamicSegments/Persistence/Loading/SubscribersIds.php
Normal file
@@ -0,0 +1,29 @@
|
||||
<?php
|
||||
|
||||
namespace MailPoet\Premium\DynamicSegments\Persistence\Loading;
|
||||
|
||||
use MailPoet\Models\Subscriber;
|
||||
use MailPoet\Premium\Models\DynamicSegment;
|
||||
|
||||
class SubscribersIds {
|
||||
|
||||
/**
|
||||
* Finds subscribers in a dynamic segment and returns their ids.
|
||||
*
|
||||
* @param DynamicSegment $dynamic_segment
|
||||
* @param array $limit_to_subscribers_ids If passed the result will be limited only to ids within this array
|
||||
*
|
||||
* @return Subscriber[]
|
||||
*/
|
||||
function load(DynamicSegment $dynamic_segment, $limit_to_subscribers_ids = null) {
|
||||
$orm = Subscriber::selectExpr(Subscriber::$_table . '.id');
|
||||
foreach ($dynamic_segment->getFilters() as $filter) {
|
||||
$orm = $filter->toSql($orm);
|
||||
}
|
||||
if ($limit_to_subscribers_ids) {
|
||||
$orm->whereIn(Subscriber::$_table . '.id', $limit_to_subscribers_ids);
|
||||
}
|
||||
return $orm->findMany();
|
||||
}
|
||||
|
||||
}
|
Reference in New Issue
Block a user