Current File : //home/mdkeenpw/www/wp-content/plugins/google-analytics-for-wordpress/includes/admin/ajax.php |
<?php
/**
* Handles all admin ajax interactions for the MonsterInsights plugin.
*
* @since 6.0.0
*
* @package MonsterInsights
* @subpackage Ajax
* @author Chris Christoff
*/
// Exit if accessed directly
if ( ! defined( 'ABSPATH' ) ) {
exit;
}
/**
* Stores a user setting for the logged-in WordPress User
*
* @access public
* @since 6.0.0
*/
function monsterinsights_ajax_set_user_setting() {
// Run a security check first.
check_ajax_referer( 'monsterinsights-set-user-setting', 'nonce' );
// Prepare variables.
$name = stripslashes( !empty($_POST['name']) ? sanitize_text_field($_POST['name']) : '' );
$value = stripslashes( !empty($_POST['value']) ? sanitize_text_field($_POST['value']) : '' );
// Set user setting.
set_user_setting( $name, $value );
// Send back the response.
wp_send_json_success();
wp_die();
}
add_action( 'wp_ajax_monsterinsights_install_addon', 'monsterinsights_ajax_install_addon' );
/**
* Installs a MonsterInsights addon.
*
* @access public
* @since 6.0.0
*/
function monsterinsights_ajax_install_addon() {
// Run a security check first.
check_ajax_referer( 'monsterinsights-install', 'nonce' );
if ( ! monsterinsights_can_install_plugins() ) {
wp_send_json( array(
'error' => esc_html__( 'You are not allowed to install plugins', 'google-analytics-for-wordpress' ),
) );
}
// Install the addon.
if ( isset( $_POST['plugin'] ) ) {
$download_url = $_POST['plugin'];
global $hook_suffix;
// Set the current screen to avoid undefined notices.
set_current_screen();
// Prepare variables.
$method = '';
$url = add_query_arg(
array(
'page' => 'monsterinsights-settings'
),
admin_url( 'admin.php' )
);
$url = esc_url( $url );
// Start output bufferring to catch the filesystem form if credentials are needed.
ob_start();
if ( false === ( $creds = request_filesystem_credentials( $url, $method, false, false, null ) ) ) {
$form = ob_get_clean();
echo json_encode( array( 'form' => $form ) );
wp_die();
}
// 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();
echo json_encode( array( 'form' => $form ) );
wp_die();
}
// We do not need any extra credentials if we have gotten this far, so let's install the plugin.
monsterinsights_require_upgrader( false );
// Create the plugin upgrader with our custom skin.
$installer = new Plugin_Upgrader( $skin = new MonsterInsights_Skin() );
$installer->install( $download_url );
// Flush the cache and return the newly installed plugin basename.
wp_cache_flush();
if ( $installer->plugin_info() ) {
$plugin_basename = $installer->plugin_info();
echo json_encode( array( 'plugin' => $plugin_basename ) );
wp_die();
}
}
// Send back a response.
echo json_encode( true );
wp_die();
}
add_action( 'wp_ajax_monsterinsights_activate_addon', 'monsterinsights_ajax_activate_addon' );
/**
* Activates a MonsterInsights addon.
*
* @access public
* @since 6.0.0
*/
function monsterinsights_ajax_activate_addon() {
// Run a security check first.
check_ajax_referer( 'monsterinsights-activate', 'nonce' );
if ( ! current_user_can( 'activate_plugins' ) ) {
wp_send_json( array(
'error' => esc_html__( 'You are not allowed to activate plugins', 'google-analytics-for-wordpress' ),
) );
}
// Activate the addon.
if ( isset( $_POST['plugin'] ) ) {
$plugin = esc_attr( $_POST['plugin'] );
if ( isset( $_POST['isnetwork'] ) && $_POST['isnetwork'] ) {
$activate = activate_plugin( $plugin, null, true );
} else {
$activate = activate_plugin( $plugin );
}
/* Restrict thirt-party redirections on activation */
if ( "userfeedback-lite/userfeedback.php" === $plugin ) {
delete_transient( '_userfeedback_activation_redirect' );
}
if ( is_wp_error( $activate ) ) {
echo json_encode( array( 'error' => $activate->get_error_message() ) );
wp_die();
}
do_action( 'monsterinsights_after_ajax_activate_addon', sanitize_text_field( $_POST['plugin'] ) );
// FunnelKit Stripe Woo Payment Gateway activation.
if ( 'funnelkit-stripe-woo-payment-gateway/funnelkit-stripe-woo-payment-gateway.php' === $plugin ) {
monsterinsights_activate_plugin_funnelkit_stripe_woo_gateway();
}
}
echo json_encode( true );
wp_die();
}
add_action( 'wp_ajax_monsterinsights_deactivate_addon', 'monsterinsights_ajax_deactivate_addon' );
/**
* Deactivates a MonsterInsights addon.
*
* @access public
* @since 6.0.0
*/
function monsterinsights_ajax_deactivate_addon() {
// Run a security check first.
check_ajax_referer( 'monsterinsights-deactivate', 'nonce' );
if ( ! current_user_can( 'deactivate_plugins' ) ) {
wp_send_json( array(
'error' => esc_html__( 'You are not allowed to deactivate plugins', 'google-analytics-for-wordpress' ),
) );
}
// Deactivate the addon.
if ( isset( $_POST['plugin'] ) ) {
if ( isset( $_POST['isnetwork'] ) && $_POST['isnetwork'] ) {
$deactivate = deactivate_plugins( $_POST['plugin'], false, true );
} else {
$deactivate = deactivate_plugins( $_POST['plugin'] );
}
}
do_action( 'monsterinsights_after_ajax_deactivate_addon', sanitize_text_field( $_POST['plugin'] ) );
echo json_encode( true );
wp_die();
}
/**
* Called whenever a notice is dismissed in MonsterInsights or its Addons.
*
* Updates a key's value in the options table to mark the notice as dismissed,
* preventing it from displaying again
*
* @access public
* @since 6.0.0
*/
function monsterinsights_ajax_dismiss_notice() {
// Run a security check first.
check_ajax_referer( 'monsterinsights-dismiss-notice', 'nonce' );
// Deactivate the notice
if ( isset( $_POST['notice'] ) ) {
// Init the notice class and mark notice as deactivated
MonsterInsights()->notices->dismiss( $_POST['notice'] );
// Return true
echo json_encode( true );
wp_die();
}
// If here, an error occurred
echo json_encode( false );
wp_die();
}
add_action( 'wp_ajax_monsterinsights_ajax_dismiss_notice', 'monsterinsights_ajax_dismiss_notice' );
/**
* Dismiss SEMRush CTA
*
* @access public
* @since 7.12.3
*/
function monsterinsights_ajax_dismiss_semrush_cta() {
check_ajax_referer( 'mi-admin-nonce', 'nonce' );
if ( ! current_user_can( 'monsterinsights_save_settings' ) ) {
return;
}
// Deactivate the notice
if ( update_option( 'monsterinsights_dismiss_semrush_cta', 'yes' ) ) {
// Return true
wp_send_json( array(
'dismissed' => 'yes',
) );
wp_die();
}
// If here, an error occurred
wp_send_json( array(
'dismissed' => 'no',
) );
wp_die();
}
add_action( 'wp_ajax_monsterinsights_vue_dismiss_semrush_cta', 'monsterinsights_ajax_dismiss_semrush_cta' );
/**
* Dismiss AISEO plugin call-to-action
*
* @access public
* @since 8.22.1
*/
function monsterinsights_vue_dismiss_aiseo_cta() {
check_ajax_referer( 'mi-admin-nonce', 'nonce' );
if ( ! current_user_can( 'monsterinsights_save_settings' ) ) {
return;
}
// Deactivate the notice
if ( update_option( 'monsterinsights_dismiss_aiseo_cta', 'yes' ) ) {
// Return true
wp_send_json( array(
'dismissed' => 'yes',
) );
wp_die();
}
// If here, an error occurred
wp_send_json( array(
'dismissed' => 'no',
) );
wp_die();
}
add_action( 'wp_ajax_monsterinsights_vue_dismiss_aiseo_cta', 'monsterinsights_vue_dismiss_aiseo_cta' );
/**
* Get the sem rush cta dismiss status value
*/
function monsterinsights_get_sem_rush_cta_status() {
check_ajax_referer( 'mi-admin-nonce', 'nonce' );
$dismissed_cta = get_option( 'monsterinsights_dismiss_semrush_cta', 'no' );
wp_send_json( array(
'dismissed' => $dismissed_cta,
) );
}
add_action( 'wp_ajax_monsterinsights_get_sem_rush_cta_status', 'monsterinsights_get_sem_rush_cta_status' );
/**
* Checks if AISEO call-to-action is dismissed.
*
* @since 8.22.1
* @return void
*/
function monsterinsights_get_aiseo_cta_status() {
check_ajax_referer( 'mi-admin-nonce', 'nonce' );
$dismissed_cta = get_option( 'monsterinsights_dismiss_aiseo_cta', 'no' );
wp_send_json( array(
'dismissed' => $dismissed_cta,
) );
}
add_action( 'wp_ajax_monsterinsights_get_aiseo_cta_status', 'monsterinsights_get_aiseo_cta_status' );
function monsterinsights_handle_get_plugin_info() {
$auth = MonsterInsights()->auth;
// Authenticate with public key
$key = !empty($_REQUEST['key']) ? sanitize_text_field($_REQUEST['key']) : ''; // phpcs:ignore WordPress.Security.NonceVerification.Recommended
$site_key = is_network_admin() ? $auth->get_network_key() : $auth->get_key();
if ( !hash_equals( $site_key, $key ) ) {
wp_send_json_error([
'error' => __( 'Invalid site key.', 'google-analytics-for-wordpress' )
], 401);
}
$v4 = is_network_admin() ? $auth->get_network_v4_id() : $auth->get_v4_id();
$has_secret = is_network_admin() ?
!empty( $auth->get_network_measurement_protocol_secret() ) :
!empty( $auth->get_measurement_protocol_secret() );
wp_send_json([
'v4' => $v4,
'has_mp_secret' => $has_secret,
'plugin_version' => MonsterInsights()->version
]);
}
add_action( 'wp_ajax_nopriv_monsterinsights_get_plugin_info', 'monsterinsights_handle_get_plugin_info' );
/**
* User journey report show demo report for not licensed.
*
* @return void
* @since 8.16
*/
function monsterinsights_user_journey_demo_report_ajax() {
$report = array();
$sources = array( 'google', 'newsletter', 'billboard' );
$mediums = array( 'cpc', 'banner', 'email' );
$campaigns = array( 'campaign-name', 'slogan', 'promo-code' );
for ( $i = 1; $i <= 13; $i ++ ) {
$rand_key = array_rand( $sources );
$report[] = array(
'transaction_id' => wp_rand( 12, 30 ),
'steps' => wp_rand( 3, 8 ),
'order_total' => wp_rand( 10, 50 ),
'utm_source' => $sources[ $rand_key ],
'utm_medium' => $mediums[ $rand_key ],
'utm_campaign' => $campaigns[ $rand_key ],
'purchase_date' => '--',
);
}
wp_send_json( array( 'items' => $report, 'demo' => true ) );
}
$license_type = MonsterInsights()->license->get_license_type();
// If it is not a pro licensed.
if ( ! ( $license_type === 'master' || $license_type === 'pro' ) ) {
add_action( 'wp_ajax_monsterinsights_user_journey_report', 'monsterinsights_user_journey_demo_report_ajax' );
add_action( 'wp_ajax_monsterinsights_user_journey_report_filter_params', '__return_false' );
}
/**
* Plugin FunnelKit Stripe Woo Payment Gateway activation.
*
* @return void
*/
function monsterinsights_activate_plugin_funnelkit_stripe_woo_gateway() {
// Add FunnelKit partner ID. For MonsterInsights is 3f6c515da4bdcb59afc860b305a0cc3e .
update_option( 'fkwcs_wp_stripe', '3f6c515da4bdcb59afc860b305a0cc3e', false );
}
/**
* Plugin FunnelKit Stripe Woo Payment Gateway, check if Stripe is connected.
*
* @access public
* @since 6.0.0
*/
function monsterinsights_check_plugin_funnelkit_funnelkit_stripe_woo_gateway_configured() {
// Run a security check first.
check_ajax_referer( 'monsterinsights-funnelkit-stripe-woo-nonce', 'nonce' );
$fkwcs_con_status = get_option('fkwcs_con_status');
if ( 'success' === $fkwcs_con_status ) {
echo json_encode( true );
wp_die();
}
echo json_encode( false );
wp_die();
}
add_action( 'wp_ajax_monsterinsights_funnelkit_stripe_woo_gateway_configured', 'monsterinsights_check_plugin_funnelkit_funnelkit_stripe_woo_gateway_configured' );
/**
* AJAX handler to dismiss WPConsent notice.
*/
function monsterinsights_ajax_dismiss_wpconsent_notice() {
// Check nonce for security
check_ajax_referer( 'monsterinsights-dismiss-notice', 'nonce' );
// Check if user has proper capabilities
if ( ! current_user_can( 'manage_options' ) ) {
wp_send_json_error( array( 'message' => 'Insufficient permissions' ) );
return;
}
// Save the dismissal
update_option( 'monsterinsights_wpconsent_notice_dismissed', true );
wp_send_json_success( array( 'dismissed' => true ) );
}
add_action( 'wp_ajax_monsterinsights_dismiss_wpconsent_notice', 'monsterinsights_ajax_dismiss_wpconsent_notice' );