Refactor checking settings change into separate method

[MAILPOET-2079]
This commit is contained in:
Ján Mikláš
2019-05-21 15:02:31 +02:00
committed by M. Shull
parent a55d2fc69f
commit 54527ecfb4

View File

@ -40,17 +40,15 @@ class Settings extends APIEndpoint {
WPFunctions::get()->__('You have not specified any settings to be saved.', 'mailpoet'),
]);
} else {
$original_inactivation_interval = (int)$this->settings->get('deactivate_subscriber_after_inactive_days');
$old_settings = $this->settings->getAll();
// Will be uncommented on task [MAILPOET-1998]
// $signup_confirmation = $this->settings->get('signup_confirmation.enabled');
foreach ($settings as $name => $value) {
$this->settings->set($name, $value);
}
if (isset($settings['deactivate_subscriber_after_inactive_days'])
&& $original_inactivation_interval !== (int)$settings['deactivate_subscriber_after_inactive_days']
) {
$this->onInactiveSubscribersIntervalChange();
}
$this->onSettingsChange($old_settings, $this->settings->getAll());
$bridge = new Bridge();
$bridge->onSettingsSave($settings);
// Will be uncommented on task [MAILPOET-1998]
@ -61,6 +59,15 @@ class Settings extends APIEndpoint {
}
}
private function onSettingsChange($old_settings, $new_settings) {
// Recalculate inactive subscribers
$old_inactivation_interval = $old_settings['deactivate_subscriber_after_inactive_days'];
$new_inactivation_interval = $new_settings['deactivate_subscriber_after_inactive_days'];
if ($old_inactivation_interval !== $new_inactivation_interval) {
$this->onInactiveSubscribersIntervalChange();
}
}
private function onInactiveSubscribersIntervalChange() {
$task = ScheduledTask::where('type', InactiveSubscribers::TASK_TYPE)
->whereRaw('status = ?', [ScheduledTask::STATUS_SCHEDULED])