Remove dynamic segments services that are no longer needed

[MAILPOET-3164]
This commit is contained in:
Rostislav Wolny
2021-01-20 16:14:58 +01:00
committed by Veljko V
parent b7914a3ff6
commit 9868f5cc21
9 changed files with 0 additions and 482 deletions

View File

@@ -1,48 +0,0 @@
<?php
namespace MailPoet\DynamicSegments\FreePluginConnectors;
use MailPoet\DynamicSegments\Persistence\Loading\Loader;
use MailPoet\DynamicSegments\Persistence\Loading\SubscribersCount;
class AddToNewslettersSegments {
/** @var Loader */
private $loader;
/** @var SubscribersCount */
private $subscribersCountLoader;
public function __construct(Loader $loader, SubscribersCount $subscribersCountLoader) {
$this->loader = $loader;
$this->subscribersCountLoader = $subscribersCountLoader;
}
/**
* @param array $initialSegments
*
* @return array
*/
public function add(array $initialSegments) {
$dynamicSegments = $this->getListings();
return array_merge($initialSegments, $dynamicSegments);
}
private function getListings() {
$dynamicSegments = $this->loader->load();
return $this->buildResult($dynamicSegments);
}
private function buildResult($dynamicSegments) {
$result = [];
foreach ($dynamicSegments as $dynamicSegment) {
$result[] = [
'id' => $dynamicSegment->id,
'name' => $dynamicSegment->name,
'subscribers' => $this->subscribersCountLoader->getSubscribersCount($dynamicSegment),
'deleted_at' => $dynamicSegment->deletedAt,
];
}
return $result;
}
}

View File

@@ -1,34 +0,0 @@
<?php
namespace MailPoet\DynamicSegments\Persistence\Loading;
use MailPoet\DynamicSegments\Mappers\DBMapper;
use MailPoet\Models\DynamicSegment;
use MailPoet\Models\DynamicSegmentFilter;
class Loader {
/** @var DBMapper */
private $mapper;
public function __construct(DBMapper $mapper) {
$this->mapper = $mapper;
}
/**
* @return DynamicSegment[]
*/
public 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);
}
}

View File

@@ -1,38 +0,0 @@
<?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 $dynamicSegment
*
* @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);
}
$orm->where(MP_SUBSCRIBERS_TABLE . '.status', Subscriber::STATUS_SUBSCRIBED);
return $orm->findOne()->cnt;
}
}

View File

@@ -1,43 +0,0 @@
<?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 SubscribersIds {
/** @var RequirementsChecker */
private $requirementsChecker;
public function __construct(RequirementsChecker $requirementsChecker = null) {
if (!$requirementsChecker) {
$requirementsChecker = new RequirementsChecker(new WooCommerceHelper());
}
$this->requirementsChecker = $requirementsChecker;
}
/**
* Finds subscribers in a dynamic segment and returns their ids.
*
* @param DynamicSegment $dynamicSegment
* @param array $limitToSubscribersIds If passed the result will be limited only to ids within this array
*
* @return Subscriber[]
*/
public function load(DynamicSegment $dynamicSegment, $limitToSubscribersIds = null) {
$orm = Subscriber::selectExpr(Subscriber::$_table . '.id');
if ($this->requirementsChecker->shouldSkipSegment($dynamicSegment)) {
return [];
}
foreach ($dynamicSegment->getFilters() as $filter) {
$orm = $filter->toSql($orm);
}
if ($limitToSubscribersIds) {
$orm->whereIn(Subscriber::$_table . '.id', $limitToSubscribersIds);
}
return $orm->findMany();
}
}