File "Settings.php"
Full Path: /home/warrior1/public_html/languages/wp-content-20241001222009/plugins/mailpoet/lib/AdminPages/Pages/Settings.php
File size: 3.52 KB
MIME-type: text/x-php
Charset: utf-8
<?php
namespace MailPoet\AdminPages\Pages;
if (!defined('ABSPATH')) exit;
use MailPoet\AdminPages\PageRenderer;
use MailPoet\Config\Installer;
use MailPoet\Config\ServicesChecker;
use MailPoet\Segments\SegmentsSimpleListRepository;
use MailPoet\Services\AuthorizedSenderDomainController;
use MailPoet\Services\Bridge;
use MailPoet\Settings\Hosts;
use MailPoet\Settings\Pages;
use MailPoet\Settings\SettingsController;
use MailPoet\Subscription\Captcha;
use MailPoet\WP\Functions as WPFunctions;
use MailPoet\WP\Notice as WPNotice;
class Settings {
/** @var PageRenderer */
private $pageRenderer;
/** @var SettingsController */
private $settings;
/** @var WPFunctions */
private $wp;
/** @var ServicesChecker */
private $servicesChecker;
/** @var Captcha */
private $captcha;
/** @var SegmentsSimpleListRepository */
private $segmentsListRepository;
/** @var Bridge */
private $bridge;
/** @var AuthorizedSenderDomainController */
private $senderDomainController;
public function __construct(
PageRenderer $pageRenderer,
SettingsController $settings,
WPFunctions $wp,
ServicesChecker $servicesChecker,
Captcha $captcha,
SegmentsSimpleListRepository $segmentsListRepository,
Bridge $bridge,
AuthorizedSenderDomainController $senderDomainController
) {
$this->pageRenderer = $pageRenderer;
$this->settings = $settings;
$this->wp = $wp;
$this->servicesChecker = $servicesChecker;
$this->captcha = $captcha;
$this->segmentsListRepository = $segmentsListRepository;
$this->bridge = $bridge;
$this->senderDomainController = $senderDomainController;
}
public function render() {
$settings = $this->settings->getAll();
$premiumKeyValid = $this->servicesChecker->isPremiumKeyValid(false);
// force MSS key check even if the method isn't active
$mpApiKeyValid = $this->servicesChecker->isMailPoetAPIKeyValid(false, true);
$data = [
'settings' => $settings,
'segments' => $this->segmentsListRepository->getListWithSubscribedSubscribersCounts(),
'premium_key_valid' => !empty($premiumKeyValid),
'mss_key_valid' => !empty($mpApiKeyValid),
'pages' => Pages::getAll(),
'current_user' => $this->wp->wpGetCurrentUser(),
'is_members_plugin_active' => $this->wp->isPluginActive('members/members.php'),
'hosts' => [
'web' => Hosts::getWebHosts(),
'smtp' => Hosts::getSMTPHosts(),
],
'paths' => [
'root' => ABSPATH,
'plugin' => dirname(dirname(dirname(__DIR__))),
],
'built_in_captcha_supported' => $this->captcha->isSupported(),
];
$data['authorized_emails'] = [];
$data['verified_sender_domains'] = [];
$data['all_sender_domains'] = [];
if ($this->bridge->isMailpoetSendingServiceEnabled() && $mpApiKeyValid) {
$data['authorized_emails'] = $this->bridge->getAuthorizedEmailAddresses();
$data['verified_sender_domains'] = $this->senderDomainController->getVerifiedSenderDomains();
$data['all_sender_domains'] = $this->senderDomainController->getAllSenderDomains();
}
$data = array_merge($data, Installer::getPremiumStatus());
if (isset($_GET['enable-customizer-notice'])) {
$notice = new WPNotice(WPNotice::TYPE_ERROR, _x(
'You need to have WooCommerce active to access the MailPoet email customizer for WooCommerce.',
'Notice in Settings when WooCommerce is not enabled',
'mailpoet'
));
$notice->displayWPNotice();
}
$this->pageRenderer->displayPage('settings.html', $data);
}
}