File Editor
Directories:
.. (Back)
OMAPI
assets
views
vue
Files:
optin-monster-wp-api.php
readme.txt
Create New File
Create
Edit File: optin-monster-wp-api.php
<?php /** * Plugin Name: OptinMonster * Plugin URI: https://optinmonster.com * Description: OptinMonster is the best WordPress popup builder plugin that helps you grow your email newsletter list and sales with email popups, exit intent popups, floating bars and more! * Author: OptinMonster Popup Builder Team * Author URI: https://optinmonster.com * Version: 2.16.7 * Text Domain: optin-monster-api * Domain Path: languages * * WC requires at least: 3.2 * WC tested up to: 9.3 * Requires at least: 4.7 * Requires PHP: 5.3 * Tested up to: 6.6 * * @package OMAPI * * OptinMonster is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 2 of the License, or * any later version. * * OptinMonster is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with OptinMonster. If not, see <https://www.gnu.org/licenses/>. */ // Exit if accessed directly. if ( ! defined( 'ABSPATH' ) ) { exit; } // Autoload the class files. spl_autoload_register( 'OMAPI::autoload' ); // Store base file location. define( 'OMAPI_FILE', __FILE__ ); /** * Main plugin class. * * @since 1.0.0 * * @package OMAPI * @author Thomas Griffin */ #[\AllowDynamicProperties] class OMAPI { /** * Holds the class object. * * @since 1.0.0 * * @var object */ public static $instance; /** * Plugin version, used for cache-busting of style and script file references. * * @since 1.0.0 * * @var string */ public $version = '2.16.7'; /** * The name of the plugin. * * @since 1.0.0 * * @var string */ public $plugin_name = 'OptinMonster'; /** * Unique plugin slug identifier. * * @since 1.0.0 * * @var string */ public $plugin_slug = 'optinmonster'; /** * Plugin file. * * @since 1.0.0 * * @var string */ public $file = __FILE__; /** * The assets base URL for this plugin. * * @var string */ public $url; /** * Defines the properties that can be autoloaded from classes. * * @since 2.11.2 * * @var array */ protected static $class_map = array( 'ajax' => 'OMAPI_Ajax', 'blocks' => 'OMAPI_Blocks', 'type' => 'OMAPI_Type', 'output' => 'OMAPI_Output', 'shortcode' => 'OMAPI_Shortcode', 'revenue' => 'OMAPI_RevenueAttribution', 'woocommerce' => 'OMAPI_WooCommerce', // @since 2.9.0 'wpforms' => 'OMAPI_WPForms', 'elementor' => 'OMAPI_Elementor', 'mailpoet' => 'OMAPI_MailPoet', 'edd' => 'OMAPI_EasyDigitalDownloads', 'memberpress' => 'OMAPI_MemberPress', 'rest_api' => 'OMAPI_RestApi', 'actions' => 'OMAPI_Actions', 'menu' => 'OMAPI_Menu', 'save' => 'OMAPI_Save', 'refresh' => 'OMAPI_Refresh', 'validate' => 'OMAPI_Validate', 'welcome' => 'OMAPI_Welcome', 'promos' => 'OMAPI_Promos', 'review' => 'OMAPI_Review', 'sites' => 'OMAPI_Sites', 'notifications' => 'OMAPI_Notifications', 'classicEditor' => 'OMAPI_ClassicEditor', // @since 2.10.0 'urls' => 'OMAPI_Urls', ); /** * Primary class constructor. * * @since 1.0.0 */ public function __construct() { // Load the plugin textdomain. add_action( 'plugins_loaded', array( $this, 'load_plugin_textdomain' ) ); // Early action for WooCommerce compatibility. add_action( 'before_woocommerce_init', 'OMAPI_WooCommerce::declare_hpos_compat' ); // Load the plugin widgets. add_action( 'widgets_init', array( $this, 'widgets' ) ); // Define Constants. add_action( 'init', array( $this, 'define_constants' ) ); // Load the plugin. add_action( 'init', array( $this, 'init' ) ); // Hide the unrelated admin notices. add_action( 'admin_print_scripts', array( $this, 'hide_unrelated_admin_notices' ) ); // PHP version check. add_action( 'admin_init', array( $this, 'check_php_version' ) ); // Filter the WooCommerce category/tag REST API responses. add_filter( 'woocommerce_rest_prepare_product_cat', 'OMAPI_WooCommerce::add_category_base_to_api_response' ); add_filter( 'woocommerce_rest_prepare_product_tag', 'OMAPI_WooCommerce::add_tag_base_to_api_response' ); } /** * Loads the plugin textdomain for translation. * * @since 1.0.0 */ public function load_plugin_textdomain() { $domain = 'optin-monster-api'; // phpcs:ignore WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedHooknameFound $locale = apply_filters( 'plugin_locale', get_locale(), $domain ); load_textdomain( $domain, WP_LANG_DIR . '/' . $domain . '/' . $domain . '-' . $locale . '.mo' ); load_plugin_textdomain( $domain, false, dirname( plugin_basename( __FILE__ ) ) . '/languages/' ); } /** * Registers the OptinMonster widgets. * * @since 1.0.0 */ public function widgets() { // To do: add widgets. register_widget( 'OMAPI_Widget' ); } /** * Set the OM constants. * * @since 2.0.2 */ public function define_constants() { $this->url = plugin_dir_url( __FILE__ ); do_action( 'optin_monster_before_define_constants', $this ); // Define necessary plugin constants. if ( ! defined( 'OPTINMONSTER_APP_URL' ) ) { define( 'OPTINMONSTER_APP_URL', 'https://app.optinmonster.com' ); } if ( ! defined( 'OPTINMONSTER_URL' ) ) { define( 'OPTINMONSTER_URL', 'https://optinmonster.com' ); } if ( ! defined( 'OPTINMONSTER_API_URL' ) ) { define( 'OPTINMONSTER_API_URL', 'https://api.omwpapi.com' ); } if ( ! defined( 'OPTINMONSTER_CDN_URL' ) ) { define( 'OPTINMONSTER_CDN_URL', is_admin() ? 'https://a.omwpapi.com' : 'https://a.omappapi.com' ); } if ( ! defined( 'OPTINMONSTER_VUE_ASSETS_URL' ) ) { define( 'OPTINMONSTER_VUE_ASSETS_URL', OPTINMONSTER_CDN_URL . '/app/wp-plugin/build' ); } if ( ! defined( 'OPTINMONSTER_VUE_ASSETS_PATH' ) ) { define( 'OPTINMONSTER_VUE_ASSETS_PATH', '' ); } if ( ! defined( 'OPTINMONSTER_APIJS_URL' ) ) { define( 'OPTINMONSTER_APIJS_URL', OPTINMONSTER_CDN_URL . '/app/js/api.min.js' ); } if ( ! defined( 'OPTINMONSTER_SHAREABLE_LINK' ) ) { define( 'OPTINMONSTER_SHAREABLE_LINK', 'https://app.monstercampaigns.com' ); } } /** * Loads the plugin into WordPress. * * @since 1.0.0 */ public function init() { // Load our global option. $this->load_option(); // Load global components. $this->load_global(); add_action( 'rest_api_init', array( $this, 'load_rest' ) ); // Load admin only components. if ( is_admin() ) { $this->load_admin(); } // Run hook once OptinMonster has been fully loaded. do_action( 'optin_monster_api_loaded' ); } /** * Sets our options if not found in the DB. * * @since 1.0.0 */ public function load_option() { // Check/set the plugin options. $option = get_option( 'optin_monster_api' ); if ( empty( $option ) ) { $option = self::default_options(); update_option( 'optin_monster_api', $option ); } $review = get_option( 'omapi_review' ); $review_installed = ! empty( $review['time'] ) && is_numeric( $review['time'] ); $review_dismissed = ! empty( $review['dismissed'] ); if ( ! $review_installed ) { $review = array( 'time' => time(), 'dismissed' => $review_dismissed, ); update_option( 'omapi_review', $review ); } // Create a connection token if one doesn't exist, and we're not already connected. $is_connected = ! empty( $option['api']['apikey'] ) && isset( $option['userId'] ) && 0 < absint( $option['userId'] ); if ( ! $is_connected && empty( $option['connectionToken'] ) ) { $option['connectionToken'] = wp_hash( get_current_user_id() . site_url() . time() ); update_option( 'optin_monster_api', $option ); } // Check/set the installation date. if ( empty( $option['installed'] ) ) { // If the review was dismissed, we know the plugin was installed at least a day // before the notice was shown and dismissed. Otherwise, the review timestamp // should be pretty close to the install date. $option['installed'] = $review_dismissed ? $review['time'] - DAY_IN_SECONDS : $review['time']; // Store the plugin install date. update_option( 'optin_monster_api', $option ); } } /** * Loads all global related classes into scope. * * @since 1.0.0 */ public function load_global() { // Register global components. $this->ajax = new OMAPI_Ajax(); $this->blocks = new OMAPI_Blocks(); $this->type = new OMAPI_Type(); $this->output = new OMAPI_Output(); $this->shortcode = new OMAPI_Shortcode(); $this->woocommerce = new OMAPI_WooCommerce(); $this->wpforms = new OMAPI_WPForms(); $this->elementor = new OMAPI_Elementor(); $this->edd = new OMAPI_EasyDigitalDownloads(); $this->memberpress = new OMAPI_MemberPress(); if ( defined( 'DOING_CRON' ) && DOING_CRON && ! $this->actions ) { $this->actions = new OMAPI_Actions(); } // Fire a hook to say that the global classes are loaded. do_action( 'optin_monster_api_global_loaded' ); } /** * Loads all REST API related classes into scope. * * @since 1.8.0 */ public function load_rest() { // Register global components. $this->actions = new OMAPI_Actions(); $this->rest_api = new OMAPI_RestApi(); $this->notifications = new OMAPI_Notifications(); // Fire a hook to say that the global classes are loaded. do_action( 'optin_monster_api_rest_loaded' ); } /** * Loads all admin related classes into scope. * * @since 1.0.0 */ public function load_admin() { // Register admin components. $this->actions = new OMAPI_Actions(); $this->menu = new OMAPI_Menu(); $this->validate = new OMAPI_Validate(); $this->welcome = new OMAPI_Welcome(); $this->promos = new OMAPI_Promos(); $this->notifications = new OMAPI_Notifications(); // phpcs:ignore WordPress.NamingConventions.ValidVariableName.UsedPropertyNotSnakeCase $this->classicEditor = new OMAPI_ClassicEditor(); // Fire a hook to say that the admin classes are loaded. do_action( 'optin_monster_api_admin_loaded' ); } /** * Internal method that returns a optin based on ID. * * @since 1.0.0 * * @param int $id The optin ID used to retrieve a optin. * @return array|bool Array of optin data or false if none found. */ public function get_optin( $id ) { $optin = get_post( absint( $id ) ); return $this->add_campaign_properties( $optin ); } /** * Internal method that returns a optin based on slug. * * @since 1.0.0 * * @param string $slug The optin slug used to retrieve a optin. * @return WP_Post|null Array of optin data or false if none found. */ public function get_optin_by_slug( $slug ) { $optin = get_page_by_path( sanitize_text_field( $slug ), OBJECT, OMAPI_Type::SLUG ); return $this->add_campaign_properties( $optin ); } /** * Get all data for given campaign (optin). * * @since 1.9.10 * * @param WP_Post $campaign The campaign post object. * * @return array */ public function collect_campaign_data( $campaign ) { $campaign = $this->validate_is_campaign_type( $campaign ); if ( empty( $campaign ) ) { return array( 'id' => '', 'post' => $campaign, 'type' => '', 'inline' => false, 'post_meta' => array(), ); } $meta = array(); $keys = get_post_meta( $campaign->ID ); if ( ! empty( $keys ) ) { foreach ( $keys as $key => $x ) { $val = get_post_meta( $campaign->ID, $key, true ); switch ( $key ) { case '_omapi_never': case '_omapi_only': $val = OMAPI_Utils::unique_array( $val ); break; case '_omapi_taxonomies': $val = ! empty( $val ) ? array_map( array( 'OMAPI_Utils', 'unique_array' ), $val ) : array(); break; } $meta[ $key ] = $val; } } $type = get_post_meta( $campaign->ID, '_omapi_type', true ); return array( 'id' => $campaign->post_name, 'post' => $campaign, 'type' => $type, 'inline' => OMAPI_Utils::is_inline_type( $type ), 'post_meta' => $meta, ); } /** * Internal method that returns all optins created on the site. * * @since 1.0.0 * * @param array $args Array of args to modify the query for retreiving optins. * @return array|bool Array of optin data or false if none found. */ public function get_optins( $args = array() ) { $optins = get_posts( wp_parse_args( $args, array( 'no_found_rows' => true, 'nopaging' => true, 'post_type' => OMAPI_Type::SLUG, 'posts_per_page' => -1, 'update_post_term_cache' => false, ) ) ); if ( empty( $optins ) ) { return false; } $optins = array_map( array( $this, 'add_campaign_properties' ), $optins ); // Return the optin data. return $optins; } /** * Add campaign-type and enabled status to post object properties. * * @since 2.6.8 * * @param WP_Post|null $post Optin post object. */ public function add_campaign_properties( $post ) { $post = $this->validate_is_campaign_type( $post ); if ( ! empty( $post->ID ) ) { $post->campaign_type = get_post_meta( $post->ID, '_omapi_type', true ); $post->enabled = ! ! get_post_meta( $post->ID, '_omapi_enabled', true ); } return $post; } /** * Validates post object to ensure our optin post-type. * * @since 2.12.2 * * @param WP_Post $post The post object to check. * * @return WP_Post|null Null if post-type doesn't match. */ public function validate_is_campaign_type( $post ) { if ( ! empty( $post->post_type ) && OMAPI_Type::SLUG !== $post->post_type ) { $post = null; } return $post; } /** * Returns all local campaigns. Cached. * * @since 2.2.0 * * @return array|bool Array of optin data or false if none found. */ public function get_campaigns() { static $campaigns = null; if ( null === $campaigns ) { $campaigns = $this->get_optins(); } return $campaigns; } /** * Returns the main option for the plugin. * * @since 1.0.0 * * @param string $key The option value to get for given key. * @param string $subkey The option value to get for given key and sub-key. * @param mixed $fallback The fallback value. * * @return mixed The main option array for the plugin, or requsted value. */ public function get_option( $key = '', $subkey = '', $fallback = false ) { $option = get_option( 'optin_monster_api' ); if ( ! empty( $key ) ) { if ( ! isset( $option[ $key ] ) ) { return $fallback; } if ( ! empty( $subkey ) ) { return isset( $option[ $key ], $option[ $key ][ $subkey ] ) ? $option[ $key ][ $subkey ] : $fallback; } return $option[ $key ]; } return $option; } /** * Returns the API credentials for OptinMonster. * * @since 1.0.0 * * @return array|bool $creds The user's API creds for OptinMonster. */ public function get_api_credentials() { // Prepare variables. $option = $this->get_option(); $key = false; $user = false; $apikey = false; // Attempt to grab the new API Key. if ( empty( $option['api']['apikey'] ) ) { if ( defined( 'OPTINMONSTER_REST_API_LICENSE_KEY' ) ) { $apikey = OPTINMONSTER_REST_API_LICENSE_KEY; } } else { $apikey = $option['api']['apikey']; } // Attempt to grab the Legacy API key and API user. if ( empty( $option['api']['key'] ) ) { if ( defined( 'OPTINMONSTER_API_LICENSE_KEY' ) ) { $key = OPTINMONSTER_API_LICENSE_KEY; } } else { $key = $option['api']['key']; } if ( empty( $option['api']['user'] ) ) { if ( defined( 'OPTINMONSTER_API_USER' ) ) { $user = OPTINMONSTER_API_USER; } } else { $user = $option['api']['user']; } // Check if we have any of the authentication data. if ( ! $apikey ) { // Do we at least have Legacy API Key and User. if ( ! $key || ! $user ) { return false; } } // Return the API credentials. return apply_filters( 'optin_monster_api_creds', array( 'key' => $key, 'user' => $user, 'apikey' => $apikey, ) ); } /** * Returns the API credentials for OptinMonster. * * @since 1.9.2 * * @return string The API url to use for embedding on the page. */ public function get_api_url() { return OMAPI_Urls::om_api(); } /** * Check if the main WooCommerce class is active. * * @since 1.1.9 * * @deprecated 2.8.0 Use `OMAPI_WooCommerce::is_active` instead. * * @return bool */ public static function is_woocommerce_active() { _deprecated_function( __FUNCTION__, '2.8.0', 'OMAPI_WooCommerce::is_active' ); return OMAPI_WooCommerce::is_active(); } /** * Return the WooCommerce versions string. * * @since 1.6.5 * * @return string */ public static function woocommerce_version() { return OMAPI_WooCommerce::version(); } /** * Determines if the passed version string passes the operator compare * against the currently installed version of WooCommerce. * * Defaults to checking if the current WooCommerce version is greater than * the passed version. * * @since 1.7.0 * * @param string $version The version to check. * @param string $operator The operator to use for comparison. * * @return string */ public static function woocommerce_version_compare( $version = '', $operator = '>=' ) { return OMAPI_WooCommerce::version_compare( $version, $operator ); } /** * Check to see if Mailpoet is active. * * @since 1.2.3 * * @return bool */ public static function is_mailpoet_active() { return OMAPI_MailPoet::is_active(); } /** * Returns possible API key error flag. * * @since 1.0.0 * * @return bool True if there are API key errors, false otherwise. */ public function get_api_key_errors() { $option = $this->get_option(); return isset( $option['is_expired'] ) && $option['is_expired'] || isset( $option['is_disabled'] ) && $option['is_disabled'] || isset( $option['is_invalid'] ) && $option['is_invalid']; } /** * Get and include a view file for output. * * @since 1.9.0 * * @param string $file The view file. * @param mixed $data Arbitrary data to be made available to the view file. * * @return void * * phpcs:disable Generic.CodeAnalysis.UnusedFunctionParameter.FoundAfterLastUsed */ public function output_view( $file, $data = array() ) { // phpcs:enable Generic.CodeAnalysis.UnusedFunctionParameter.FoundAfterLastUsed // Potentially use validate_file() (WP function) if we end up needing sub-directories later. require dirname( $this->file ) . DIRECTORY_SEPARATOR . 'views' . DIRECTORY_SEPARATOR . basename( $file ); } /** * Get view file output content. * * @since 2.3.0 * * @param string $file The view file. * @param mixed $data Arbitrary data to be made available to the view file. * * @return string The view html content. */ public function get_view_contents( $file, $data = array() ) { ob_start(); $this->output_view( $file, $data ); return ob_get_clean(); } /** * Get and include a view file with css and minify the output. * * @since 2.3.0 * * @param string $file The view file. * @param mixed $data Arbitrary data to be made available to the view file. * * @return string */ public function get_min_css_view_contents( $file, $data = array() ) { $contents = $this->get_view_contents( $file, $data ); return str_replace( array( "\n", "\r", "\t" ), '', $contents ); } /** * Get and include a view file with css and minify the output. * * @since 1.9.0 * * @param string $file The view file. * @param mixed $data Arbitrary data to be made available to the view file. * * @return void */ public function output_min_css( $file, $data = array() ) { echo wp_kses( $this->get_min_css_view_contents( $file, $data ), array( 'style' => array( 'type' => array(), ), ) ); } /** * Return the level of the OM user. * * @since 2.0.0 * * @return string The level. */ public function get_level() { return $this->get_option( 'currentLevel', '', '' ); } /** * Check if the OM user has a custom plan. * * @since 2.0.0 * * @return string The level. */ public function is_custom_plan() { return 'vbp_custom' === $this->get_option( 'plan' ); } /** * Check if the OM user's plan is upgradeable. * * @since 2.4.0 * * @return boolean Whether OM user's plan is upgradeable. */ public function can_upgrade() { $level = $this->get_level(); // If plan upgradeable... (e.g. not top tier). return $level && ! in_array( $level, array( 'vbp_agency', 'vbp_team', 'vbp_growth', ), true ) ? $level : false; } /** * Check if the user can see upgrade prompts. * * @since 2.11.0 * * @return boolean Whether upgrades can be shown. */ public function can_show_upgrade() { return $this->can_upgrade() || ! $this->get_level(); } /** * Whether user is a lite user. * * @since 2.11.0 * * @return boolean Whether user is a lite user. */ public function is_lite_user() { return 'vbp_free' === $this->get_level(); } /** * Check if the OM user is allowed MonsterLinks. * * @since 2.6.6 * * @param string $rule_type The rule type to check. * * @return boolean Whether OM user is allowed MonsterLinks. */ public function has_rule_type( $rule_type ) { $data = OMAPI_Api::fetch_me_cached(); // phpcs:ignore WordPress.NamingConventions.ValidVariableName.UsedPropertyNotSnakeCase return ! empty( $data->ruleTypes ) && in_array( $rule_type, (array) $data->ruleTypes, true ); } /** * Loads the default plugin options. * * @since 1.0.0 * * @return array Array of default plugin options. */ public static function default_options() { $options = array( 'api' => array(), 'is_expired' => false, 'is_disabled' => false, 'is_invalid' => false, 'installed' => time(), 'connected' => '', 'beta' => false, 'auto_updates' => '', 'usage_tracking' => false, 'hide_announcements' => false, 'welcome' => array( 'status' => 'none', ), ); return apply_filters( 'optin_monster_api_default_options', $options ); } /** * PRS-0 compliant autoloader. * * @since 1.0.0 * * @param string $classname The classname to check with the autoloader. */ public static function autoload( $classname ) { // Return early if not the proper classname. if ( 'OMAPI' !== mb_substr( $classname, 0, 5, 'UTF-8' ) ) { return; } // Check if the file exists. If so, load the file. $filename = dirname( __FILE__ ) . DIRECTORY_SEPARATOR . str_replace( '_', DIRECTORY_SEPARATOR, $classname ) . '.php'; if ( file_exists( $filename ) ) { require $filename; } } /** * Gets all site IDs associated with this site * * @since 1.9.10 * * @return array */ public function get_site_ids() { $option = $this->get_option(); return ! empty( $option['siteIds'] ) ? (array) $option['siteIds'] : array(); } /** * Gets the site ID associated with this site * * @since 1.9.10 * * @return string */ public function get_site_id() { $option = $this->get_option(); return ! empty( $option['siteId'] ) ? (string) $option['siteId'] : ''; } /** * Gets the revenue attribution settings associated with the * account that has registered this site. * * @since 2.6.13 * * @return array */ public function get_revenue_attribution() { $option = $this->get_option(); return ! empty( $option['revenueAttribution'] ) ? (array) $option['revenueAttribution'] : array(); } /** * Checks if given (or current) page is an optinmonster admin page. * * @since 2.10.0 * * @param string $page Page to check. Falls back to $_REQUEST['page']. * * @return boolean Whether given (or current) page is an optinmonster admin page. */ public function is_om_page( $page = null ) { // phpcs:disable WordPress.Security.NonceVerification.Recommended if ( empty( $page ) && ! empty( $_REQUEST['page'] ) ) { $page = sanitize_key( wp_unslash( $_REQUEST['page'] ) ); } // phpcs:enable WordPress.Security.NonceVerification.Recommended return ! empty( $page ) && preg_match( '/optin-monster-/', $page ); } /** * Hides unrelated admin notices. * * @since 1.9.7 */ public function hide_unrelated_admin_notices() { // Bail if we're not on a OptinMonster screen. // phpcs:ignore WordPress.Security.NonceVerification.Recommended if ( ! $this->is_om_page() ) { return; } global $wp_filter; $notices_type = array( 'user_admin_notices', 'admin_notices', 'all_admin_notices', ); foreach ( $notices_type as $type ) { if ( empty( $wp_filter[ $type ]->callbacks ) || ! is_array( $wp_filter[ $type ]->callbacks ) ) { continue; } foreach ( $wp_filter[ $type ]->callbacks as $priority => $hooks ) { foreach ( $hooks as $name => $arr ) { if ( is_object( $arr['function'] ) && $arr['function'] instanceof Closure ) { unset( $wp_filter[ $type ]->callbacks[ $priority ][ $name ] ); continue; } $class = ! empty( $arr['function'][0] ) && is_object( $arr['function'][0] ) ? strtolower( get_class( $arr['function'][0] ) ) : ''; if ( ! empty( $class ) && preg_match( '/^(?:omapi|am_notification)/', $class ) ) { continue; } if ( ! empty( $name ) && ! preg_match( '/^(?:omapi|am_notification)/', $name ) ) { unset( $wp_filter[ $type ]->callbacks[ $priority ][ $name ] ); } } } } } /** * Checks PHP version. * * @return void */ public function check_php_version() { // Display for PHP below 5.6. if ( version_compare( PHP_VERSION, '5.5', '>=' ) ) { return; } // Display for admins only. if ( ! is_super_admin() ) { return; } // Display on Dashboard page only. if ( isset( $GLOBALS['pagenow'] ) && 'index.php' !== $GLOBALS['pagenow'] ) { return; } // Do not double up on WPForms notice. if ( function_exists( 'wpforms_check_php_version' ) ) { return; } // Display the notice, finally. echo '<div id="message" class="notice notice-error">' . '<p>' . sprintf( wp_kses( /* translators: %1$s - OptinMonster API plugin name; %2$s - optinmonster.com URL to a related doc. */ __( 'Your site is running an outdated version of PHP that is no longer supported and may cause issues with the %1$s plugin. <a href="%2$s" target="_blank" rel="noopener noreferrer">Read more</a> for additional information.', 'optin-monster-api' ), array( 'a' => array( 'href' => array(), 'target' => array(), 'rel' => array(), ), ) ), '<strong>OptinMonster API</strong>', 'https://optinmonster.com/docs/supported-php-version/' ) . '<br><br><em>' . wp_kses( __( '<strong>Please Note:</strong> Support for PHP 5.5 will be discontinued in 2020. After this, if no further action is taken, OptinMonster functionality will be disabled.', 'optin-monster-api' ), array( 'strong' => array(), 'em' => array(), ) ) . '</em></p>' . '</div>'; } /** * Get the asset version for enqueued assets. * * @since 1.9.10 * * @return mixed */ public function asset_version() { if ( defined( 'SCRIPT_DEBUG' ) && SCRIPT_DEBUG ) { return time(); } if ( defined( 'OPTINMONSTER_ENV' ) && 'dev' === strtolower( OPTINMONSTER_ENV ) ) { return time(); } $beta_version = $this->beta_version( 'U' ); return $beta_version ? $beta_version : $this->version; } /** * Check if beta is enabled. * * @since 2.0.0 * * @return bool */ public function beta_enabled() { $option = $this->get_option(); return apply_filters( 'optin_monster_beta_enabled', ! empty( $option['beta'] ) ); } /** * Get beta version. * * @since 2.0.0 * * @param string $format The php date format. * * @return bool */ public function beta_version( $format = 'd M Y H:i:s' ) { static $timestamp = null; $version = false; if ( ! $this->beta_enabled() ) { return $version; } if ( null === $timestamp ) { $file = plugin_dir_path( __FILE__ ) . '.betaversion'; if ( file_exists( $file ) ) { ob_start(); include plugin_dir_path( __FILE__ ) . '.betaversion'; $timestamp = ob_get_clean(); } } if ( ! empty( $timestamp ) ) { $version = gmdate( $format, (int) $timestamp ); } return $version; } /** * The access capability required for access to OptinMonster pages/settings. * * @since 2.0.0 * * @param string|null $slug The menu slug. Null by default. * * @return string The access capability. */ public function access_capability( $slug = null ) { return apply_filters( 'optin_monster_api_menu_cap', 'manage_options', $slug ); } /** * Check if user has access capability required for access to OptinMonster pages/settings. * * @since 2.0.0 * * @param string|null $slug The menu slug. Null by default. * * @return bool Whether user has access. */ public function can_access( $slug = null ) { return current_user_can( $this->access_capability( $slug ) ); } /** * Get app url, with proper query args set to ensure going to correct account, and setting return * query arg to come back (if relevant on the destination page). * * @since 2.0.0 * * @param string $path The path on the app. * @param string $return_url Url to return. Will default to wp_get_referer(). * * @return string The app url. */ public function app_url( $path, $return_url = '' ) { return OMAPI_Urls::om_app( $path, $return_url ); } /** * Returns the singleton instance of the class. * * @since 1.0.0 * * @return OMAPI */ public static function get_instance() { if ( ! isset( self::$instance ) && ! ( self::$instance instanceof OMAPI ) ) { self::$instance = new OMAPI(); } return self::$instance; } /** * Magic getter for our object. * * @since 2.11.2 * * @param string $property The property to retrieve. * * @return mixed */ public function __get( $property ) { if ( ! empty( self::$class_map[ $property ] ) ) { $this->$property = new self::$class_map[ $property ](); } return $this->$property; } } register_activation_hook( __FILE__, 'optin_monster_api_activation_hook' ); /** * Fired when the plugin is activated. * * @since 1.0.0 * * @global int $wp_version The version of WordPress for this install. * @global object $wpdb The WordPress database object. * @param boolean $network_wide True if WPMU superadmin uses "Network Activate" action, false otherwise. */ function optin_monster_api_activation_hook( $network_wide ) { global $wp_version; if ( version_compare( $wp_version, '4.7.0', '<' ) && ! defined( 'OPTINMONSTER_FORCE_ACTIVATION' ) ) { deactivate_plugins( plugin_basename( __FILE__ ) ); wp_die( wp_kses_post( sprintf( /* translators: %s) admin url */ __( 'Sorry, but your version of WordPress does not meet OptinMonster\'s required version of <strong>4.7.0</strong> to run properly. The plugin has been deactivated. <a href="%s">Click here to return to the Dashboard</a>.', 'optin-monster-api' ), esc_url( admin_url() ) ) ) ); } $instance = OMAPI::get_instance(); global $wpdb; if ( is_multisite() && $network_wide ) { $site_list = $wpdb->get_results( "SELECT * FROM $wpdb->blogs ORDER BY blog_id" ); foreach ( (array) $site_list as $site ) { switch_to_blog( $site->blog_id ); // Set default option. $instance->load_option(); restore_current_blog(); } } else { // Set default option. $instance->load_option(); } // If we don't have api credentials, set up the redirect on plugin activation. if ( ! $instance->get_api_credentials() ) { $options = $instance->get_option(); $options['welcome']['status'] = 'none'; update_option( 'optin_monster_api', $options ); } // Abort so we only set the transient for single site installs. // phpcs:ignore WordPress.Security.NonceVerification.Recommended if ( isset( $_GET['activate-multi'] ) || is_network_admin() ) { return; } // Add transient to trigger redirect to the Welcome screen. set_transient( 'optin_monster_api_activation_redirect', true, 30 ); } register_uninstall_hook( __FILE__, 'optin_monster_api_uninstall_hook' ); /** * Fired when the plugin is uninstalled. * * @since 1.0.0 * * @global object $wpdb The WordPress database object. */ function optin_monster_api_uninstall_hook() { $instance = OMAPI::get_instance(); global $wpdb; if ( is_multisite() ) { $site_list = $wpdb->get_results( "SELECT * FROM $wpdb->blogs ORDER BY blog_id" ); foreach ( (array) $site_list as $site ) { switch_to_blog( $site->blog_id ); delete_option( 'optin_monster_api' ); restore_current_blog(); } } else { delete_option( 'optin_monster_api' ); } } // Load the plugin. $optin_monster_api = OMAPI::get_instance(); // Conditionally load the template tag. if ( ! function_exists( 'optin_monster' ) ) { /** * Primary template tag for outputting OptinMonster optins in templates. * * @since 1.0.0 * * @param int $id The ID of the optin to load. * @param string $type The type of field to query. * @param array $args Associative array of args to be passed. * @param bool $return Flag to echo or return the optin HTML. */ function optin_monster( $id, $type = 'id', $args = array(), $return = false ) { // If we have args, build them into a shortcode format. $args_string = ''; if ( ! empty( $args ) ) { foreach ( (array) $args as $key => $value ) { $args_string .= ' ' . $key . '="' . $value . '"'; } } // Build the shortcode. $shortcode = ! empty( $args_string ) ? '[optin-monster ' . $type . '="' . $id . '"' . $args_string . ']' : '[optin-monster ' . $type . '="' . $id . '"]'; // Return or echo the shortcode output. if ( $return ) { return do_shortcode( $shortcode ); } else { echo do_shortcode( $shortcode ); } } } // Backwards compat for the v1 template tag. if ( ! function_exists( 'optin_monster_tag' ) ) { /** * Primary template tag for outputting OptinMonster optins in templates (v1). * * @since 1.0.0 * * @param int $id The post name of the optin to load. * @param bool $return Flag to echo or return the optin HTML. */ function optin_monster_tag( $id, $return = false ) { // Return the v2 template tag. return optin_monster( $id, 'slug', array(), $return ); } }
Save Changes
Rename File
Rename