Move MSS Activation to change handler
[MAILPOET-4061]
This commit is contained in:
committed by
Veljko V
parent
00f3e3787d
commit
5f5255f921
@@ -208,7 +208,7 @@ class Settings extends APIEndpoint {
|
|||||||
$oldSendingMethod = $oldSettings['mta_group'];
|
$oldSendingMethod = $oldSettings['mta_group'];
|
||||||
$newSendingMethod = $newSettings['mta_group'];
|
$newSendingMethod = $newSettings['mta_group'];
|
||||||
if (($oldSendingMethod !== $newSendingMethod) && ($newSendingMethod === 'mailpoet')) {
|
if (($oldSendingMethod !== $newSendingMethod) && ($newSendingMethod === 'mailpoet')) {
|
||||||
$this->onMSSActivate($newSettings);
|
$this->settingsChangeHandler->onMSSActivate($newSettings);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Sync WooCommerce Customers list
|
// Sync WooCommerce Customers list
|
||||||
@@ -227,23 +227,6 @@ class Settings extends APIEndpoint {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private function onMSSActivate($newSettings) {
|
|
||||||
// see mailpoet/assets/js/src/wizard/create_sender_settings.jsx:freeAddress
|
|
||||||
$domain = str_replace('www.', '', $_SERVER['HTTP_HOST']);
|
|
||||||
if (
|
|
||||||
isset($newSettings['sender']['address'])
|
|
||||||
&& !empty($newSettings['reply_to']['address'])
|
|
||||||
&& ($newSettings['sender']['address'] === ('wordpress@' . $domain))
|
|
||||||
) {
|
|
||||||
$sender = [
|
|
||||||
'name' => $newSettings['reply_to']['name'] ?? '',
|
|
||||||
'address' => $newSettings['reply_to']['address'],
|
|
||||||
];
|
|
||||||
$this->settings->set('sender', $sender);
|
|
||||||
$this->settings->set('reply_to', null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public function recalculateSubscribersCountsCache() {
|
public function recalculateSubscribersCountsCache() {
|
||||||
$segments = $this->segmentsRepository->findAll();
|
$segments = $this->segmentsRepository->findAll();
|
||||||
foreach ($segments as $segment) {
|
foreach ($segments as $segment) {
|
||||||
|
@@ -11,15 +11,18 @@ use MailPoetVendor\Carbon\Carbon;
|
|||||||
|
|
||||||
class SettingsChangeHandler {
|
class SettingsChangeHandler {
|
||||||
|
|
||||||
/**
|
/** @var ScheduledTasksRepository */
|
||||||
* @var ScheduledTasksRepository
|
|
||||||
*/
|
|
||||||
private $scheduledTasksRepository;
|
private $scheduledTasksRepository;
|
||||||
|
|
||||||
|
/** @var SettingsController */
|
||||||
|
private $settingsController;
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
ScheduledTasksRepository $scheduledTasksRepository
|
ScheduledTasksRepository $scheduledTasksRepository,
|
||||||
|
SettingsController $settingsController
|
||||||
) {
|
) {
|
||||||
$this->scheduledTasksRepository = $scheduledTasksRepository;
|
$this->scheduledTasksRepository = $scheduledTasksRepository;
|
||||||
|
$this->settingsController = $settingsController;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function onSubscribeOldWoocommerceCustomersChange(): void {
|
public function onSubscribeOldWoocommerceCustomersChange(): void {
|
||||||
@@ -50,6 +53,23 @@ class SettingsChangeHandler {
|
|||||||
$this->scheduledTasksRepository->flush();
|
$this->scheduledTasksRepository->flush();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function onMSSActivate($newSettings) {
|
||||||
|
// see mailpoet/assets/js/src/wizard/create_sender_settings.jsx:freeAddress
|
||||||
|
$domain = str_replace('www.', '', $_SERVER['HTTP_HOST']);
|
||||||
|
if (
|
||||||
|
isset($newSettings['sender']['address'])
|
||||||
|
&& !empty($newSettings['reply_to']['address'])
|
||||||
|
&& ($newSettings['sender']['address'] === ('wordpress@' . $domain))
|
||||||
|
) {
|
||||||
|
$sender = [
|
||||||
|
'name' => $newSettings['reply_to']['name'] ?? '',
|
||||||
|
'address' => $newSettings['reply_to']['address'],
|
||||||
|
];
|
||||||
|
$this->settingsController->set('sender', $sender);
|
||||||
|
$this->settingsController->set('reply_to', null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private function createScheduledTask(string $type): ScheduledTaskEntity {
|
private function createScheduledTask(string $type): ScheduledTaskEntity {
|
||||||
$task = new ScheduledTaskEntity();
|
$task = new ScheduledTaskEntity();
|
||||||
$task->setType($type);
|
$task->setType($type);
|
||||||
|
Reference in New Issue
Block a user