MonsterInsights()->license->get_site_license_key(), 'type' => MonsterInsights()->license->get_site_license_type(), 'is_disabled' => MonsterInsights()->license->site_license_disabled(), 'is_expired' => MonsterInsights()->license->site_license_expired(), 'is_invalid' => MonsterInsights()->license->site_license_invalid(), ); $network_license = array( 'key' => MonsterInsights()->license->get_network_license_key(), 'type' => MonsterInsights()->license->get_network_license_type(), 'is_disabled' => MonsterInsights()->license->network_license_disabled(), 'is_expired' => MonsterInsights()->license->network_license_expired(), 'is_invalid' => MonsterInsights()->license->network_license_disabled(), ); wp_send_json( array( 'site' => $site_license, 'network' => $network_license, ) ); } /** * Ajax handler for grabbing the current authenticated profile. */ public function get_profile() { check_ajax_referer( 'mi-admin-nonce', 'nonce' ); if ( ! current_user_can( 'monsterinsights_save_settings' ) ) { return; } $auth = MonsterInsights()->auth; wp_send_json( array( 'ua' => $auth->get_ua(), 'v4' => $auth->get_v4_id(), 'viewname' => $auth->get_viewname(), 'manual_ua' => $auth->get_manual_ua(), 'manual_v4' => $auth->get_manual_v4_id(), 'measurement_protocol_secret' => $auth->get_measurement_protocol_secret(), 'network_ua' => $auth->get_network_ua(), 'network_v4' => $auth->get_network_v4_id(), 'network_viewname' => $auth->get_network_viewname(), 'network_manual_ua' => $auth->get_network_manual_ua(), 'network_measurement_protocol_secret' => $auth->get_network_measurement_protocol_secret(), 'connected_type' => $auth->get_connected_type(), ) ); } /** * Ajax handler for grabbing the settings. */ public function get_settings() { check_ajax_referer( 'mi-admin-nonce', 'nonce' ); if ( ! current_user_can( 'monsterinsights_view_dashboard' ) ) { return; } $options = monsterinsights_get_options(); // Array fields are needed even if empty. $array_fields = array( 'view_reports', 'save_settings', 'ignore_users' ); foreach ( $array_fields as $array_field ) { if ( ! isset( $options[ $array_field ] ) ) { $options[ $array_field ] = array(); } } if ( isset( $options['custom_code'] ) ) { $options['custom_code'] = stripslashes( $options['custom_code'] ); } //add email summaries options if ( monsterinsights_is_pro_version() ) { $default_email = array( 'email' => get_option( 'admin_email' ), ); if ( ! isset( $options['email_summaries'] ) ) { $options['email_summaries'] = 'on'; } if ( ! isset( $options['summaries_email_addresses'] ) ) { $options['summaries_email_addresses'] = array( $default_email, ); } if ( ! isset( $options['summaries_html_template'] ) ) { $options['summaries_html_template'] = 'yes'; } if ( ! isset( $options['summaries_carbon_copy'] ) ) { $options['summaries_carbon_copy'] = 'no'; } if ( ! isset( $options['summaries_header_image'] ) ) { $options['summaries_header_image'] = ''; } if ( ! isset( $options['local_gtag_file_modified_at'] ) ) { $options['local_gtag_file_modified_at'] = ''; } } wp_send_json( $options ); } /** * Ajax handler for updating the settings. */ public function update_settings() { check_ajax_referer( 'mi-admin-nonce', 'nonce' ); if ( ! current_user_can( 'monsterinsights_save_settings' ) ) { return; } if ( isset( $_POST['setting'] ) ) { $setting = sanitize_text_field( wp_unslash( $_POST['setting'] ) ); if ( isset( $_POST['value'] ) ) { $value = $this->handle_sanitization( $setting, $_POST['value'] ); monsterinsights_update_option( $setting, $value ); do_action( 'monsterinsights_after_update_settings', $setting, $value ); } else { monsterinsights_update_option( $setting, false ); do_action( 'monsterinsights_after_update_settings', $setting, false ); } } wp_send_json_success(); } /** * Ajax handler for updating the settings. */ public function update_settings_bulk() { check_ajax_referer( 'mi-admin-nonce', 'nonce' ); if ( ! current_user_can( 'monsterinsights_save_settings' ) ) { return; } if ( isset( $_POST['settings'] ) ) { $settings = json_decode( sanitize_text_field( wp_unslash( $_POST['settings'] ) ), true ); foreach ( $settings as $setting => $value ) { $value = $this->handle_sanitization( $setting, $value ); monsterinsights_update_option( $setting, $value ); do_action( 'monsterinsights_after_update_settings', $setting, $value ); } } wp_send_json_success(); } /** * Sanitization specific to each field. * * @param string $field The key of the field to sanitize. * @param string $value The value of the field to sanitize. * * @return mixed The sanitized input. */ private function handle_sanitization( $field, $value ) { $value = wp_unslash( $value ); // Textarea fields. $textarea_fields = array( 'custom_code', ); if ( in_array( $field, $textarea_fields, true ) ) { if ( function_exists( 'sanitize_textarea_field' ) ) { return sanitize_textarea_field( $value ); } else { return wp_kses( $value, array() ); } } $array_value = json_decode( $value, true ); if ( is_array( $array_value ) ) { $value = $array_value; // Don't save empty values. foreach ( $value as $key => $item ) { if ( is_array( $item ) ) { $empty = true; foreach ( $item as $item_value ) { if ( ! empty( $item_value ) ) { $empty = false; } } if ( $empty ) { unset( $value[ $key ] ); } } } // Reset array keys because JavaScript can't handle arrays with non-sequential keys. $value = array_values( $value ); return $value; } return sanitize_text_field( $value ); } /** * Return the state of the addons ( installed, activated ) */ public function get_addons() { check_ajax_referer( 'mi-admin-nonce', 'nonce' ); if ( ! current_user_can( 'monsterinsights_save_settings' ) ) { return; } if ( isset( $_POST['network'] ) && intval( $_POST['network'] ) > 0 ) { define( 'WP_NETWORK_ADMIN', true ); } $addons_data = monsterinsights_get_addons(); $parsed_addons = array(); $installed_plugins = get_plugins(); if ( ! is_array( $addons_data ) ) { $addons_data = array(); } foreach ( $addons_data as $addons_type => $addons ) { foreach ( $addons as $addon ) { $slug = 'monsterinsights-' . $addon->slug; if ( 'monsterinsights-ecommerce' === $slug && 'm' === $slug[0] ) { $addon = $this->get_addon( $installed_plugins, $addons_type, $addon, $slug ); if ( empty( $addon->installed ) ) { $slug = 'ga-ecommerce'; $addon = $this->get_addon( $installed_plugins, $addons_type, $addon, $slug ); } } else { $addon = $this->get_addon( $installed_plugins, $addons_type, $addon, $slug ); } $parsed_addons[ $addon->slug ] = $addon; } } // Include data about the plugins needed by some addons ( WooCommerce, EDD, Google AMP, CookieBot, etc ). // WooCommerce. $parsed_addons['woocommerce'] = array( 'active' => class_exists( 'WooCommerce' ), ); // Edd. $parsed_addons['easy_digital_downloads'] = array( 'active' => class_exists( 'Easy_Digital_Downloads' ), ); // MemberPress. $parsed_addons['memberpress'] = array( 'active' => defined( 'MEPR_VERSION' ) && version_compare( MEPR_VERSION, '1.3.43', '>' ), ); // LifterLMS. $parsed_addons['lifterlms'] = array( 'active' => function_exists( 'LLMS' ) && version_compare( LLMS()->version, '3.32.0', '>=' ), ); // Restrict Content Pro. $parsed_addons['rcp'] = array( 'active' => class_exists( 'Restrict_Content_Pro' ) && version_compare( RCP_PLUGIN_VERSION, '3.5.4', '>=' ), ); // GiveWP. $parsed_addons['givewp'] = array( 'active' => function_exists( 'Give' ), ); // GiveWP Analytics. $parsed_addons['givewp_google_analytics'] = array( 'active' => function_exists( 'Give_Google_Analytics' ), ); // Cookiebot. $parsed_addons['cookiebot'] = array( 'active' => function_exists( 'cookiebot_active' ) && cookiebot_active(), ); // Cookie Notice. $parsed_addons['cookie_notice'] = array( 'active' => class_exists( 'Cookie_Notice' ), ); // Fb Instant Articles. $parsed_addons['instant_articles'] = array( 'active' => defined( 'IA_PLUGIN_VERSION' ) && version_compare( IA_PLUGIN_VERSION, '3.3.4', '>' ), ); // Google AMP. $parsed_addons['google_amp'] = array( 'active' => defined( 'AMP__FILE__' ), ); // Yoast SEO. $parsed_addons['yoast_seo'] = array( 'active' => defined( 'WPSEO_VERSION' ), ); // EasyAffiliate. $parsed_addons['easy_affiliate'] = array( 'active' => defined( 'ESAF_EDITION' ), ); // WPForms. $parsed_addons['wpforms-lite'] = array( 'active' => function_exists( 'wpforms' ), 'icon' => plugin_dir_url( MONSTERINSIGHTS_PLUGIN_FILE ) . 'assets/images/plugin-wpforms.png', 'title' => 'WPForms', 'excerpt' => __( 'The best drag & drop WordPress form builder. Easily create beautiful contact forms, surveys, payment forms, and more with our 150+ form templates. Trusted by over 4 million websites as the best forms plugin', 'google-analytics-for-wordpress' ), 'installed' => array_key_exists( 'wpforms-lite/wpforms.php', $installed_plugins ), 'basename' => 'wpforms-lite/wpforms.php', 'slug' => 'wpforms-lite', ); // AIOSEO. $parsed_addons['aioseo'] = array( 'active' => function_exists( 'aioseo' ), 'icon' => plugin_dir_url( MONSTERINSIGHTS_PLUGIN_FILE ) . 'assets/images/plugin-all-in-one-seo.png', 'title' => 'AIOSEO', 'excerpt' => __( 'The original WordPress SEO plugin and toolkit that improves your website’s search rankings. Comes with all the SEO features like Local SEO, WooCommerce SEO, sitemaps, SEO optimizer, schema, and more.', 'google-analytics-for-wordpress' ), 'installed' => array_key_exists( 'all-in-one-seo-pack/all_in_one_seo_pack.php', $installed_plugins ), 'basename' => ( monsterinsights_is_installed_aioseo_pro() ) ? 'all-in-one-seo-pack-pro/all_in_one_seo_pack.php' : 'all-in-one-seo-pack/all_in_one_seo_pack.php', 'slug' => 'all-in-one-seo-pack', ); // OptinMonster. $parsed_addons['optinmonster'] = array( 'active' => class_exists( 'OMAPI' ), 'icon' => plugin_dir_url( MONSTERINSIGHTS_PLUGIN_FILE ) . 'assets/images/plugin-om.png', 'title' => 'OptinMonster', 'excerpt' => __( 'Instantly get more subscribers, leads, and sales with the #1 conversion optimization toolkit. Create high converting popups, announcement bars, spin a wheel, and more with smart targeting and personalization.', 'google-analytics-for-wordpress' ), 'installed' => array_key_exists( 'optinmonster/optin-monster-wp-api.php', $installed_plugins ), 'basename' => 'optinmonster/optin-monster-wp-api.php', 'slug' => 'optinmonster', ); // WP Mail Smtp. $parsed_addons['wp-mail-smtp'] = array( 'active' => function_exists( 'wp_mail_smtp' ), 'icon' => plugin_dir_url( MONSTERINSIGHTS_PLUGIN_FILE ) . 'assets/images/plugin-smtp.png', 'title' => 'WP Mail SMTP', 'excerpt' => __( 'Improve your WordPress email deliverability and make sure that your website emails reach user’s inbox with the #1 SMTP plugin for WordPress. Over 2 million websites use it to fix WordPress email issues.', 'google-analytics-for-wordpress' ), 'installed' => array_key_exists( 'wp-mail-smtp/wp_mail_smtp.php', $installed_plugins ), 'basename' => 'wp-mail-smtp/wp_mail_smtp.php', 'slug' => 'wp-mail-smtp', ); // SeedProd. $parsed_addons['coming-soon'] = array( 'active' => function_exists( 'seed_csp4_activation' ), 'icon' => plugin_dir_url( MONSTERINSIGHTS_PLUGIN_FILE ) . 'assets/images/plugin-seedprod.png', 'title' => 'SeedProd', 'excerpt' => __( 'The fastest drag & drop landing page builder for WordPress. Create custom landing pages without writing code, connect them with your CRM, collect subscribers, and grow your audience. Trusted by 1 million sites.', 'google-analytics-for-wordpress' ), 'installed' => array_key_exists( 'coming-soon/coming-soon.php', $installed_plugins ), 'basename' => 'coming-soon/coming-soon.php', 'slug' => 'coming-soon', ); // RafflePress $parsed_addons['rafflepress'] = array( 'active' => function_exists( 'rafflepress_lite_activation' ), 'icon' => plugin_dir_url( MONSTERINSIGHTS_PLUGIN_FILE ) . 'assets/images/pluign-rafflepress.png', 'title' => 'RafflePress', 'excerpt' => __( 'Turn your website visitors into brand ambassadors! Easily grow your email list, website traffic, and social media followers with the most powerful giveaways & contests plugin for WordPress.', 'google-analytics-for-wordpress' ), 'installed' => array_key_exists( 'rafflepress/rafflepress.php', $installed_plugins ), 'basename' => 'rafflepress/rafflepress.php', 'slug' => 'rafflepress', ); // TrustPulse $parsed_addons['trustpulse-api'] = array( 'active' => class_exists( 'TPAPI' ), 'icon' => plugin_dir_url( MONSTERINSIGHTS_PLUGIN_FILE ) . 'assets/images/plugin-trust-pulse.png', 'title' => 'TrustPulse', 'excerpt' => __( 'Boost your sales and conversions by up to 15% with real-time social proof notifications. TrustPulse helps you show live user activity and purchases to help convince other users to purchase.', 'google-analytics-for-wordpress' ), 'installed' => array_key_exists( 'trustpulse-api/trustpulse.php', $installed_plugins ), 'basename' => 'trustpulse-api/trustpulse.php', 'slug' => 'trustpulse-api', ); // Smash Balloon (Instagram) $parsed_addons['smash-balloon-instagram'] = array( 'active' => class_exists( 'sb_instagram_feed_init' ), 'icon' => plugin_dir_url( MONSTERINSIGHTS_PLUGIN_FILE ) . 'assets/images/plugin-smash-balloon.png', 'title' => 'Smash Balloon Instagram Feeds', 'excerpt' => __( 'Easily display Instagram content on your WordPress site without writing any code. Comes with multiple templates, ability to show content from multiple accounts, hashtags, and more. Trusted by 1 million websites.', 'google-analytics-for-wordpress' ), 'installed' => array_key_exists( 'instagram-feed/instagram-feed.php', $installed_plugins ), 'basename' => 'instagram-feed/instagram-feed.php', 'slug' => 'instagram-feed', ); // PushEngage $parsed_addons['pushengage'] = array( 'active' => method_exists( 'Pushengage', 'init' ), 'icon' => plugin_dir_url( MONSTERINSIGHTS_PLUGIN_FILE ) . 'assets/images/plugin-pushengage.svg', 'title' => 'PushEngage', 'excerpt' => __( 'Connect with your visitors after they leave your website with the leading web push notification software. Over 10,000+ businesses worldwide use PushEngage to send 9 billion notifications each month.', 'google-analytics-for-wordpress' ), 'installed' => array_key_exists( 'pushengage/main.php', $installed_plugins ), 'basename' => 'pushengage/main.php', 'slug' => 'pushengage', ); // Pretty Links $parsed_addons['pretty-link'] = array( 'active' => class_exists( 'PrliBaseController' ), 'icon' => '', 'title' => 'Pretty Links', 'excerpt' => __( 'Pretty Links helps you shrink, beautify, track, manage and share any URL on or off of your WordPress website. Create links that look how you want using your own domain name!', 'google-analytics-for-wordpress' ), 'installed' => array_key_exists( 'pretty-link/pretty-link.php', $installed_plugins ), 'basename' => 'pretty-link/pretty-link.php', 'slug' => 'pretty-link', ); // Gravity Forms. $parsed_addons['gravity_forms'] = array( 'active' => class_exists( 'GFCommon' ), ); // Formidable Forms. $parsed_addons['formidable_forms'] = array( 'active' => class_exists( 'FrmHooksController' ), ); // Manual UA Addon. if ( ! isset( $parsed_addons['manual_ua'] ) ) { $parsed_addons['manual_ua'] = array( 'active' => class_exists( 'MonsterInsights_Manual_UA' ), ); } wp_send_json( $parsed_addons ); } public function get_addon( $installed_plugins, $addons_type, $addon, $slug ) { $active = false; $installed = false; $plugin_basename = monsterinsights_get_plugin_basename_from_slug( $slug ); if ( isset( $installed_plugins[ $plugin_basename ] ) ) { $installed = true; if ( is_multisite() && is_network_admin() ) { $active = is_plugin_active_for_network( $plugin_basename ); } else { $active = is_plugin_active( $plugin_basename ); } } if ( empty( $addon->url ) ) { $addon->url = ''; } $active_version = false; if ( $active ) { if ( ! empty( $installed_plugins[ $plugin_basename ]['Version'] ) ) { $active_version = $installed_plugins[ $plugin_basename ]['Version']; } } $addon->type = $addons_type; $addon->installed = $installed; $addon->active_version = $active_version; $addon->active = $active; $addon->basename = $plugin_basename; return $addon; } /** * Use custom notices in the Vue app on the Settings screen. */ public function hide_old_notices() { global $wp_version; if ( version_compare( $wp_version, '4.6', '<' ) ) { // remove_all_actions triggers an infinite loop on older versions. return; } $screen = get_current_screen(); // Bail if we're not on a MonsterInsights screen. if ( empty( $screen->id ) || strpos( $screen->id, 'monsterinsights' ) === false ) { return; } // Hide admin notices on the settings screen. if ( monsterinsights_is_settings_page() ) { remove_all_actions( 'admin_notices' ); } } /** * Update manual ua. */ public function update_manual_ua() { check_ajax_referer( 'mi-admin-nonce', 'nonce' ); if ( ! current_user_can( 'monsterinsights_save_settings' ) ) { return; } $manual_ua_code = isset( $_POST['manual_ua_code'] ) ? sanitize_text_field( wp_unslash( $_POST['manual_ua_code'] ) ) : ''; $manual_ua_code = monsterinsights_is_valid_ua( $manual_ua_code ); // Also sanitizes the string. if ( ! empty( $_REQUEST['isnetwork'] ) && sanitize_text_field( wp_unslash( $_REQUEST['isnetwork'] ) ) ) { define( 'WP_NETWORK_ADMIN', true ); } $manual_ua_code_old = is_network_admin() ? MonsterInsights()->auth->get_network_manual_ua() : MonsterInsights()->auth->get_manual_ua(); if ( $manual_ua_code && $manual_ua_code_old && $manual_ua_code_old === $manual_ua_code ) { // Same code we had before // Do nothing. wp_send_json_success(); } else if ( $manual_ua_code && $manual_ua_code_old && $manual_ua_code_old !== $manual_ua_code ) { // Different UA code. if ( is_network_admin() ) { MonsterInsights()->auth->set_network_manual_ua( $manual_ua_code ); } else { MonsterInsights()->auth->set_manual_ua( $manual_ua_code ); } } else if ( $manual_ua_code && empty( $manual_ua_code_old ) ) { // Move to manual. if ( is_network_admin() ) { MonsterInsights()->auth->set_network_manual_ua( $manual_ua_code ); } else { MonsterInsights()->auth->set_manual_ua( $manual_ua_code ); } } else if ( empty( $manual_ua_code ) && $manual_ua_code_old ) { // Deleted manual. if ( is_network_admin() ) { MonsterInsights()->auth->delete_network_manual_ua(); } else { MonsterInsights()->auth->delete_manual_ua(); } } else if ( isset( $_POST['manual_ua_code'] ) && empty( $manual_ua_code ) ) { wp_send_json_error( array( 'error' => __( 'Invalid UA code', 'google-analytics-for-wordpress' ), ) ); } wp_send_json_success(); } /** * Update manual v4. */ public function update_manual_v4() { check_ajax_referer( 'mi-admin-nonce', 'nonce' ); if ( ! current_user_can( 'monsterinsights_save_settings' ) ) { return; } $manual_v4_code = isset( $_POST['manual_v4_code'] ) ? sanitize_text_field( wp_unslash( $_POST['manual_v4_code'] ) ) : ''; $manual_v4_code = monsterinsights_is_valid_v4_id( $manual_v4_code ); // Also sanitizes the string. if ( ! empty( $_REQUEST['isnetwork'] ) && sanitize_text_field( wp_unslash( $_REQUEST['isnetwork'] ) ) ) { define( 'WP_NETWORK_ADMIN', true ); } $manual_v4_code_old = is_network_admin() ? MonsterInsights()->auth->get_network_manual_v4_id() : MonsterInsights()->auth->get_manual_v4_id(); if ( $manual_v4_code && $manual_v4_code_old && $manual_v4_code_old === $manual_v4_code ) { // Same code we had before // Do nothing. wp_send_json_success(); } else if ( $manual_v4_code && $manual_v4_code_old && $manual_v4_code_old !== $manual_v4_code ) { // Different UA code. if ( is_network_admin() ) { MonsterInsights()->auth->set_network_manual_v4_id( $manual_v4_code ); } else { MonsterInsights()->auth->set_manual_v4_id( $manual_v4_code ); } } else if ( $manual_v4_code && empty( $manual_v4_code_old ) ) { // Move to manual. if ( is_network_admin() ) { MonsterInsights()->auth->set_network_manual_v4_id( $manual_v4_code ); } else { MonsterInsights()->auth->set_manual_v4_id( $manual_v4_code ); } } else if ( empty( $manual_v4_code ) && $manual_v4_code_old ) { // Deleted manual. if ( is_network_admin() ) { MonsterInsights()->auth->delete_network_manual_v4_id(); } else { MonsterInsights()->auth->delete_manual_v4_id(); } } else if ( isset( $_POST['manual_v4_code'] ) && empty( $manual_v4_code ) ) { wp_send_json_error( array( 'error' => __( 'Invalid UA code', 'google-analytics-for-wordpress' ), ) ); } wp_send_json_success(); } public function update_dual_tracking_id() { check_ajax_referer( 'mi-admin-nonce', 'nonce' ); if ( ! current_user_can( 'monsterinsights_save_settings' ) ) { return; } if ( ! empty( $_REQUEST['isnetwork'] ) && sanitize_text_field( wp_unslash( $_REQUEST['isnetwork'] ) ) ) { define( 'WP_NETWORK_ADMIN', true ); } $value = empty( $_REQUEST['value'] ) ? '' : sanitize_text_field( wp_unslash( $_REQUEST['value'] ) ); $sanitized_ua_value = monsterinsights_is_valid_ua( $value ); $sanitized_v4_value = monsterinsights_is_valid_v4_id( $value ); if ( $sanitized_v4_value ) { $value = $sanitized_v4_value; } elseif ( $sanitized_ua_value ) { $value = $sanitized_ua_value; } elseif ( ! empty( $value ) ) { wp_send_json_error( array( 'error' => __( 'Invalid dual tracking code', 'google-analytics-for-wordpress' ), ) ); } $auth = MonsterInsights()->auth; if ( is_network_admin() ) { $auth->set_network_dual_tracking_id( $value ); } else { $auth->set_dual_tracking_id( $value ); } wp_send_json_success(); } public function update_measurement_protocol_secret() { check_ajax_referer( 'mi-admin-nonce', 'nonce' ); if ( ! current_user_can( 'monsterinsights_save_settings' ) ) { return; } if ( ! empty( $_REQUEST['isnetwork'] ) && sanitize_text_field( wp_unslash( $_REQUEST['isnetwork'] ) ) ) { define( 'WP_NETWORK_ADMIN', true ); } $value = empty( $_REQUEST['value'] ) ? '' : sanitize_text_field( wp_unslash( $_REQUEST['value'] ) ); $auth = MonsterInsights()->auth; if ( is_network_admin() ) { $auth->set_network_measurement_protocol_secret( $value ); } else { $auth->set_measurement_protocol_secret( $value ); } // Send API request to Relay // TODO: Remove when token automation API is ready $api = new MonsterInsights_API_Request( 'auth/mp-token/', 'POST' ); $api->set_additional_data( array( 'mp_token' => $value, ) ); // Even if there's an error from Relay, we can still return a successful json // payload because we can try again with Relay token push in the future $data = array(); $result = $api->request(); if ( is_wp_error( $result ) ) { // Just need to output the error in the response for debugging purpose $data['error'] = array( 'message' => $result->get_error_message(), 'code' => $result->get_error_code(), ); } wp_send_json_success( $data ); } /** * */ public function handle_settings_import() { check_ajax_referer( 'mi-admin-nonce', 'nonce' ); if ( ! current_user_can( 'monsterinsights_save_settings' ) ) { return; } if ( ! isset( $_FILES['import_file'] ) ) { return; } $extension = explode( '.', sanitize_text_field( wp_unslash( $_FILES['import_file']['name'] ) ) ); $extension = end( $extension ); if ( 'json' !== $extension ) { wp_send_json_error( array( 'message' => esc_html__( 'Please upload a valid .json file', 'google-analytics-for-wordpress' ), ) ); } $import_file = sanitize_text_field( wp_unslash( $_FILES['import_file']['tmp_name'] ) ); $file = file_get_contents( $import_file ); if ( empty( $file ) ) { wp_send_json_error( array( 'message' => esc_html__( 'Please upload a file to import', 'google-analytics-for-wordpress' ), ) ); } // Retrieve the settings from the file and convert the json object to an array. $new_settings = json_decode( wp_json_encode( json_decode( $file ) ), true ); $settings = monsterinsights_get_options(); $exclude = array( 'analytics_profile', 'analytics_profile_code', 'analytics_profile_name', 'oauth_version', 'cron_last_run', 'monsterinsights_oauth_status', ); foreach ( $exclude as $e ) { if ( ! empty( $new_settings[ $e ] ) ) { unset( $new_settings[ $e ] ); } } if ( ! is_super_admin() ) { if ( ! empty( $new_settings['custom_code'] ) ) { unset( $new_settings['custom_code'] ); } } foreach ( $exclude as $e ) { if ( ! empty( $settings[ $e ] ) ) { $new_settings = $settings[ $e ]; } } global $monsterinsights_settings; $monsterinsights_settings = $new_settings; update_option( monsterinsights_get_option_name(), $new_settings ); wp_send_json_success( $new_settings ); } /** * Generic Ajax handler for grabbing report data in JSON. */ public function get_report_data() { check_ajax_referer( 'mi-admin-nonce', 'nonce' ); if ( ! current_user_can( 'monsterinsights_view_dashboard' ) ) { wp_send_json_error( array( 'message' => __( "You don't have permission to view MonsterInsights reports.", 'google-analytics-for-wordpress' ) ) ); } if ( ! empty( $_REQUEST['isnetwork'] ) && $_REQUEST['isnetwork'] ) { define( 'WP_NETWORK_ADMIN', true ); } $settings_page = admin_url( 'admin.php?page=monsterinsights_settings' ); // Only for Pro users, require a license key to be entered first so we can link to things. if ( monsterinsights_is_pro_version() ) { if ( ! MonsterInsights()->license->is_site_licensed() && ! MonsterInsights()->license->is_network_licensed() ) { wp_send_json_error( array( 'message' => __( "You can't view MonsterInsights reports because you are not licensed.", 'google-analytics-for-wordpress' ), 'footer' => '' . __( 'Add your license', 'google-analytics-for-wordpress' ) . '', ) ); } else if ( MonsterInsights()->license->is_site_licensed() && ! MonsterInsights()->license->site_license_has_error() ) { // Good to go: site licensed. } else if ( MonsterInsights()->license->is_network_licensed() && ! MonsterInsights()->license->network_license_has_error() ) { // Good to go: network licensed. } else { wp_send_json_error( array( 'message' => __( "You can't view MonsterInsights reports due to license key errors.", 'google-analytics-for-wordpress' ) ) ); } } // We do not have a current auth. $site_auth = MonsterInsights()->auth->get_viewname(); $ms_auth = is_multisite() && MonsterInsights()->auth->get_network_viewname(); if ( ! $site_auth && ! $ms_auth ) { wp_send_json_error( array( 'message' => __( 'You must authenticate with MonsterInsights before you can view reports.', 'google-analytics-for-wordpress' ) ) ); } $report_name = isset( $_POST['report'] ) ? sanitize_text_field( wp_unslash( $_POST['report'] ) ) : ''; if ( empty( $report_name ) ) { wp_send_json_error( array( 'message' => __( 'Unknown report. Try refreshing and retrying. Contact support if this issue persists.', 'google-analytics-for-wordpress' ) ) ); } $report = MonsterInsights()->reporting->get_report( $report_name ); $isnetwork = ! empty( $_REQUEST['isnetwork'] ) ? sanitize_text_field( wp_unslash( $_REQUEST['isnetwork'] ) ) : ''; $start = ! empty( $_POST['start'] ) ? sanitize_text_field( wp_unslash( $_POST['start'] ) ) : $report->default_start_date(); $end = ! empty( $_POST['end'] ) ? sanitize_text_field( wp_unslash( $_POST['end'] ) ) : $report->default_end_date(); $args = array( 'start' => $start, 'end' => $end, ); if ( $isnetwork ) { $args['network'] = true; } if ( monsterinsights_is_pro_version() && ! MonsterInsights()->license->license_can( $report->level ) ) { $data = array( 'success' => false, 'error' => 'license_level', ); } else { $data = apply_filters( 'monsterinsights_vue_reports_data', $report->get_data( $args ), $report_name, $report ); } if ( ! empty( $data['success'] ) && ! empty( $data['data'] ) ) { wp_send_json_success( $data['data'] ); } else if ( isset( $data['success'] ) && false === $data['success'] && ! empty( $data['error'] ) ) { // Use a custom handler for invalid_grant errors. if ( strpos( $data['error'], 'invalid_grant' ) > 0 ) { wp_send_json_error( array( 'message' => 'invalid_grant', 'footer' => '', ) ); } wp_send_json_error( array( 'message' => $data['error'], 'footer' => isset( $data['data']['footer'] ) ? $data['data']['footer'] : '', ) ); } wp_send_json_error( array( 'message' => __( 'We encountered an error when fetching the report data.', 'google-analytics-for-wordpress' ) ) ); } /** * Install plugins which are not addons. */ public function install_plugin() { check_ajax_referer( 'mi-admin-nonce', 'nonce' ); if ( ! monsterinsights_can_install_plugins() ) { wp_send_json( array( 'error' => esc_html__( 'You are not allowed to install plugins', 'google-analytics-for-wordpress' ), ) ); } $slug = isset( $_POST['slug'] ) ? sanitize_text_field( wp_unslash( $_POST['slug'] ) ) : false; if ( ! $slug ) { wp_send_json( array( 'message' => esc_html__( 'Missing plugin name.', 'google-analytics-for-wordpress' ), ) ); } include_once ABSPATH . 'wp-admin/includes/plugin-install.php'; $api = plugins_api( 'plugin_information', array( 'slug' => $slug, 'fields' => array( 'short_description' => false, 'sections' => false, 'requires' => false, 'rating' => false, 'ratings' => false, 'downloaded' => false, 'last_updated' => false, 'added' => false, 'tags' => false, 'compatibility' => false, 'homepage' => false, 'donate_link' => false, ), ) ); if ( is_wp_error( $api ) ) { return $api->get_error_message(); } $download_url = $api->download_link; $method = ''; $url = add_query_arg( array( 'page' => 'monsterinsights-settings', ), admin_url( 'admin.php' ) ); $url = esc_url( $url ); ob_start(); if ( false === ( $creds = request_filesystem_credentials( $url, $method, false, false, null ) ) ) { $form = ob_get_clean(); wp_send_json( array( 'form' => $form ) ); } // If we are not authenticated, make it happen now. if ( ! WP_Filesystem( $creds ) ) { ob_start(); request_filesystem_credentials( $url, $method, true, false, null ); $form = ob_get_clean(); wp_send_json( array( 'form' => $form ) ); } // We do not need any extra credentials if we have gotten this far, so let's install the plugin. monsterinsights_require_upgrader(); // Prevent language upgrade in ajax calls. remove_action( 'upgrader_process_complete', array( 'Language_Pack_Upgrader', 'async_upgrade' ), 20 ); // Create the plugin upgrader with our custom skin. $installer = new MonsterInsights_Plugin_Upgrader( new MonsterInsights_Skin() ); $installer->install( $download_url ); // Flush the cache and return the newly installed plugin basename. wp_cache_flush(); wp_send_json_success(); wp_die(); } /** * Store that the first run notice has been dismissed so it doesn't show up again. */ public function dismiss_first_time_notice() { monsterinsights_update_option( 'monsterinsights_first_run_notice', true ); wp_send_json_success(); } /** * Get the notice status by id. */ public function get_notice_status() { check_ajax_referer( 'mi-admin-nonce', 'nonce' ); $notice_id = empty( $_POST['notice'] ) ? false : sanitize_text_field( wp_unslash( $_POST['notice'] ) ); if ( ! $notice_id ) { wp_send_json_error(); } $is_dismissed = MonsterInsights()->notices->is_dismissed( $notice_id ); wp_send_json_success( array( 'dismissed' => $is_dismissed, ) ); } /** * Dismiss notices by id. */ public function dismiss_notice() { check_ajax_referer( 'mi-admin-nonce', 'nonce' ); $notice_id = empty( $_POST['notice'] ) ? false : sanitize_text_field( wp_unslash( $_POST['notice'] ) ); if ( ! $notice_id ) { wp_send_json_error(); } MonsterInsights()->notices->dismiss( $notice_id ); wp_send_json_success(); } /** * Retrieve posts/pages * * @access admin * @since 3.0.0 */ public function get_posts() { // Run a security check first. check_ajax_referer( 'mi-admin-nonce', 'nonce' ); $post_type = isset( $_POST['post_type'] ) ? sanitize_text_field( wp_unslash( $_POST['post_type'] ) ) : 'any'; $args = array( 's' => isset( $_POST['keyword'] ) ? sanitize_text_field( wp_unslash( $_POST['keyword'] ) ) : '', 'post_type' => $post_type, 'posts_per_page' => isset( $_POST['numberposts'] ) ? sanitize_text_field( wp_unslash( $_POST['numberposts'] ) ) : 10, 'orderby' => 'relevance', ); $array = array(); $posts = get_posts( $args ); if ( in_array( $post_type, array( 'page', 'any' ), true ) ) { $homepage = get_option( 'page_on_front' ); if ( ! $homepage ) { $array[] = array( 'id' => - 1, 'title' => __( 'Homepage', 'google-analytics-for-wordpress' ), ); } } if ( $posts ) { foreach ( $posts as $post ) { $array[] = array( 'id' => $post->ID, 'title' => $post->post_title, ); } } wp_send_json_success( $array ); } /** * Search for taxonomy terms. * * @access admin * @since 3.0.0 */ public function get_taxonomy_terms() { // Run a security check first. check_ajax_referer( 'mi-admin-nonce', 'nonce' ); $keyword = isset( $_POST['keyword'] ) ? sanitize_text_field( wp_unslash( $_POST['keyword'] ) ) : ''; $taxonomy = isset( $_POST['taxonomy'] ) ? sanitize_text_field( wp_unslash( $_POST['taxonomy'] ) ) : 'category'; $args = array( 'taxonomy' => array( $taxonomy ), 'hide_empty' => false, 'name__like' => $keyword, ); $terms = get_terms( $args ); $array = array(); if ( ! empty( $terms ) ) { foreach ( $terms as $term ) { $array[] = array( 'id' => esc_attr( $term->term_id ), 'text' => esc_attr( $term->name ), ); } } wp_send_json_success( $array ); } /** * Get the post types in a name => Label array. */ public function get_post_types() { // Run a security check first. check_ajax_referer( 'mi-admin-nonce', 'nonce' ); $post_types_args = array( 'public' => true, ); $post_types = get_post_types( $post_types_args, 'objects' ); $post_types_parsed = array(); foreach ( $post_types as $post_type ) { // Exclude post types that don't support the content editor. // Exclude the WooCommerce product post type as that doesn't use the "the_content" filter and we can't auto-add popular posts to it. if ( ! post_type_supports( $post_type->name, 'editor' ) || 'product' === $post_type->name ) { continue; } $post_types_parsed[ $post_type->name ] = $post_type->labels->singular_name; } $post_types_parsed = apply_filters( 'monsterinsights_vue_post_types_editor', $post_types_parsed ); wp_send_json( $post_types_parsed ); } public function check_popular_posts_report() { check_ajax_referer( 'mi-admin-nonce', 'nonce' ); if ( ! current_user_can( 'monsterinsights_view_dashboard' ) ) { wp_send_json_error( array( 'message' => __( "You don't have permission to view MonsterInsights reports.", 'google-analytics-for-wordpress' ) ) ); } if ( ! empty( $_REQUEST['isnetwork'] ) && $_REQUEST['isnetwork'] ) { define( 'WP_NETWORK_ADMIN', true ); } $settings_page = admin_url( 'admin.php?page=monsterinsights_settings' ); // Only for Pro users, require a license key to be entered first so we can link to things. if ( monsterinsights_is_pro_version() ) { if ( ! MonsterInsights()->license->is_site_licensed() && ! MonsterInsights()->license->is_network_licensed() ) { wp_send_json_error( array( 'message' => __( "You can't view MonsterInsights reports because you are not licensed.", 'google-analytics-for-wordpress' ), 'footer' => '' . __( 'Add your license', 'google-analytics-for-wordpress' ) . '', ) ); } else if ( MonsterInsights()->license->is_site_licensed() && ! MonsterInsights()->license->site_license_has_error() ) { // Good to go: site licensed. } else if ( MonsterInsights()->license->is_network_licensed() && ! MonsterInsights()->license->network_license_has_error() ) { // Good to go: network licensed. } else { wp_send_json_error( array( 'message' => __( 'You can\'t view MonsterInsights reports due to license key errors.', 'google-analytics-for-wordpress' ) ) ); } } // We do not have a current auth. $site_auth = MonsterInsights()->auth->get_viewname(); $ms_auth = is_multisite() && MonsterInsights()->auth->get_network_viewname(); if ( ! $site_auth && ! $ms_auth ) { wp_send_json_error( array( 'message' => __( 'You must authenticate with MonsterInsights before you can view reports.', 'google-analytics-for-wordpress' ) ) ); } $report_name = 'popularposts'; if ( empty( $report_name ) ) { wp_send_json_error( array( 'message' => __( 'Unknown report. Try refreshing and retrying. Contact support if this issue persists.', 'google-analytics-for-wordpress' ) ) ); } $report = MonsterInsights()->reporting->get_report( $report_name ); $isnetwork = ! empty( $_REQUEST['isnetwork'] ) ? sanitize_text_field( wp_unslash( $_REQUEST['isnetwork'] ) ) : ''; $start = ! empty( $_POST['start'] ) ? sanitize_text_field( wp_unslash( $_POST['start'] ) ) : $report->default_start_date(); $end = ! empty( $_POST['end'] ) ? sanitize_text_field( wp_unslash( $_POST['end'] ) ) : $report->default_end_date(); $args = array( 'start' => $start, 'end' => $end, ); if ( $isnetwork ) { $args['network'] = true; } if ( monsterinsights_is_pro_version() && ! MonsterInsights()->license->license_can( $report->level ) ) { $data = array( 'success' => false, 'error' => 'license_level', ); } else { $data = apply_filters( 'monsterinsights_vue_reports_data', $report->get_data( $args ), $report_name, $report ); } if ( ! empty( $data['success'] ) && ! empty( $data['data'] ) ) { wp_send_json_success( $data['data'] ); } else if ( isset( $data['success'] ) && false === $data['success'] && ! empty( $data['error'] ) ) { // Use a custom handler for invalid_grant errors. if ( strpos( $data['error'], 'invalid_grant' ) > 0 ) { wp_send_json_error( array( 'message' => 'invalid_grant', 'footer' => '', ) ); } wp_send_json_error( array( 'message' => $data['error'], 'footer' => isset( $data['data']['footer'] ) ? $data['data']['footer'] : '', ) ); } wp_send_json_error( array( 'message' => __( 'We encountered an error when fetching the report data.', 'google-analytics-for-wordpress' ) ) ); } /** * Ajax handler for popular posts theme customization settings. * Specific theme styles are stored separately so we can handle 20+ themes with their specific settings. */ public function update_popular_posts_theme_setting() { check_ajax_referer( 'mi-admin-nonce', 'nonce' ); if ( ! current_user_can( 'monsterinsights_save_settings' ) ) { return; } if ( ! empty( $_POST['type'] ) && ! empty( $_POST['theme'] ) && ! empty( $_POST['object'] ) && ! empty( $_POST['key'] ) && ! empty( $_POST['value'] ) ) { $settings_key = 'monsterinsights_popular_posts_theme_settings'; $type = sanitize_text_field( wp_unslash( $_POST['type'] ) ); // Type of Popular Posts instance: inline/widget/products. $theme = sanitize_text_field( wp_unslash( $_POST['theme'] ) ); $object = sanitize_text_field( wp_unslash( $_POST['object'] ) ); // Style object like title, label, background, etc. $key = sanitize_text_field( wp_unslash( $_POST['key'] ) ); // Style key for the object like color, font size, etc. $value = sanitize_text_field( wp_unslash( $_POST['value'] ) ); // Value of custom style like 12px or #fff. $settings = get_option( $settings_key, array() ); if ( ! isset( $settings[ $type ] ) ) { $settings[ $type ] = array(); } if ( ! isset( $settings[ $type ][ $theme ] ) ) { $settings[ $type ][ $theme ] = array(); } if ( ! isset( $settings[ $type ][ $theme ][ $object ] ) ) { $settings[ $type ][ $theme ][ $object ] = array(); } $settings[ $type ][ $theme ][ $object ][ $key ] = $value; update_option( $settings_key, $settings ); wp_send_json_success(); } wp_send_json_error(); } }