Server IP : 192.64.112.168 / Your IP : 3.145.37.211 Web Server : Apache System : Linux nc-ph-2300-85.bluforrest.com 4.18.0-513.9.1.el8_9.x86_64 #1 SMP Sat Dec 2 05:23:44 EST 2023 x86_64 User : expressoneac ( 1128) PHP Version : 8.0.30 Disable Function : exec,passthru,shell_exec,system MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /home/expressoneac/www/wp-content/plugins/mailchimp-for-wp/includes/admin/ |
Upload File : |
<?php /** * Class MC4WP_Admin * * @ignore * @access private */ class MC4WP_Admin { /** * @var string The relative path to the main plugin file from the plugins dir */ protected $plugin_file; /** * @var MC4WP_Admin_Messages */ protected $messages; /** * @var MC4WP_Admin_Ads */ protected $ads; /** * @var MC4WP_Admin_Tools */ protected $tools; /** * @var MC4WP_Admin_Review_Notice */ protected $review_notice; /** * Constructor * * @param MC4WP_Admin_Tools $tools * @param MC4WP_Admin_Messages $messages */ public function __construct(MC4WP_Admin_Tools $tools, MC4WP_Admin_Messages $messages) { $this->tools = $tools; $this->messages = $messages; $this->plugin_file = plugin_basename(MC4WP_PLUGIN_FILE); $this->ads = new MC4WP_Admin_Ads(); $this->review_notice = new MC4WP_Admin_Review_Notice($tools); } /** * Registers all hooks */ public function add_hooks() { // Actions used globally throughout WP Admin add_action('admin_menu', array( $this, 'build_menu' )); add_action('admin_init', array( $this, 'initialize' )); add_action('current_screen', array( $this, 'customize_admin_texts' )); add_action('wp_dashboard_setup', array( $this, 'register_dashboard_widgets' )); add_action('mc4wp_admin_empty_lists_cache', array( $this, 'renew_lists_cache' )); add_action('mc4wp_admin_empty_debug_log', array( $this, 'empty_debug_log' )); add_action('admin_notices', array( $this, 'show_api_key_notice' )); add_action('mc4wp_admin_dismiss_api_key_notice', array( $this, 'dismiss_api_key_notice' )); add_action('admin_enqueue_scripts', array( $this, 'enqueue_assets' )); $this->ads->add_hooks(); $this->messages->add_hooks(); $this->review_notice->add_hooks(); } /** * Initializes various stuff used in WP Admin * * - Registers settings */ public function initialize() { // register settings register_setting('mc4wp_settings', 'mc4wp', array( $this, 'save_general_settings' )); // Load upgrader $this->init_upgrade_routines(); // listen for custom actions $this->listen_for_actions(); } /** * Listen for `_mc4wp_action` requests */ public function listen_for_actions() { // do nothing if _mc4wp_action was not in the request parameters if (! isset($_REQUEST['_mc4wp_action'])) { return; } // check if user is authorized if (! $this->tools->is_user_authorized()) { return; } // verify nonce if (! isset($_REQUEST['_wpnonce']) || false === wp_verify_nonce($_REQUEST['_wpnonce'], '_mc4wp_action')) { wp_nonce_ays('_mc4wp_action'); exit; } $action = (string) $_REQUEST['_mc4wp_action']; /** * Allows you to hook into requests containing `_mc4wp_action` => action name. * * The dynamic portion of the hook name, `$action`, refers to the action name. * * By the time this hook is fired, the user is already authorized. After processing all the registered hooks, * the request is redirected back to the referring URL. * * @since 3.0 */ do_action('mc4wp_admin_' . $action); // redirect back to where we came from (to prevent double submit) if (isset($_POST['_redirect_to'])) { $redirect_url = $_POST['_redirect_to']; } elseif (isset($_GET['_redirect_to'])) { $redirect_url = $_GET['_redirect_to']; } else { $redirect_url = remove_query_arg('_mc4wp_action'); } wp_safe_redirect($redirect_url); exit; } /** * Register dashboard widgets */ public function register_dashboard_widgets() { if (! $this->tools->is_user_authorized()) { return; } /** * Setup dashboard widget, users are authorized by now. * * Use this hook to register your own dashboard widgets for users with the required capability. * * @since 3.0 * @ignore */ do_action('mc4wp_dashboard_setup'); } /** * Upgrade routine */ private function init_upgrade_routines() { // upgrade routine for upgrade routine.... $previous_version = get_option('mc4wp_lite_version', 0); if ($previous_version) { delete_option('mc4wp_lite_version'); update_option('mc4wp_version', $previous_version); } $previous_version = get_option('mc4wp_version', 0); // Ran upgrade routines before? if (empty($previous_version)) { update_option('mc4wp_version', MC4WP_VERSION); // if we have at least one form, we're going to run upgrade routine for v3 => v4 anyway. $posts = get_posts( array( 'post_type' => 'mc4wp-form', 'posts_per_page' => 1, ) ); if (empty($posts)) { return; } $previous_version = '3.9'; } // This means we're good! if (version_compare($previous_version, MC4WP_VERSION, '>=')) { return; } define('MC4WP_DOING_UPGRADE', true); $upgrade_routines = new MC4WP_Upgrade_Routines($previous_version, MC4WP_VERSION, __DIR__ . '/migrations'); $upgrade_routines->run(); update_option('mc4wp_version', MC4WP_VERSION); } /** * Renew Mailchimp lists cache */ public function renew_lists_cache() { // try getting new lists to fill cache again $mailchimp = new MC4WP_MailChimp(); $lists = $mailchimp->refresh_lists(); if (! empty($lists)) { $this->messages->flash(esc_html__('Success! The cached configuration for your Mailchimp lists has been renewed.', 'mailchimp-for-wp')); } } /** * Customize texts throughout WP Admin */ public function customize_admin_texts() { $texts = new MC4WP_Admin_Texts($this->plugin_file); $texts->add_hooks(); } /** * Validates the General settings * @param array $settings * @return array */ public function save_general_settings(array $settings) { $current = mc4wp_get_options(); // merge with current settings to allow passing partial arrays to this method $settings = array_merge($current, $settings); // Make sure not to use obfuscated key if (strpos($settings['api_key'], '*') !== false) { $settings['api_key'] = $current['api_key']; } // Sanitize API key $settings['api_key'] = sanitize_text_field($settings['api_key']); // if API key changed, empty Mailchimp cache if ($settings['api_key'] !== $current['api_key']) { delete_transient('mc4wp_mailchimp_lists'); } /** * Runs right before general settings are saved. * * @param array $settings The updated settings array * @param array $current The old settings array */ do_action('mc4wp_save_settings', $settings, $current); return $settings; } /** * Load scripts and stylesheet on Mailchimp for WP Admin pages */ public function enqueue_assets() { if (! $this->tools->on_plugin_page()) { return; } $opts = mc4wp_get_options(); $page = $this->tools->get_plugin_page(); $mailchimp = new MC4WP_MailChimp(); // css wp_register_style('mc4wp-admin', mc4wp_plugin_url('assets/css/admin.css'), array(), MC4WP_VERSION); wp_enqueue_style('mc4wp-admin'); // js wp_register_script('mc4wp-admin', mc4wp_plugin_url('assets/js/admin.js'), array(), MC4WP_VERSION, true); wp_enqueue_script('mc4wp-admin'); $connected = ! empty($opts['api_key']); $mailchimp_lists = $connected ? $mailchimp->get_lists() : array(); wp_localize_script( 'mc4wp-admin', 'mc4wp_vars', array( 'ajaxurl' => admin_url('admin-ajax.php'), 'nonce' => wp_create_nonce('mc4wp-ajax'), 'mailchimp' => array( 'api_connected' => $connected, 'lists' => $mailchimp_lists, ), 'countries' => MC4WP_Tools::get_countries(), 'i18n' => array( 'invalid_api_key' => __('The given value does not look like a valid Mailchimp API key.', 'mailchimp-for-wp'), 'pro_only' => __('This is a premium feature. Please upgrade to Mailchimp for WordPress Premium to be able to use it.', 'mailchimp-for-wp'), 'renew_mailchimp_lists' => __('Renew Mailchimp audiences', 'mailchimp-for-wp'), 'fetching_mailchimp_lists' => __('Fetching Mailchimp audiences', 'mailchimp-for-wp'), 'fetching_mailchimp_lists_done' => __('Done! Mailchimp audiences renewed.', 'mailchimp-for-wp'), 'fetching_mailchimp_lists_error' => __('Failed to renew your audiences. An error occured.', 'mailchimp-for-wp'), ), ) ); /** * Hook to enqueue your own custom assets on the Mailchimp for WordPress setting pages. * * @since 3.0 * * @param string $suffix * @param string $page */ do_action('mc4wp_admin_enqueue_assets', '', $page); } /** * Register the setting pages and their menu items */ public function build_menu() { $required_cap = $this->tools->get_required_capability(); $menu_items = array( array( 'title' => esc_html__('Mailchimp API Settings', 'mailchimp-for-wp'), 'text' => 'Mailchimp', 'slug' => '', 'callback' => array( $this, 'show_generals_setting_page' ), 'position' => 0, ), array( 'title' => esc_html__('Other Settings', 'mailchimp-for-wp'), 'text' => esc_html__('Other', 'mailchimp-for-wp'), 'slug' => 'other', 'callback' => array( $this, 'show_other_setting_page' ), 'position' => 90, ), ); /** * Filters the menu items to appear under the main menu item. * * To add your own item, add an associative array in the following format. * * $menu_items[] = array( * 'title' => 'Page title', * 'text' => 'Menu text', * 'slug' => 'Page slug', * 'callback' => 'my_page_function', * 'position' => 50 * ); * * @param array $menu_items * @since 3.0 */ $menu_items = (array) apply_filters('mc4wp_admin_menu_items', $menu_items); // add top menu item $icon = file_get_contents(MC4WP_PLUGIN_DIR . '/assets/img/icon.svg'); add_menu_page('Mailchimp for WP', 'MC4WP', $required_cap, 'mailchimp-for-wp', array( $this, 'show_generals_setting_page' ), 'data:image/svg+xml;base64,' . base64_encode($icon), '99.68491'); // sort submenu items by 'position' usort($menu_items, array( $this, 'sort_menu_items_by_position' )); // add sub-menu items foreach ($menu_items as $item) { $this->add_menu_item($item); } } /** * @param array $item */ public function add_menu_item(array $item) { // generate menu slug $slug = 'mailchimp-for-wp'; if (! empty($item['slug'])) { $slug .= '-' . $item['slug']; } // provide some defaults $parent_slug = ! empty($item['parent_slug']) ? $item['parent_slug'] : 'mailchimp-for-wp'; $capability = ! empty($item['capability']) ? $item['capability'] : $this->tools->get_required_capability(); // register page $hook = add_submenu_page($parent_slug, $item['title'] . ' - Mailchimp for WordPress', $item['text'], $capability, $slug, $item['callback']); // register callback for loading this page, if given if (array_key_exists('load_callback', $item)) { add_action('load-' . $hook, $item['load_callback']); } } /** * Show the API Settings page */ public function show_generals_setting_page() { $opts = mc4wp_get_options(); $api_key = mc4wp_get_api_key(); $lists = array(); $connected = ! empty($api_key); if ($connected) { try { $connected = $this->get_api()->is_connected(); $mailchimp = new MC4WP_MailChimp(); $lists = $mailchimp->get_lists(); } catch (MC4WP_API_Connection_Exception $e) { $message = sprintf('<strong>%s</strong> %s %s ', esc_html__('Error connecting to Mailchimp:', 'mailchimp-for-wp'), $e->getCode(), $e->getMessage()); if (is_object($e->response_data) && ! empty($e->response_data->ref_no)) { $message .= '<br />' . sprintf(esc_html__('Looks like your server is blocked by Mailchimp\'s firewall. Please contact Mailchimp support and include the following reference number: %s', 'mailchimp-for-wp'), $e->response_data->ref_no); } $message .= '<br /><br />' . sprintf('<a href="%s">' . esc_html__('Here\'s some info on solving common connectivity issues.', 'mailchimp-for-wp') . '</a>', 'https://www.mc4wp.com/kb/solving-connectivity-issues/#utm_source=wp-plugin&utm_medium=mailchimp-for-wp&utm_campaign=settings-notice'); $this->messages->flash($message, 'error'); $connected = false; } catch (MC4WP_API_Exception $e) { $message = sprintf('<strong>%s</strong><br /> %s', esc_html__('Mailchimp returned the following error:', 'mailchimp-for-wp'), nl2br((string) $e)); $this->messages->flash($message, 'error'); $connected = false; } } $obfuscated_api_key = mc4wp_obfuscate_string($api_key); $is_procaptcha_configured = MC4WP_Procaptcha::get_instance()->is_enabled(); require MC4WP_PLUGIN_DIR . '/includes/views/general-settings.php'; } /** * Show the Other Settings page */ public function show_other_setting_page() { $opts = mc4wp_get_options(); $log = $this->get_log(); $log_reader = new MC4WP_Debug_Log_Reader($log->file); require MC4WP_PLUGIN_DIR . '/includes/views/other-settings.php'; } /** * @param $a * @param $b * * @return int */ public function sort_menu_items_by_position($a, $b) { $pos_a = isset($a['position']) ? $a['position'] : 80; $pos_b = isset($b['position']) ? $b['position'] : 90; return $pos_a < $pos_b ? -1 : 1; } /** * Empties the log file */ public function empty_debug_log() { $log = $this->get_log(); file_put_contents($log->file, ''); $this->messages->flash(esc_html__('Log successfully emptied.', 'mailchimp-for-wp')); } /** * Shows a notice when API key is not set. */ public function show_api_key_notice() { // don't show if on settings page already if ($this->tools->on_plugin_page('')) { return; } // only show to user with proper permissions if (! $this->tools->is_user_authorized()) { return; } // don't show if dismissed if (get_transient('mc4wp_api_key_notice_dismissed')) { return; } // don't show if api key is set already $api_key = mc4wp_get_api_key(); if (! empty($api_key)) { return; } echo '<div class="notice notice-warning mc4wp-is-dismissible">'; echo '<p>', sprintf(wp_kses(__('To get started with Mailchimp for WordPress, please <a href="%s">enter your Mailchimp API key on the settings page of the plugin</a>.', 'mailchimp-for-wp'), array( 'a' => array( 'href' => array() ) )), admin_url('admin.php?page=mailchimp-for-wp')), '</p>'; echo '<form method="post">'; wp_nonce_field('_mc4wp_action', '_wpnonce'); echo '<input type="hidden" name="_mc4wp_action" value="dismiss_api_key_notice" />'; echo '<button type="submit" class="notice-dismiss"><span class="screen-reader-text">Dismiss this notice.</span></button>'; echo '</form>'; echo '</div>'; } /** * Dismisses the API key notice for 1 week */ public function dismiss_api_key_notice() { set_transient('mc4wp_api_key_notice_dismissed', 1, 3600 * 24 * 7); } /** * @return MC4WP_Debug_Log */ protected function get_log() { return mc4wp('log'); } /** * @return MC4WP_API_V3 */ protected function get_api() { return mc4wp('api'); } }