Add Settings page class
[MAILPOET-2200]
This commit is contained in:
committed by
M. Shull
parent
073b88979e
commit
3c87713830
124
lib/AdminPages/Pages/Settings.php
Normal file
124
lib/AdminPages/Pages/Settings.php
Normal file
@ -0,0 +1,124 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace MailPoet\AdminPages\Pages;
|
||||||
|
|
||||||
|
use MailPoet\AdminPages\PageRenderer;
|
||||||
|
use MailPoet\Config\Installer;
|
||||||
|
use MailPoet\Config\ServicesChecker;
|
||||||
|
use MailPoet\Cron\CronTrigger;
|
||||||
|
use MailPoet\Features\FeaturesController;
|
||||||
|
use MailPoet\Models\Segment;
|
||||||
|
use MailPoet\Models\Subscriber;
|
||||||
|
use MailPoet\Services\Bridge;
|
||||||
|
use MailPoet\Settings\Hosts;
|
||||||
|
use MailPoet\Settings\Pages;
|
||||||
|
use MailPoet\Settings\SettingsController;
|
||||||
|
use MailPoet\Util\Installation;
|
||||||
|
use MailPoet\Util\License\License;
|
||||||
|
use MailPoet\WooCommerce\Helper as WooCommerceHelper;
|
||||||
|
use MailPoet\WP\Functions as WPFunctions;
|
||||||
|
|
||||||
|
if (!defined('ABSPATH')) exit;
|
||||||
|
|
||||||
|
class Settings {
|
||||||
|
/** @var PageRenderer */
|
||||||
|
private $page_renderer;
|
||||||
|
|
||||||
|
/** @var SettingsController */
|
||||||
|
private $settings;
|
||||||
|
|
||||||
|
/** @var WooCommerceHelper */
|
||||||
|
private $woocommerce_helper;
|
||||||
|
|
||||||
|
/** @var WPFunctions */
|
||||||
|
private $wp;
|
||||||
|
|
||||||
|
/** @var ServicesChecker */
|
||||||
|
private $services_checker;
|
||||||
|
|
||||||
|
/** @var FeaturesController */
|
||||||
|
private $features_controller;
|
||||||
|
|
||||||
|
/** @var Installation */
|
||||||
|
private $installation;
|
||||||
|
|
||||||
|
function __construct(
|
||||||
|
PageRenderer $page_renderer,
|
||||||
|
SettingsController $settings,
|
||||||
|
WooCommerceHelper $woocommerce_helper,
|
||||||
|
WPFunctions $wp,
|
||||||
|
ServicesChecker $services_checker,
|
||||||
|
FeaturesController $features_controller,
|
||||||
|
Installation $installation
|
||||||
|
) {
|
||||||
|
$this->page_renderer = $page_renderer;
|
||||||
|
$this->settings = $settings;
|
||||||
|
$this->woocommerce_helper = $woocommerce_helper;
|
||||||
|
$this->wp = $wp;
|
||||||
|
$this->services_checker = $services_checker;
|
||||||
|
$this->features_controller = $features_controller;
|
||||||
|
$this->installation = $installation;
|
||||||
|
}
|
||||||
|
|
||||||
|
function render() {
|
||||||
|
$settings = $this->settings->getAll();
|
||||||
|
$flags = $this->getFlags();
|
||||||
|
|
||||||
|
// force MSS key check even if the method isn't active
|
||||||
|
$mp_api_key_valid = $this->services_checker->isMailPoetAPIKeyValid(false, true);
|
||||||
|
|
||||||
|
$data = [
|
||||||
|
'settings' => $settings,
|
||||||
|
'segments' => Segment::getSegmentsWithSubscriberCount(),
|
||||||
|
'cron_trigger' => CronTrigger::getAvailableMethods(),
|
||||||
|
'total_subscribers' => Subscriber::getTotalSubscribers(),
|
||||||
|
'premium_plugin_active' => License::getLicense(),
|
||||||
|
'premium_key_valid' => !empty($this->premium_key_valid),
|
||||||
|
'mss_active' => Bridge::isMPSendingServiceEnabled(),
|
||||||
|
'mss_key_valid' => !empty($mp_api_key_valid),
|
||||||
|
'members_plugin_active' => $this->wp->isPluginActive('members/members.php'),
|
||||||
|
'pages' => Pages::getAll(),
|
||||||
|
'flags' => $flags,
|
||||||
|
'current_user' => $this->wp->wpGetCurrentUser(),
|
||||||
|
'linux_cron_path' => dirname(dirname(__DIR__)),
|
||||||
|
'is_woocommerce_active' => $this->woocommerce_helper->isWooCommerceActive(),
|
||||||
|
'display_revenues' => $this->features_controller->isSupported(FeaturesController::FEATURE_DISPLAY_WOOCOMMERCE_REVENUES),
|
||||||
|
'ABSPATH' => ABSPATH,
|
||||||
|
'hosts' => [
|
||||||
|
'web' => Hosts::getWebHosts(),
|
||||||
|
'smtp' => Hosts::getSMTPHosts(),
|
||||||
|
],
|
||||||
|
];
|
||||||
|
|
||||||
|
$data['is_new_user'] = $this->installation->isNewInstallation();
|
||||||
|
|
||||||
|
$data = array_merge($data, Installer::getPremiumStatus());
|
||||||
|
|
||||||
|
$this->page_renderer->displayPage('settings.html', $data);
|
||||||
|
}
|
||||||
|
|
||||||
|
private function getFlags() {
|
||||||
|
// flags (available features on WP install)
|
||||||
|
$flags = [];
|
||||||
|
if ($this->wp->isMultisite()) {
|
||||||
|
// get multisite registration option
|
||||||
|
$registration = $this->wp->applyFilters(
|
||||||
|
'wpmu_registration_enabled',
|
||||||
|
$this->wp->getSiteOption('registration', 'all')
|
||||||
|
);
|
||||||
|
|
||||||
|
// check if users can register
|
||||||
|
$flags['registration_enabled'] =
|
||||||
|
!(in_array($registration, [
|
||||||
|
'none',
|
||||||
|
'blog',
|
||||||
|
]));
|
||||||
|
} else {
|
||||||
|
// check if users can register
|
||||||
|
$flags['registration_enabled'] =
|
||||||
|
(bool)$this->wp->getOption('users_can_register', false);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $flags;
|
||||||
|
}
|
||||||
|
}
|
@ -5,9 +5,9 @@ namespace MailPoet\Config;
|
|||||||
use Carbon\Carbon;
|
use Carbon\Carbon;
|
||||||
use MailPoet\AdminPages\PageRenderer;
|
use MailPoet\AdminPages\PageRenderer;
|
||||||
use MailPoet\AdminPages\Pages\Newsletters;
|
use MailPoet\AdminPages\Pages\Newsletters;
|
||||||
|
use MailPoet\AdminPages\Pages\Settings;
|
||||||
use MailPoet\AdminPages\Pages\WelcomeWizard;
|
use MailPoet\AdminPages\Pages\WelcomeWizard;
|
||||||
use MailPoet\Cron\CronHelper;
|
use MailPoet\Cron\CronHelper;
|
||||||
use MailPoet\Cron\CronTrigger;
|
|
||||||
use MailPoet\DI\ContainerWrapper;
|
use MailPoet\DI\ContainerWrapper;
|
||||||
use MailPoet\Features\FeaturesController;
|
use MailPoet\Features\FeaturesController;
|
||||||
use MailPoet\Form\Block;
|
use MailPoet\Form\Block;
|
||||||
@ -23,7 +23,6 @@ use MailPoet\Models\Subscriber;
|
|||||||
use MailPoet\Newsletter\Shortcodes\ShortcodesHelper;
|
use MailPoet\Newsletter\Shortcodes\ShortcodesHelper;
|
||||||
use MailPoet\Router\Endpoints\CronDaemon;
|
use MailPoet\Router\Endpoints\CronDaemon;
|
||||||
use MailPoet\Services\Bridge;
|
use MailPoet\Services\Bridge;
|
||||||
use MailPoet\Settings\Hosts;
|
|
||||||
use MailPoet\Settings\Pages;
|
use MailPoet\Settings\Pages;
|
||||||
use MailPoet\Settings\SettingsController;
|
use MailPoet\Settings\SettingsController;
|
||||||
use MailPoet\Settings\UserFlagsController;
|
use MailPoet\Settings\UserFlagsController;
|
||||||
@ -33,7 +32,6 @@ use MailPoet\Tasks\State;
|
|||||||
use MailPoet\Util\Installation;
|
use MailPoet\Util\Installation;
|
||||||
use MailPoet\Util\License\Features\Subscribers as SubscribersFeature;
|
use MailPoet\Util\License\Features\Subscribers as SubscribersFeature;
|
||||||
use MailPoet\Util\License\License;
|
use MailPoet\Util\License\License;
|
||||||
use MailPoet\WooCommerce\Helper as WooCommerceHelper;
|
|
||||||
use MailPoet\WP\Readme;
|
use MailPoet\WP\Readme;
|
||||||
use MailPoet\WP\Functions as WPFunctions;
|
use MailPoet\WP\Functions as WPFunctions;
|
||||||
|
|
||||||
@ -42,9 +40,6 @@ if (!defined('ABSPATH')) exit;
|
|||||||
class Menu {
|
class Menu {
|
||||||
const MAIN_PAGE_SLUG = 'mailpoet-newsletters';
|
const MAIN_PAGE_SLUG = 'mailpoet-newsletters';
|
||||||
|
|
||||||
/** @var WooCommerceHelper */
|
|
||||||
private $woocommerce_helper;
|
|
||||||
|
|
||||||
/** @var Renderer */
|
/** @var Renderer */
|
||||||
public $renderer;
|
public $renderer;
|
||||||
public $mp_api_key_valid;
|
public $mp_api_key_valid;
|
||||||
@ -84,7 +79,6 @@ class Menu {
|
|||||||
SettingsController $settings,
|
SettingsController $settings,
|
||||||
FeaturesController $featuresController,
|
FeaturesController $featuresController,
|
||||||
WPFunctions $wp,
|
WPFunctions $wp,
|
||||||
WooCommerceHelper $woocommerce_helper,
|
|
||||||
ServicesChecker $servicesChecker,
|
ServicesChecker $servicesChecker,
|
||||||
UserFlagsController $user_flags,
|
UserFlagsController $user_flags,
|
||||||
PageRenderer $page_renderer,
|
PageRenderer $page_renderer,
|
||||||
@ -96,7 +90,6 @@ class Menu {
|
|||||||
$this->wp = $wp;
|
$this->wp = $wp;
|
||||||
$this->settings = $settings;
|
$this->settings = $settings;
|
||||||
$this->features_controller = $featuresController;
|
$this->features_controller = $featuresController;
|
||||||
$this->woocommerce_helper = $woocommerce_helper;
|
|
||||||
$this->servicesChecker = $servicesChecker;
|
$this->servicesChecker = $servicesChecker;
|
||||||
$this->user_flags = $user_flags;
|
$this->user_flags = $user_flags;
|
||||||
$this->page_renderer = $page_renderer;
|
$this->page_renderer = $page_renderer;
|
||||||
@ -522,45 +515,10 @@ class Menu {
|
|||||||
$this->page_renderer->displayPage('premium.html', $data);
|
$this->page_renderer->displayPage('premium.html', $data);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
function settings() {
|
function settings() {
|
||||||
$settings = $this->settings->getAll();
|
$this->container->get(Settings::class)->render();
|
||||||
$flags = $this->_getFlags();
|
|
||||||
|
|
||||||
// force MSS key check even if the method isn't active
|
|
||||||
$mp_api_key_valid = $this->servicesChecker->isMailPoetAPIKeyValid(false, true);
|
|
||||||
|
|
||||||
$data = [
|
|
||||||
'settings' => $settings,
|
|
||||||
'segments' => Segment::getSegmentsWithSubscriberCount(),
|
|
||||||
'cron_trigger' => CronTrigger::getAvailableMethods(),
|
|
||||||
'total_subscribers' => Subscriber::getTotalSubscribers(),
|
|
||||||
'premium_plugin_active' => License::getLicense(),
|
|
||||||
'premium_key_valid' => !empty($this->premium_key_valid),
|
|
||||||
'mss_active' => Bridge::isMPSendingServiceEnabled(),
|
|
||||||
'mss_key_valid' => !empty($mp_api_key_valid),
|
|
||||||
'members_plugin_active' => $this->wp->isPluginActive('members/members.php'),
|
|
||||||
'pages' => Pages::getAll(),
|
|
||||||
'flags' => $flags,
|
|
||||||
'current_user' => $this->wp->wpGetCurrentUser(),
|
|
||||||
'linux_cron_path' => dirname(dirname(__DIR__)),
|
|
||||||
'is_woocommerce_active' => $this->woocommerce_helper->isWooCommerceActive(),
|
|
||||||
'display_revenues' => $this->features_controller->isSupported(FeaturesController::FEATURE_DISPLAY_WOOCOMMERCE_REVENUES),
|
|
||||||
'ABSPATH' => ABSPATH,
|
|
||||||
'hosts' => [
|
|
||||||
'web' => Hosts::getWebHosts(),
|
|
||||||
'smtp' => Hosts::getSMTPHosts(),
|
|
||||||
],
|
|
||||||
];
|
|
||||||
|
|
||||||
$data['is_new_user'] = $this->installation->isNewInstallation();
|
|
||||||
|
|
||||||
$data = array_merge($data, Installer::getPremiumStatus());
|
|
||||||
|
|
||||||
$this->page_renderer->displayPage('settings.html', $data);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
function help() {
|
function help() {
|
||||||
$tasks_state = new State();
|
$tasks_state = new State();
|
||||||
$system_info_data = Beacon::getData();
|
$system_info_data = Beacon::getData();
|
||||||
@ -593,32 +551,6 @@ class Menu {
|
|||||||
$this->page_renderer->displayPage('experimental-features.html', []);
|
$this->page_renderer->displayPage('experimental-features.html', []);
|
||||||
}
|
}
|
||||||
|
|
||||||
private function _getFlags() {
|
|
||||||
// flags (available features on WP install)
|
|
||||||
$flags = [];
|
|
||||||
|
|
||||||
if (is_multisite()) {
|
|
||||||
// get multisite registration option
|
|
||||||
$registration = $this->wp->applyFilters(
|
|
||||||
'wpmu_registration_enabled',
|
|
||||||
$this->wp->getSiteOption('registration', 'all')
|
|
||||||
);
|
|
||||||
|
|
||||||
// check if users can register
|
|
||||||
$flags['registration_enabled'] =
|
|
||||||
!(in_array($registration, [
|
|
||||||
'none',
|
|
||||||
'blog',
|
|
||||||
]));
|
|
||||||
} else {
|
|
||||||
// check if users can register
|
|
||||||
$flags['registration_enabled'] =
|
|
||||||
(bool)get_option('users_can_register', false);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $flags;
|
|
||||||
}
|
|
||||||
|
|
||||||
function subscribers() {
|
function subscribers() {
|
||||||
$data = [];
|
$data = [];
|
||||||
|
|
||||||
|
@ -31,6 +31,7 @@ class ContainerConfigurator implements IContainerConfigurator {
|
|||||||
// AdminPages
|
// AdminPages
|
||||||
$container->autowire(\MailPoet\AdminPages\PageRenderer::class);
|
$container->autowire(\MailPoet\AdminPages\PageRenderer::class);
|
||||||
$container->autowire(\MailPoet\AdminPages\Pages\Newsletters::class);
|
$container->autowire(\MailPoet\AdminPages\Pages\Newsletters::class);
|
||||||
|
$container->autowire(\MailPoet\AdminPages\Pages\Settings::class);
|
||||||
$container->autowire(\MailPoet\AdminPages\Pages\WelcomeWizard::class);
|
$container->autowire(\MailPoet\AdminPages\Pages\WelcomeWizard::class);
|
||||||
// Analytics
|
// Analytics
|
||||||
$container->autowire(\MailPoet\Analytics\Reporter::class)->setPublic(true);
|
$container->autowire(\MailPoet\Analytics\Reporter::class)->setPublic(true);
|
||||||
|
@ -7,12 +7,12 @@ use MailPoet\AdminPages\PageRenderer;
|
|||||||
use MailPoet\Config\AccessControl;
|
use MailPoet\Config\AccessControl;
|
||||||
use MailPoet\Config\Menu;
|
use MailPoet\Config\Menu;
|
||||||
use MailPoet\Config\ServicesChecker;
|
use MailPoet\Config\ServicesChecker;
|
||||||
|
use MailPoet\DI\ContainerWrapper;
|
||||||
use MailPoet\Features\FeaturesController;
|
use MailPoet\Features\FeaturesController;
|
||||||
use MailPoet\Listing\PageLimit;
|
use MailPoet\Listing\PageLimit;
|
||||||
use MailPoet\Settings\SettingsController;
|
use MailPoet\Settings\SettingsController;
|
||||||
use MailPoet\Settings\UserFlagsController;
|
use MailPoet\Settings\UserFlagsController;
|
||||||
use MailPoet\Util\Installation;
|
use MailPoet\Util\Installation;
|
||||||
use MailPoet\WooCommerce\Helper as WooCommerceHelper;
|
|
||||||
use MailPoet\WP\Functions as WPFunctions;
|
use MailPoet\WP\Functions as WPFunctions;
|
||||||
|
|
||||||
class MenuTest extends \MailPoetTest {
|
class MenuTest extends \MailPoetTest {
|
||||||
@ -97,12 +97,12 @@ class MenuTest extends \MailPoetTest {
|
|||||||
$settings,
|
$settings,
|
||||||
new FeaturesController(),
|
new FeaturesController(),
|
||||||
$wp,
|
$wp,
|
||||||
new WooCommerceHelper($wp),
|
|
||||||
new ServicesChecker,
|
new ServicesChecker,
|
||||||
new UserFlagsController,
|
new UserFlagsController,
|
||||||
$renderer,
|
$renderer,
|
||||||
new PageLimit($wp),
|
new PageLimit($wp),
|
||||||
new Installation($settings, $wp)
|
new Installation($settings, $wp),
|
||||||
|
ContainerWrapper::getInstance()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user