HEX
Server: Apache
System: Linux elegant-goodall 5.15.0-107-generic #117-Ubuntu SMP Fri Apr 26 12:26:49 UTC 2024 x86_64
User: allende-losmares.com_h71qfkqzx8k (10002)
PHP: 8.0.30
Disabled: opcache_get_status
Upload Files
File: /var/www/vhosts/allende-losmares.com/httpdocs/wp-content/plugins/wp-seopress-pro/inc/admin/cron.php
<?php
if ( ! defined('ABSPATH')) {
    exit;
}

///////////////////////////////////////////////////////////////////////////////////////////////////
//Request Google PageSpeed Insights
///////////////////////////////////////////////////////////////////////////////////////////////////
function seopress_request_page_speed_fn($cron = false) {
    $options = get_option('seopress_pro_option_name');

    //Save URLs field
    if (isset($_POST['seopress_ps_url'])) {
        $options['seopress_ps_url'] = sanitize_textarea_field($_POST['seopress_ps_url']);
        update_option('seopress_pro_option_name', $options);
    } elseif (isset($options['seopress_ps_url'])) {
        $seopress_get_site_url = $options['seopress_ps_url'];
    } else {
        $seopress_get_site_url = get_home_url();
    }

    $options = get_option('seopress_pro_option_name');

    //Save API key
    if (isset($_POST['seopress_ps_api_key'])) {
        $options['seopress_ps_api_key'] = sanitize_textarea_field($_POST['seopress_ps_api_key']);
        update_option('seopress_pro_option_name', $options);
    }

    $options = get_option('seopress_pro_option_name');

    $seopress_google_api_key = ! empty($options['seopress_ps_api_key']) ? $options['seopress_ps_api_key'] : 'AIzaSyBqvSx2QrqbEqZovzKX8znGpTosw7KClHQ';
    $seopress_get_site_url = ! empty($options['seopress_ps_url']) ? $options['seopress_ps_url'] : get_home_url();

    delete_transient('seopress_results_page_speed');
    delete_transient('seopress_results_page_speed_desktop');

    $args = ['timeout' => 30, 'blocking' => true];

    //Mobile
    if (false === ($seopress_results_page_speed_cache = get_transient('seopress_results_page_speed'))) {
        $seopress_results_page_speed = wp_remote_retrieve_body(wp_remote_get('https://www.googleapis.com/pagespeedonline/v5/runPagespeed?url=' . $seopress_get_site_url . '&key=' . $seopress_google_api_key . '&screenshot=true&strategy=mobile&category=performance&category=seo&category=best-practices&locale=' . get_locale(), $args));
        $seopress_results_page_speed_cache = $seopress_results_page_speed;
        set_transient('seopress_results_page_speed', $seopress_results_page_speed_cache, 1 * DAY_IN_SECONDS);
    }

    //Desktop
    if (false === ($seopress_results_page_speed_desktop_cache = get_transient('seopress_results_page_speed_desktop'))) {
        $seopress_results_page_speed_desktop = wp_remote_retrieve_body(wp_remote_get('https://www.googleapis.com/pagespeedonline/v5/runPagespeed?url=' . $seopress_get_site_url . '&key=' . $seopress_google_api_key . '&screenshot=true&strategy=desktop&category=performance&locale=' . get_locale(), $args));
        $seopress_results_page_speed_desktop_cache = $seopress_results_page_speed_desktop;
        set_transient('seopress_results_page_speed_desktop', $seopress_results_page_speed_desktop_cache, 1 * DAY_IN_SECONDS);
    }
    $data = ['url' => add_query_arg('ps', 'done', remove_query_arg(['data_permalink', 'ps'], admin_url('admin.php?page=seopress-pro-page&ps=done#tab=tab_seopress_page_speed')))];

    if ($cron === false) {
        wp_send_json_success($data);
    }
    exit();
}
/**
 * Request Page Speed Insights by CRON.
 *
 * @since 5.3
 * @param boolean Is is a CRON request?
 *
 * @author Benjamin
 */
function seopress_request_page_speed_insights_cron() {
    seopress_request_page_speed_fn(true);
}
add_action('seopress_page_speed_insights_cron', 'seopress_request_page_speed_insights_cron');

function seopress_request_page_speed() {
    check_ajax_referer('seopress_request_page_speed_nonce');

    if (current_user_can(seopress_capability('manage_options', 'cron')) && is_admin()) {
        seopress_request_page_speed_fn();
    }
}
add_action('wp_ajax_seopress_request_page_speed', 'seopress_request_page_speed');

///////////////////////////////////////////////////////////////////////////////////////////////////
//Request Google Analytics
///////////////////////////////////////////////////////////////////////////////////////////////////
use Google\Analytics\Data\V1beta\BetaAnalyticsDataClient;
use Google\Analytics\Data\V1beta\DateRange;
use Google\Analytics\Data\V1beta\Dimension;
use Google\Analytics\Data\V1beta\OrderBy;
use Google\Analytics\Data\V1beta\Metric;
use Google\ApiCore\ApiException;
use Google\Auth\OAuth2;

function seopress_request_google_analytics_fn($clear = false) {
    if (function_exists('seopress_google_analytics_dashboard_widget_option') && seopress_google_analytics_dashboard_widget_option() === '1') {
        exit();
    }

    /**
     * @deprecated 5.9.0
     * @uses seopress_get_service('GoogleAnalyticsOption')
     */
    function seopress_google_analytics_auth_option() {
        $service = seopress_get_service('GoogleAnalyticsOption');

        if ( ! empty($service) || ! method_exists($service, 'getAuth')) {
            $data = get_option('seopress_google_analytics_option_name');
            if (isset($data['seopress_google_analytics_auth'])) {
                return $data['seopress_google_analytics_auth'];
            }
        }

        return $service->getAuth();
    }

    /**
    * @deprecated 5.9.0
    * @uses seopress_get_service('GoogleAnalyticsOption')
    */
    function seopress_google_analytics_auth_client_id_option() {
        $service = seopress_get_service('GoogleAnalyticsOption');

        if ( ! empty($service) || ! method_exists($service, 'getAuthClientId')) {
            $data = get_option('seopress_google_analytics_option_name');
            if (isset($data['seopress_google_analytics_auth_client_id'])) {
                return $data['seopress_google_analytics_auth_client_id'];
            }
        }

        return $service->getAuthClientId();
    }

    /**
     * @deprecated 5.9.0
     * @uses seopress_get_service('GoogleAnalyticsOption')
     */
    function seopress_google_analytics_auth_secret_id_option() {
        $service = seopress_get_service('GoogleAnalyticsOption');

        if ( ! empty($service) || ! method_exists($service, 'getAuthSecretId')) {
            $data = get_option('seopress_google_analytics_option_name');
            if (isset($data['seopress_google_analytics_auth_secret_id'])) {
                return $data['seopress_google_analytics_auth_secret_id'];
            }
        }

        return $service->getAuthSecretId();
    }


    /**
     * @deprecated 5.9.0
     * @uses seopress_pro_get_service('GoogleAnalyticsPro')
     */
    function seopress_google_analytics_auth_token_option() {
        return seopress_pro_get_service('GoogleAnalyticsOptionPro')->getAccessToken();
    }

    /**
    * @deprecated 5.9.0
    * @uses seopress_pro_get_service('GoogleAnalyticsPro')
    */
    function seopress_google_analytics_refresh_token_option() {
        return seopress_pro_get_service('GoogleAnalyticsOptionPro')->getRefreshToken();
    }

    /**
     * @deprecated 5.9.0
     * @uses seopress_pro_get_service('GoogleAnalyticsPro')
     */
    function seopress_google_analytics_debug_option() {
        return seopress_pro_get_service('GoogleAnalyticsOptionPro')->getDebug();
    }

    /**
     * @deprecated 5.9.0
     * @uses seopress_get_service('GoogleAnalyticsOption')
     */
    function seopress_google_analytics_ga4_2_option() {
       return seopress_get_service('GoogleAnalyticsOption')->getGA4();
    }

    /**
     * @deprecated 5.9.0
     * @uses seopress_get_service('GoogleAnalyticsOption')
     */
    function seopress_google_analytics_ga4_property_id_option() {
        $service = seopress_get_service('GoogleAnalyticsOption');

        if ( ! empty($service) || ! method_exists($service, 'getGA4PropertId')) {
            $data = get_option('seopress_google_analytics_option_name');
            if (isset($data['seopress_google_analytics_ga4_property_id'])) {
                return $data['seopress_google_analytics_ga4_property_id'];
            }
        }

        return $service->getGA4PropertId();
    }

    $authOption = seopress_google_analytics_auth_option();
    if ((!empty($authOption)  || '' != seopress_google_analytics_ga4_property_id_option() ) && '' != seopress_google_analytics_auth_token_option()) {

        try {
            // get saved data
            if ( ! $widget_options = get_option('seopress_ga_dashboard_widget_options')) {
                $widget_options = [];
            }

            // check if saved data contains content
            $seopress_ga_dashboard_widget_options_period = isset($widget_options['period']) ? $widget_options['period'] : false;

            $seopress_ga_dashboard_widget_options_type = isset($widget_options['type']) ? $widget_options['type'] : 'ga_sessions';

            // custom content saved by control callback, modify output
            if ($seopress_ga_dashboard_widget_options_period) {
                $period = $seopress_ga_dashboard_widget_options_period;
            } else {
                $period = '30daysAgo';
            }

            $client_id = seopress_google_analytics_auth_client_id_option();
            $client_secret = seopress_google_analytics_auth_secret_id_option();

            if(empty($client_id) || empty($client_secret)) {
                return;
            }

            $ga_account = 'ga:' . $authOption;
            $redirect_uri = admin_url('admin.php?page=seopress-google-analytics');

            require_once SEOPRESS_PRO_PLUGIN_DIR_PATH . '/vendor/autoload.php';

            $oauth = new OAuth2([
                'scope' => 'https://www.googleapis.com/auth/analytics.readonly',
                'tokenCredentialUri' => 'https://oauth2.googleapis.com/token',
                'authorizationUri' => 'https://accounts.google.com/o/oauth2/auth',
                'clientId' => seopress_google_analytics_auth_client_id_option(),
                'clientSecret' => seopress_google_analytics_auth_secret_id_option(),
                'redirectUri' => admin_url('admin.php?page=seopress-google-analytics'),
            ]);

            $client = new Google_Client();
            $client->setApplicationName('Client_Library_Examples');
            $client->setClientId($client_id);
            $client->setClientSecret($client_secret);
            $client->setRedirectUri($redirect_uri);
            $client->setScopes(['https://www.googleapis.com/auth/analytics.readonly']);
            $client->setApprovalPrompt('force');   // mandatory to get this fucking refreshtoken
            $client->setAccessType('offline'); // mandatory to get this fucking refreshtoken

            $client->setAccessToken(seopress_google_analytics_debug_option());

            if ($client->isAccessTokenExpired()) {
                $client->refreshToken(seopress_google_analytics_debug_option());

                $seopress_new_access_token = $client->getAccessToken(seopress_google_analytics_debug_option());

                $seopress_google_analytics_options = get_option('seopress_google_analytics_option_name1');
                $seopress_google_analytics_options['access_token'] = $seopress_new_access_token['access_token'];
                $seopress_google_analytics_options['refresh_token'] = $seopress_new_access_token['refresh_token'];
                $seopress_google_analytics_options['debug'] = $seopress_new_access_token;
                update_option('seopress_google_analytics_option_name1', $seopress_google_analytics_options, 'yes');
            }

            $service = new Google_Service_AnalyticsReporting($client);

            $oauth->setAccessToken(seopress_google_analytics_auth_token_option());
            $oauth->setRefreshToken(seopress_google_analytics_refresh_token_option());

            // GA4 Stats
            $all = [];

            //Get GA4 property ID
            $property_id = '';
            if (seopress_google_analytics_ga4_property_id_option()) {
                $property_id = seopress_google_analytics_ga4_property_id_option();

                //Get GA4 data
                $ga4_data = new BetaAnalyticsDataClient(['credentials' => $oauth]);

                // sessions
                $sessions = $ga4_data->runReport(
                    [
                        'property' => 'properties/' . $property_id,
                        'dateRanges' => [
                            new DateRange([
                                'start_date' => $period,
                                'end_date' => 'today',
                            ]),
                        ],
                        'dimensions' => [new Dimension([
                            'name' => 'date',
                        ]),
                        ],
                        'metrics' => [new Metric([
                            'name' => 'sessions',
                        ]),
                        ],
                        'orderBys' => [
                            new OrderBy([
                                'dimension' => new OrderBy\DimensionOrderBy([
                                    'dimension_name' => 'date',
                                    'order_type' => OrderBy\DimensionOrderBy\OrderType::ALPHANUMERIC
                                ]),
                                'desc' => false,
                            ]),
                        ],
                    ]
                );

                $users = $ga4_data->runReport(
                    [
                        'property' => 'properties/' . $property_id,
                        'dateRanges' => [
                            new DateRange([
                                'start_date' => $period,
                                'end_date' => 'today',
                            ]),
                        ],
                        'dimensions' => [new Dimension([
                            'name' => 'date',
                        ]),
                        ],
                        'metrics' => [new Metric([
                            'name' => 'totalUsers',
                        ]),
                        ],
                        'orderBys' => [
                            new OrderBy([
                                'dimension' => new OrderBy\DimensionOrderBy([
                                    'dimension_name' => 'date',
                                    'order_type' => OrderBy\DimensionOrderBy\OrderType::ALPHANUMERIC
                                ]),
                                'desc' => false,
                            ]),
                        ],
                    ]
                );

                $pageviews = $ga4_data->runReport(
                    [
                        'property' => 'properties/' . $property_id,
                        'dateRanges' => [
                            new DateRange([
                                'start_date' => $period,
                                'end_date' => 'today',
                            ]),
                        ],
                        'dimensions' => [new Dimension([
                            'name' => 'date',
                        ]),
                        ],
                        'metrics' => [new Metric([
                            'name' => 'screenPageViews',
                        ]),
                        ],
                        'orderBys' => [
                            new OrderBy([
                                'dimension' => new OrderBy\DimensionOrderBy([
                                    'dimension_name' => 'date',
                                    'order_type' => OrderBy\DimensionOrderBy\OrderType::ALPHANUMERIC
                                ]),
                                'desc' => false,
                            ]),
                        ],
                    ]
                );

                $avgSessionDuration = $ga4_data->runReport(
                    [
                        'property' => 'properties/' . $property_id,
                        'dateRanges' => [
                            new DateRange([
                                'start_date' => $period,
                                'end_date' => 'today',
                            ]),
                        ],
                        'dimensions' => [new Dimension([
                            'name' => 'date',
                        ]),
                        ],
                        'metrics' => [new Metric([
                            'name' => 'userEngagementDuration',
                        ]),
                        ],
                        'orderBys' => [
                            new OrderBy([
                                'dimension' => new OrderBy\DimensionOrderBy([
                                    'dimension_name' => 'date',
                                    'order_type' => OrderBy\DimensionOrderBy\OrderType::ALPHANUMERIC
                                ]),
                                'desc' => false,
                            ]),
                        ],
                    ]
                );

                $results = [
                    'sessions' => $sessions,
                    'users' => $users,
                    'pageviews' => $pageviews,
                    'avgSessionDuration' => $avgSessionDuration
                ];

                foreach ($results as $key => $value) {
                    foreach ($value->getRows() as $row) {
                        $all[0][$key][$row->getDimensionValues()[0]->getValue()] = $row->getMetricValues()[0]->getValue();
                    }
                }
            }

            if (true === $clear) {
                delete_transient('seopress_results_google_analytics');
            }

            if (false === ($seopress_results_google_analytics_cache = get_transient('seopress_results_google_analytics'))) {
                $seopress_results_google_analytics_cache = [];

                //////GA4/////////////
                if (seopress_google_analytics_ga4_property_id_option()) {
                    $seopress_results_google_analytics_cache['sessions'] = isset($all[0]['sessions']) && is_array($all[0]['sessions']) ? array_sum($all[0]['sessions']) : 0;
                    $seopress_results_google_analytics_cache['users'] = isset($all[0]['users']) && is_array($all[0]['users']) ? array_sum($all[0]['users']) : 0;
                    $seopress_results_google_analytics_cache['pageviews'] = isset($all[0]['pageviews']) && is_array($all[0]['pageviews']) ? array_sum($all[0]['pageviews']) : 0;


                    $seopress_results_google_analytics_cache['avgSessionDuration'] = 0;
                    if (isset($all[0]['avgSessionDuration']) && is_array($all[0]['avgSessionDuration'])) {
                        $sum = array_sum($all[0]['avgSessionDuration']);
                        $divided = count($all[0]['avgSessionDuration']);
                        if ($divided === 0) {
                            $divided = 1;
                        }

                        $seopress_results_google_analytics_cache['avgSessionDuration'] = gmdate('i:s', $sum / $divided);
                    }


                    switch ($seopress_ga_dashboard_widget_options_type) {
                        case 'ga_sessions':
                            $ga_sessions_rows = $all[0]['sessions'];
                            $seopress_ga_dashboard_widget_options_title = __('Sessions', 'wp-seopress-pro');
                            break;
                        case 'ga_users':
                            $ga_sessions_rows = $all[0]['users'];
                            $seopress_ga_dashboard_widget_options_title = __('Users', 'wp-seopress-pro');
                            break;
                        case 'ga_pageviews':
                            $ga_sessions_rows = $all[0]['pageviews'];
                            $seopress_ga_dashboard_widget_options_title = __('Page Views', 'wp-seopress-pro');
                            break;
                        case 'ga_avgSessionDuration':
                            $ga_sessions_rows = $all[0]['avgSessionDuration'];
                            $seopress_ga_dashboard_widget_options_title = __('Session Duration', 'wp-seopress-pro');
                            break;
                        default:
                            $ga_sessions_rows = $all[0]['sessions'];
                            $seopress_ga_dashboard_widget_options_title = __('Sessions', 'wp-seopress-pro');
                    }

                    function seopress_ga_dashboard_4_get_sessions_labels($ga_date) {
                        $labels = [];
                        foreach ($ga_date as $key => $value) {
                            array_push($labels, date_i18n(get_option('date_format'), strtotime($key)));
                        }

                        return $labels;
                    }

                    function seopress_ga_dashboard_4_get_sessions_data($ga_sessions_rows) {
                        $data = [];
                        foreach ($ga_sessions_rows as $key => $value) {
                            array_push($data, $value);
                        }

                        return $data;
                    }
                    $seopress_results_google_analytics_cache['sessions_graph_labels'] = seopress_ga_dashboard_4_get_sessions_labels($ga_sessions_rows);
                    $seopress_results_google_analytics_cache['sessions_graph_data'] = seopress_ga_dashboard_4_get_sessions_data($ga_sessions_rows);
                    $seopress_results_google_analytics_cache['sessions_graph_title'] = $seopress_ga_dashboard_widget_options_title;
                } else {

                    ////////////////////////////////////////////////////////////////////////////////////////
                    //Request Google Stats
                    ////////////////////////////////////////////////////////////////////////////////////////

                    //DATE RANGE
                    ////////////////////////////////////////////////////////////////////////////////////////

                    // Date
                    $dateRange = new Google_Service_AnalyticsReporting_DateRange();
                    $dateRange->setStartDate($period);
                    $dateRange->setEndDate('today');

                    //METRICS
                    ////////////////////////////////////////////////////////////////////////////////////////

                    // Sessions
                    $sessions = new Google_Service_AnalyticsReporting_Metric();
                    $sessions->setExpression('ga:sessions');
                    $sessions->setAlias('sessions');

                    // Users
                    $users = new Google_Service_AnalyticsReporting_Metric();
                    $users->setExpression('ga:users');
                    $users->setAlias('users');

                    // Page Views
                    $pageviews = new Google_Service_AnalyticsReporting_Metric();
                    $pageviews->setExpression('ga:pageviews');
                    $pageviews->setAlias('pageviews');

                    // Page Views per session
                    $pageviewsPerSession = new Google_Service_AnalyticsReporting_Metric();
                    $pageviewsPerSession->setExpression('ga:pageviewsPerSession');
                    $pageviewsPerSession->setAlias('pageviewsPerSession');

                    // Average session duration
                    $avgSessionDuration = new Google_Service_AnalyticsReporting_Metric();
                    $avgSessionDuration->setExpression('ga:avgSessionDuration');
                    $avgSessionDuration->setAlias('avgSessionDuration');

                    // Bounce rate
                    $bounceRate = new Google_Service_AnalyticsReporting_Metric();
                    $bounceRate->setExpression('ga:bounceRate');
                    $bounceRate->setAlias('bounceRate');

                    // % New sessions
                    $percentNewSessions = new Google_Service_AnalyticsReporting_Metric();
                    $percentNewSessions->setExpression('ga:percentNewSessions');
                    $percentNewSessions->setAlias('percentNewSessions');

                    // Total events
                    $totalEvents = new Google_Service_AnalyticsReporting_Metric();
                    $totalEvents->setExpression('ga:totalEvents');
                    $totalEvents->setAlias('totalEvents');

                    // Unique events
                    $uniqueEvents = new Google_Service_AnalyticsReporting_Metric();
                    $uniqueEvents->setExpression('ga:uniqueEvents');
                    $uniqueEvents->setAlias('uniqueEvents');

                    //DIMENSIONS
                    ////////////////////////////////////////////////////////////////////////////////////////

                    // Date
                    $date = new Google_Service_AnalyticsReporting_Dimension();
                    $date->setName('ga:date');

                    // Language
                    $language = new Google_Service_AnalyticsReporting_Dimension();
                    $language->setName('ga:language');

                    // Country
                    $country = new Google_Service_AnalyticsReporting_Dimension();
                    $country->setName('ga:country');

                    // Device Category
                    $deviceCategory = new Google_Service_AnalyticsReporting_Dimension();
                    $deviceCategory->setName('ga:deviceCategory');

                    // Browser
                    $browser = new Google_Service_AnalyticsReporting_Dimension();
                    $browser->setName('ga:browser');

                    // Social Network
                    $socialNetwork = new Google_Service_AnalyticsReporting_Dimension();
                    $socialNetwork->setName('ga:socialNetwork');

                    // Channel Grouping
                    $channelGrouping = new Google_Service_AnalyticsReporting_Dimension();
                    $channelGrouping->setName('ga:channelGrouping');

                    // Source
                    $source = new Google_Service_AnalyticsReporting_Dimension();
                    $source->setName('ga:source');

                    // Full Referrer
                    $fullReferrer = new Google_Service_AnalyticsReporting_Dimension();
                    $fullReferrer->setName('ga:fullReferrer');

                    // Page Title
                    $pageTitle = new Google_Service_AnalyticsReporting_Dimension();
                    $pageTitle->setName('ga:pageTitle');

                    // Event Category
                    $eventCategory = new Google_Service_AnalyticsReporting_Dimension();
                    $eventCategory->setName('ga:eventCategory');

                    // Event Action
                    $eventAction = new Google_Service_AnalyticsReporting_Dimension();
                    $eventAction->setName('ga:eventAction');

                    // Event Label
                    $eventLabel = new Google_Service_AnalyticsReporting_Dimension();
                    $eventLabel->setName('ga:eventLabel');

                    //ORDERS
                    ////////////////////////////////////////////////////////////////////////////////////////

                    // Order by user desc
                    $order_by_users_desc = new Google_Service_AnalyticsReporting_OrderBy();
                    $order_by_users_desc->setFieldName('ga:users');
                    $order_by_users_desc->setOrderType('VALUE');
                    $order_by_users_desc->setSortOrder('DESCENDING');

                    // Order by page views desc
                    $order_by_pageviews_desc = new Google_Service_AnalyticsReporting_OrderBy();
                    $order_by_pageviews_desc->setFieldName('ga:pageviews');
                    $order_by_pageviews_desc->setOrderType('VALUE');
                    $order_by_pageviews_desc->setSortOrder('DESCENDING');

                    // Order by total events desc
                    $order_by_events_desc = new Google_Service_AnalyticsReporting_OrderBy();
                    $order_by_events_desc->setFieldName('ga:totalEvents');
                    $order_by_events_desc->setOrderType('VALUE');
                    $order_by_events_desc->setSortOrder('DESCENDING');

                    //REPORTS
                    ////////////////////////////////////////////////////////////////////////////////////////

                    // Sessions, Users, Page Views, Page Views Per Session, Average Session Duration, Bounce Rate, New Sessions, Total Events and Unique Events by Date
                    $request_by_date = new Google_Service_AnalyticsReporting_ReportRequest();
                    $request_by_date->setViewId(seopress_google_analytics_auth_option());
                    $request_by_date->setDateRanges($dateRange);
                    $request_by_date->setDimensions([$date]);
                    $request_by_date->setMetrics([$sessions, $users, $pageviews, $pageviewsPerSession, $avgSessionDuration, $bounceRate, $percentNewSessions, $totalEvents, $uniqueEvents]);
                    $request_by_date->setSamplingLevel('SMALL');

                    // Users by language
                    $request_users_by_language = new Google_Service_AnalyticsReporting_ReportRequest();
                    $request_users_by_language->setViewId(seopress_google_analytics_auth_option());
                    $request_users_by_language->setDateRanges($dateRange);
                    $request_users_by_language->setDimensions([$language]);
                    $request_users_by_language->setMetrics([$users]);
                    $request_users_by_language->setSamplingLevel('SMALL');
                    $request_users_by_language->setOrderBys($order_by_users_desc);

                    // Users by country
                    $request_users_by_country = new Google_Service_AnalyticsReporting_ReportRequest();
                    $request_users_by_country->setViewId(seopress_google_analytics_auth_option());
                    $request_users_by_country->setDateRanges($dateRange);
                    $request_users_by_country->setDimensions([$country]);
                    $request_users_by_country->setMetrics([$users]);
                    $request_users_by_country->setSamplingLevel('SMALL');
                    $request_users_by_country->setOrderBys($order_by_users_desc);

                    // Users by device category
                    $request_users_by_device_cat = new Google_Service_AnalyticsReporting_ReportRequest();
                    $request_users_by_device_cat->setViewId(seopress_google_analytics_auth_option());
                    $request_users_by_device_cat->setDateRanges($dateRange);
                    $request_users_by_device_cat->setDimensions([$deviceCategory]);
                    $request_users_by_device_cat->setMetrics([$users]);
                    $request_users_by_device_cat->setSamplingLevel('SMALL');
                    $request_users_by_device_cat->setOrderBys($order_by_users_desc);

                    // Users by Browser
                    $request_users_by_browser = new Google_Service_AnalyticsReporting_ReportRequest();
                    $request_users_by_browser->setViewId(seopress_google_analytics_auth_option());
                    $request_users_by_browser->setDateRanges($dateRange);
                    $request_users_by_browser->setDimensions([$browser]);
                    $request_users_by_browser->setMetrics([$users]);
                    $request_users_by_browser->setSamplingLevel('SMALL');
                    $request_users_by_browser->setOrderBys($order_by_users_desc);

                    // Users by Social Networks
                    $request_users_by_social_network = new Google_Service_AnalyticsReporting_ReportRequest();
                    $request_users_by_social_network->setViewId(seopress_google_analytics_auth_option());
                    $request_users_by_social_network->setDateRanges($dateRange);
                    $request_users_by_social_network->setDimensions([$socialNetwork]);
                    $request_users_by_social_network->setMetrics([$users]);
                    $request_users_by_social_network->setSamplingLevel('SMALL');
                    $request_users_by_social_network->setOrderBys($order_by_users_desc);

                    // Users by Channel
                    $request_users_by_channel = new Google_Service_AnalyticsReporting_ReportRequest();
                    $request_users_by_channel->setViewId(seopress_google_analytics_auth_option());
                    $request_users_by_channel->setDateRanges($dateRange);
                    $request_users_by_channel->setDimensions([$channelGrouping]);
                    $request_users_by_channel->setMetrics([$users]);
                    $request_users_by_channel->setSamplingLevel('SMALL');

                    // Users by Source
                    $request_users_by_source = new Google_Service_AnalyticsReporting_ReportRequest();
                    $request_users_by_source->setViewId(seopress_google_analytics_auth_option());
                    $request_users_by_source->setDateRanges($dateRange);
                    $request_users_by_source->setDimensions([$source]);
                    $request_users_by_source->setMetrics([$users]);
                    $request_users_by_source->setSamplingLevel('SMALL');
                    $request_users_by_source->setOrderBys($order_by_users_desc);

                    // Users by Referrer
                    $request_users_by_ref = new Google_Service_AnalyticsReporting_ReportRequest();
                    $request_users_by_ref->setViewId(seopress_google_analytics_auth_option());
                    $request_users_by_ref->setDateRanges($dateRange);
                    $request_users_by_ref->setDimensions([$fullReferrer]);
                    $request_users_by_ref->setMetrics([$users]);
                    $request_users_by_ref->setSamplingLevel('SMALL');
                    $request_users_by_ref->setOrderBys($order_by_users_desc);

                    // Page Views by Page Title
                    $request_page_views_page_title = new Google_Service_AnalyticsReporting_ReportRequest();
                    $request_page_views_page_title->setViewId(seopress_google_analytics_auth_option());
                    $request_page_views_page_title->setDateRanges($dateRange);
                    $request_page_views_page_title->setDimensions([$pageTitle]);
                    $request_page_views_page_title->setMetrics([$pageviews]);
                    $request_page_views_page_title->setSamplingLevel('SMALL');
                    $request_page_views_page_title->setOrderBys($order_by_pageviews_desc);

                    // Event Cat
                    $request_events_by_cat = new Google_Service_AnalyticsReporting_ReportRequest();
                    $request_events_by_cat->setViewId(seopress_google_analytics_auth_option());
                    $request_events_by_cat->setDateRanges($dateRange);
                    $request_events_by_cat->setDimensions([$eventCategory]);
                    $request_events_by_cat->setMetrics([$totalEvents]);
                    $request_events_by_cat->setSamplingLevel('SMALL');
                    $request_events_by_cat->setOrderBys($order_by_events_desc);

                    // Event Action
                    $request_events_by_action = new Google_Service_AnalyticsReporting_ReportRequest();
                    $request_events_by_action->setViewId(seopress_google_analytics_auth_option());
                    $request_events_by_action->setDateRanges($dateRange);
                    $request_events_by_action->setDimensions([$eventAction]);
                    $request_events_by_action->setMetrics([$totalEvents]);
                    $request_events_by_action->setSamplingLevel('SMALL');
                    $request_events_by_action->setOrderBys($order_by_events_desc);

                    // Event Label
                    $request_events_by_label = new Google_Service_AnalyticsReporting_ReportRequest();
                    $request_events_by_label->setViewId(seopress_google_analytics_auth_option());
                    $request_events_by_label->setDateRanges($dateRange);
                    $request_events_by_label->setDimensions([$eventLabel]);
                    $request_events_by_label->setMetrics([$totalEvents]);
                    $request_events_by_label->setSamplingLevel('SMALL');
                    $request_events_by_label->setOrderBys($order_by_events_desc);

                    //BATCH REPORT
                    ////////////////////////////////////////////////////////////////////////////////////////

                    function seopress_analytics_get_reports($reports) {
                        $return = [];

                        for ($reportIndex = 0; $reportIndex < count($reports); ++$reportIndex) {
                            $report = $reports[$reportIndex];
                            $header = $report->getColumnHeader();
                            $dimensionHeaders = $header->getDimensions();
                            $metricHeaders = $header->getMetricHeader()->getMetricHeaderEntries();
                            $rows = $report->getData()->getRows();

                            for ($rowIndex = 0; $rowIndex < count($rows); ++$rowIndex) {
                                $row = $rows[$rowIndex];
                                $dimensions = $row->getDimensions();
                                $metrics = $row->getMetrics();
                                for ($i = 0; $i < count($dimensionHeaders) && $i < count($dimensions); ++$i) {
                                    $return[$dimensionHeaders[$i]][] = $dimensions[$i];
                                }

                                for ($j = 0; $j < count($metrics); ++$j) {
                                    $values = $metrics[$j]->getValues();
                                    for ($k = 0; $k < count($values); ++$k) {
                                        $entry = $metricHeaders[$k];
                                        $return[$entry->getName()][] = $values[$k];
                                    }
                                }
                            }
                        }

                        return $return;
                    }

                    $all = [];

                    $requests = [
                        $request_by_date,
                        $request_users_by_country,
                        $request_users_by_device_cat,
                        $request_users_by_browser,
                        $request_users_by_social_network,
                        $request_users_by_channel,
                        $request_users_by_source,
                        $request_users_by_ref,
                        $request_page_views_page_title,
                        $request_events_by_cat,
                        $request_events_by_action,
                        $request_events_by_label,
                        $request_users_by_language,
                    ];

                    foreach ($requests as $key => $request) {
                        $body = new Google_Service_AnalyticsReporting_GetReportsRequest();
                        $body->setReportRequests([$request]);
                        $body = $service->reports->batchGet($body);

                        $all[$key] = seopress_analytics_get_reports($body);
                    }

                    ////////////////////////////////////////////////////////////////////////////////////////
                    //Saving datas
                    ////////////////////////////////////////////////////////////////////////////////////////
                    $seopress_results_google_analytics_cache['sessions'] = isset($all[0]['sessions']) && $all[0]['sessions'] !== null ? array_sum($all[0]['sessions']) : 0;
                    $seopress_results_google_analytics_cache['users'] = isset($all[0]['users']) && $all[0]['users'] !== null ? array_sum($all[0]['users']) : 0;
                    $seopress_results_google_analytics_cache['pageviews'] = isset($all[0]['pageviews']) && $all[0]['pageviews'] !== null ? array_sum($all[0]['pageviews']) : 0;

                    $seopress_results_google_analytics_cache['pageviewsPerSession'] = 0;
                    if (isset($all[0]['pageviewsPerSession']) && $all[0]['pageviewsPerSession'] !== null) {
                        $divided = isset($all[0]['pageviewsPerSession']) && $all[0]['pageviewsPerSession'] !== null ? count($all[0]['pageviewsPerSession']) : 1;
                        if ($divided === 0) {
                            $divided = 1;
                        }

                        $seopress_results_google_analytics_cache['pageviewsPerSession'] = round(array_sum($all[0]['pageviewsPerSession']) / $divided, 2);
                    }


                    $seopress_results_google_analytics_cache['avgSessionDuration'] = 0;
                    if (isset($all[0]['avgSessionDuration']) && $all[0]['avgSessionDuration'] !== null) {
                        $divided = isset($all[0]['avgSessionDuration']) && $all[0]['avgSessionDuration'] !== null ? count($all[0]['avgSessionDuration']) : 1;
                        if ($divided === 0) {
                            $divided = 1;
                        }
                        $avg = array_sum($all[0]['avgSessionDuration']);
                        $seopress_results_google_analytics_cache['avgSessionDuration'] = gmdate('i:s', round($avg / $divided));
                    }

                    $seopress_results_google_analytics_cache['bounceRate'] = 0;
                    if (isset($all[0]['bounceRate']) && $all[0]['bounceRate'] !== null) {
                        $divided = isset($all[0]['bounceRate']) && $all[0]['bounceRate'] !== null ? count($all[0]['bounceRate']) : 1;
                        if ($divided === 0) {
                            $divided = 1;
                        }
                        $seopress_results_google_analytics_cache['bounceRate'] = round(array_sum($all[0]['bounceRate']) / $divided, 2);
                    }

                    $seopress_results_google_analytics_cache['percentNewSessions'] = 0;
                    if (isset($all[0]['percentNewSessions']) && $all[0]['percentNewSessions'] !== null) {
                        $divided = isset($all[0]['percentNewSessions']) && $all[0]['percentNewSessions'] !== null ? count($all[0]['percentNewSessions']) : 1;
                        if ($divided === 0) {
                            $divided = 1;
                        }
                        $seopress_results_google_analytics_cache['percentNewSessions'] = round(array_sum($all[0]['percentNewSessions']) / $divided, 2);
                    }

                    $seopress_results_google_analytics_cache['language'] = $all[12];
                    $seopress_results_google_analytics_cache['country'] = $all[1];
                    $seopress_results_google_analytics_cache['deviceCategory'] = $all[2];
                    $seopress_results_google_analytics_cache['browser'] = $all[3];
                    $seopress_results_google_analytics_cache['socialNetwork'] = $all[4];
                    $seopress_results_google_analytics_cache['channelGrouping'] = $all[5];
                    $seopress_results_google_analytics_cache['source'] = $all[6];
                    $seopress_results_google_analytics_cache['fullReferrer'] = $all[7];
                    $seopress_results_google_analytics_cache['contentpageviews'] = $all[8];
                    $seopress_results_google_analytics_cache['totalEvents'] = $all[0]['totalEvents'] ? $all[0]['totalEvents'] : '';
                    $seopress_results_google_analytics_cache['uniqueEvents'] = $all[0]['uniqueEvents'] ? $all[0]['uniqueEvents'] : '';
                    $seopress_results_google_analytics_cache['eventCategory'] = $all[9];
                    $seopress_results_google_analytics_cache['eventAction'] = $all[10];
                    $seopress_results_google_analytics_cache['eventLabel'] = $all[11];

                    switch ($seopress_ga_dashboard_widget_options_type) {
                        case 'ga_sessions':
                            $ga_sessions_rows = $all[0]['sessions'];
                            $seopress_ga_dashboard_widget_options_title = __('Sessions', 'wp-seopress-pro');
                            break;
                        case 'ga_users':
                            $ga_sessions_rows = $all[0]['users'];
                            $seopress_ga_dashboard_widget_options_title = __('Users', 'wp-seopress-pro');
                            break;
                        case 'ga_pageviews':
                            $ga_sessions_rows = $all[0]['pageviews'];
                            $seopress_ga_dashboard_widget_options_title = __('Page Views', 'wp-seopress-pro');
                            break;
                        case 'ga_pageviewsPerSession':
                            $ga_sessions_rows = $all[0]['pageviewsPerSession'];
                            $seopress_ga_dashboard_widget_options_title = __('Page Views Per Session', 'wp-seopress-pro');
                            break;
                        case 'ga_avgSessionDuration':
                            $ga_sessions_rows = $all[0]['avgSessionDuration'];
                            $seopress_ga_dashboard_widget_options_title = __('Average Session Duration', 'wp-seopress-pro');
                            break;
                        case 'ga_bounceRate':
                            $ga_sessions_rows = $all[0]['bounceRate'];
                            $seopress_ga_dashboard_widget_options_title = __('Bounce Rate', 'wp-seopress-pro');
                            break;
                        case 'ga_percentNewSessions':
                            $ga_sessions_rows = $all[0]['percentNewSessions'];
                            $seopress_ga_dashboard_widget_options_title = __('New Sessions', 'wp-seopress-pro');
                            break;
                        default:
                            $ga_sessions_rows = $all[0]['sessions'];
                            $seopress_ga_dashboard_widget_options_title = __('Sessions', 'wp-seopress-pro');
                    }

                    function seopress_ga_dashboard_get_sessions_labels($ga_date) {
                        $labels = [];
                        if ( ! empty($ga_date) && is_array($ga_date)) {
                            foreach ($ga_date as $key => $value) {
                                array_push($labels, date_i18n(get_option('date_format'), strtotime($value)));
                            }
                        }

                        return $labels;
                    }

                    function seopress_ga_dashboard_get_sessions_data($ga_sessions_rows) {
                        $data = [];
                        if ( ! empty($ga_sessions_rows) && is_array($ga_sessions_rows)) {
                            foreach ($ga_sessions_rows as $key => $value) {
                                array_push($data, $value);
                            }
                        }

                        return $data;
                    }
                    $ga_date = $all[0]['ga:date'];
                    $seopress_results_google_analytics_cache['sessions_graph_labels'] = seopress_ga_dashboard_get_sessions_labels($ga_date);
                    $seopress_results_google_analytics_cache['sessions_graph_data'] = seopress_ga_dashboard_get_sessions_data($ga_sessions_rows);
                    $seopress_results_google_analytics_cache['sessions_graph_title'] = $seopress_ga_dashboard_widget_options_title;
                }

                //Transient
                set_transient('seopress_results_google_analytics', $seopress_results_google_analytics_cache, 2 * HOUR_IN_SECONDS);
            }

            //Return
            $seopress_results_google_analytics_transient = get_transient('seopress_results_google_analytics');

            wp_send_json_success($seopress_results_google_analytics_transient);

        } catch (\Exception $e) {
            $error = $e->getMessage();
            wp_send_json(json_decode($error));
        }
    }

    exit();
}
/**
 * Request GA stats by CRON.
 *
 * @since 4.2
 *
 * @author Benjamin
 */
function seopress_request_google_analytics_cron() {
    if (function_exists('seopress_get_toggle_option') && '1' === seopress_get_toggle_option('google-analytics')) {
        seopress_request_google_analytics_fn(true);
    }
}
add_action('seopress_google_analytics_cron', 'seopress_request_google_analytics_cron');

function seopress_request_google_analytics() {
    check_ajax_referer('seopress_request_google_analytics_nonce');
    if ((current_user_can(seopress_capability('manage_options', 'cron')) || seopress_advanced_security_ga_widget_check() === true) && is_admin()) {
        if (function_exists('seopress_get_toggle_option') && '1' === seopress_get_toggle_option('google-analytics')) {
            seopress_request_google_analytics_fn(false);
        }
    }
}
add_action('wp_ajax_seopress_request_google_analytics', 'seopress_request_google_analytics');

///////////////////////////////////////////////////////////////////////////////////////////////////
//Request Matomo Analytics
///////////////////////////////////////////////////////////////////////////////////////////////////
/**
 * Request Matomo stats.
 *
 * @since 6.0
 *
 * @author Benjamin
 */
function seopress_request_matomo_analytics_fn($clear = false) {
    if (function_exists('seopress_google_analytics_matomo_dashboard_widget_option') && seopress_google_analytics_matomo_dashboard_widget_option() === '1') {
        exit();
    }

    //Clear cache if CRON
    if (true === $clear) {
        delete_transient('seopress_results_matomo');
    }

    if (false === ($seopress_results_matomo_cache = get_transient('seopress_results_matomo'))) {
        $seopress_results_matomo_cache = [];

        $matomoID = seopress_get_service('GoogleAnalyticsOption')->getMatomoId() ? seopress_get_service('GoogleAnalyticsOption')->getMatomoId() : null;

        if (empty($matomoID)) {
            exit();
        }

        $siteID = seopress_get_service('GoogleAnalyticsOption')->getMatomoSiteId() ? seopress_get_service('GoogleAnalyticsOption')->getMatomoSiteId() : null;

        if (empty($siteID)) {
            exit();
        }

        $authToken = seopress_get_service('GoogleAnalyticsOption')->getMatomoAuthToken() ? seopress_get_service('GoogleAnalyticsOption')->getMatomoAuthToken() : null;

        if (empty($authToken)) {
            exit();
        }

        // get saved data
        if ( ! $widget_options = get_option('seopress_matomo_dashboard_widget_options')) {
            $widget_options = [];
        }

        // check if saved data contains content
        $seopress_matomo_dashboard_widget_options_period = isset($widget_options['period']) ? $widget_options['period'] : false;

        $seopress_matomo_dashboard_widget_options_type = isset($widget_options['type']) ? $widget_options['type'] : 'nb_visits';

        // custom content saved by control callback, modify output
        if ($seopress_matomo_dashboard_widget_options_period) {
            $period = $seopress_matomo_dashboard_widget_options_period;
        } else {
            $period = 'last30';
        }

        $url = 'https://' . $matomoID . '?module=API&method=API.getProcessedReport&idSite=' . $siteID . '&date=' . $period . '&period=day&apiModule=VisitsSummary&apiAction=get&format=json&token_auth=' . $authToken . '&filter_truncate=5&language=en';

        $args = [
            'blocking'    => true,
            'timeout'     => 10,
            'sslverify'   => false,
        ];

        $response = wp_remote_get($url, $args);

        //Check for error
        if (!is_wp_error($response)) {
            $response = wp_remote_retrieve_body($response);
            $response = json_decode($response, true);
        }

        switch ($seopress_matomo_dashboard_widget_options_type) {
            case 'nb_uniq_visitors':
                $widget_title = __('Unique visitors', 'wp-seopress-pro');
                break;
            case 'nb_visits':
                $widget_title = __('Visits', 'wp-seopress-pro');
                break;
            case 'max_actions':
                $widget_title = __('Maximum actions in one visit', 'wp-seopress-pro');
                break;
            case 'nb_actions_per_visit':
                $widget_title = __('Average actions per visit', 'wp-seopress-pro');
                break;
            case 'bounce_rate':
                $widget_title = __('Bounce Rate', 'wp-seopress-pro');
                break;
            case 'avg_time_on_site':
                $widget_title = __('Avg. Visit Duration (in seconds)', 'wp-seopress-pro');
                break;
            default:
                $widget_title = __('Unique visitors', 'wp-seopress-pro');
        }

        function seopress_matomo_get_sessions_labels($rows) {
            $labels = [];

            if (is_array($rows) && isset($rows['reportMetadata'])) {
                $rows = $rows['reportMetadata'];
                foreach ($rows as $key => $value) {
                    $labels[] = date_i18n(get_option('date_format'), strtotime($key));
                }
            }
            return $labels;
        }

        function seopress_matomo_get_sessions_data($rows, $seopress_matomo_dashboard_widget_options_type) {
            $data = [];
            if (is_array($rows) && isset($rows['reportMetadata'])) {
                $rows = array_values($rows['reportData']);
                foreach ($rows as $key => $value) {
                    //Bounce rate: remove %
                    if ($seopress_matomo_dashboard_widget_options_type === 'bounce_rate') {
                        $value[$seopress_matomo_dashboard_widget_options_type] = rtrim($value[$seopress_matomo_dashboard_widget_options_type], '%');
                    }

                    //Average time: convert to seconds
                    if ($seopress_matomo_dashboard_widget_options_type === 'avg_time_on_site') {
                        $value[$seopress_matomo_dashboard_widget_options_type] = strtotime("1970-01-01 $value[$seopress_matomo_dashboard_widget_options_type] UTC");
                    }

                    if (isset($seopress_matomo_dashboard_widget_options_type)) {
                        $data[] = $value[$seopress_matomo_dashboard_widget_options_type];
                    }
                }
            }
            return $data;
        }

        function seopress_timestamp_to_seconds($n) {
            return strtotime("1970-01-01 $n UTC");
        }

        function seopress_remove_pourcentage($n) {
            return rtrim($n, '%');
        }

        function seopress_matomo_get_all_data($rows) {
            $data = [];
            $rows = $rows['reportData'];

            //Unique Visitors
            $data['nb_uniq_visitors'] = array_sum(array_column($rows, 'nb_uniq_visitors'));

            //Visits
            $data['nb_visits'] = array_sum(array_column($rows, 'nb_visits'));

            //Max actions
            $data['max_actions'] = max(array_column($rows, 'max_actions'));

            //Actions per visit
            $data['nb_actions_per_visit'] = array_column($rows, 'nb_actions_per_visit');
            $count = count($data['nb_actions_per_visit']);
            if ($count > 1) {
                $data['nb_actions_per_visit'] = round(array_sum($data['nb_actions_per_visit']) / $count, 2);
            } else {
                $data['nb_actions_per_visit'] = $data['nb_actions_per_visit'][0];
            }

            //Bounce rate
            $data['bounce_rate'] = array_map('seopress_remove_pourcentage', array_column($rows, 'bounce_rate'));
            $count = count($data['bounce_rate']);
            if ($count > 1) {
                $data['bounce_rate'] = round(array_sum($data['bounce_rate']) / $count, 2);
            } else {
                $data['bounce_rate'] = $data['bounce_rate'][0];
            }

            //Avg. Visit Duration
            $data['avg_time_on_site'] = array_map('seopress_timestamp_to_seconds', array_column($rows, 'avg_time_on_site'));
            $count = count($data['avg_time_on_site']);
            if ($count > 1) {
                $data['avg_time_on_site'] = round(array_sum($data['avg_time_on_site']) / $count, 2);
            } else {
                $data['avg_time_on_site'] = $data['avg_time_on_site'][0];
            }

            return $data;
        }

        $response['sessions_graph_labels'] = seopress_matomo_get_sessions_labels($response);
        $response['sessions_graph_data'] = seopress_matomo_get_sessions_data($response, $seopress_matomo_dashboard_widget_options_type);
        $response['sessions_graph_title'] = $widget_title;
        $response['all'] = seopress_matomo_get_all_data($response);

        //Transient
        set_transient('seopress_results_matomo', $response, 2 * HOUR_IN_SECONDS);
    }
    //Return
    $seopress_results_matomo_transient = get_transient('seopress_results_matomo');

    wp_send_json_success($seopress_results_matomo_transient);
    exit();
}
/**
 * Request Matomo Analytics by CRON.
 *
 * @since 6.0
 * @param boolean Is is a CRON request?
 *
 * @author Benjamin
 */
function seopress_request_matomo_analytics_cron() {
    if (function_exists('seopress_get_toggle_option') && '1' === seopress_get_toggle_option('google-analytics')) {
        seopress_request_matomo_analytics_fn(true);
    }
}
add_action('seopress_matomo_analytics_cron', 'seopress_request_matomo_analytics_cron');

function seopress_request_matomo_analytics() {
    check_ajax_referer('seopress_request_matomo_analytics_nonce');

    if ((current_user_can(seopress_capability('manage_options', 'cron')) || seopress_advanced_security_matomo_widget_check() === true) && is_admin()) {
        if (function_exists('seopress_get_toggle_option') && '1' === seopress_get_toggle_option('google-analytics')) {
            seopress_request_matomo_analytics_fn();
        }
    }
}
add_action('wp_ajax_seopress_request_matomo_analytics', 'seopress_request_matomo_analytics');

///////////////////////////////////////////////////////////////////////////////////////////////////
//Send 404 weekly email notifications
///////////////////////////////////////////////////////////////////////////////////////////////////
function seopress_404_send_alert() {
    function seopress_404_send_alert_content_type() {
        return 'text/html';
    }
    add_filter('wp_mail_content_type', 'seopress_404_send_alert_content_type');

    $to = seopress_pro_get_service('OptionPro')->get404RedirectEnableMailsFrom();
    $subject = sprintf(__('404 alert - %s', 'wp-seopress-pro'), get_bloginfo('name'));
    $content = '';

    // Get the Latest 404 errors
    $args = [
        'date_query' => [
            [
                'column' => 'post_date_gmt',
                'before' => '1 week ago',
            ],
        ],
        'posts_per_page' => 10,
        'post_type' => 'seopress_404',
        'meta_key' => '_seopress_redirections_type',
        'meta_compare' => 'NOT EXISTS',
    ];

    $args = apply_filters('seopress_404_email_alerts_latest_query', $args);

    $latest_404_query = new WP_Query($args);

    if ($latest_404_query->have_posts()) {
        $errors['latest'] = [];
        while ($latest_404_query->have_posts()) {
            $latest_404_query->the_post();

            $errors['latest'][] = ['url' => get_the_title(), 'count' => get_post_meta( get_the_ID(), 'seopress_404_count', true )];
        }
        wp_reset_postdata();
    }

    if (!empty($errors['latest'])) {
        $content .= '<h2>' . __('Latest 404 errors since 1 week', 'wp-seopress-pro') . '</h2>';
        $content .= '<ul>';
        foreach($errors['latest'] as $error) {
            $hits = !empty($error['count']) ? ' - ' . $error['count'] . __(' Hits','wp-seopress-pro') : '';
            $content .= '<li>' . get_home_url() . '/' . $error['url'] . $hits . '</li>';
        }
        $content .= '</ul>';
    }

    // Get the top 404 errors
    $args = [
        'posts_per_page' => 10,
        'post_type' => 'seopress_404',
        'meta_key' => 'seopress_404_count',
        'meta_query' => [
            'relation' => 'AND',
            [
                'key' => 'seopress_404_count',
                'compare' => 'EXISTS',
                'type' => 'NUMERIC'
            ],
            [
                'key' => '_seopress_redirections_type',
                'compare' => 'NOT EXISTS',
            ],
        ],
        'order' => 'DESC',
        'orderby' => 'meta_value_num',
    ];

    $args = apply_filters('seopress_404_email_alerts_top_query', $args);

    $top_404_query = new WP_Query($args);

    if ($top_404_query->have_posts()) {
        $errors['top'] = [];
        while ($top_404_query->have_posts()) {
            $top_404_query->the_post();

            $errors['top'][] = ['url' => get_the_title(), 'count' => get_post_meta( get_the_ID(), 'seopress_404_count', true )];

        }
        wp_reset_postdata();
    }

    if (!empty($errors['top'])) {
        $content .= '<h2>' . __('Top 404 errors', 'wp-seopress-pro') . '</h2>';
        $content .= '<ul>';
        foreach($errors['top'] as $error) {
            $hits = !empty($error['count']) ? ' - ' . $error['count'] . __(' Hits','wp-seopress-pro') : '';
            $content .= '<li>' . get_home_url() . '/' . $error['url'] . $hits . '</li>';
        }
        $content .= '</ul>';
    }

    $body = "<style>
        #wrapper {
            background-color: #F9F9F9;
            margin: 0;
            padding: 70px 0 70px 0;
            -webkit-text-size-adjust: none !important;
            width: 100%;
        }

        #template_container {
            box-shadow:0 0 0 1px #f3f3f3 !important;
            background-color: #ffffff;
            border: 1px solid #e9e9e9;
            padding: 0;
        }

        #template_header {
            color: #333;
            font-family: 'Helvetica Neue', Helvetica, Roboto, Arial, sans-serif;
        }

        #template_header h1,
        #template_header h1 a {
            color: #232323;
        }

        #template_footer td {
            padding: 0;
        }

        #template_footer #credit a {
            font-size: 13px;
            line-height: 125%;
            text-align: center;
            padding: 12px 28px 28px 28px;
            display: block;
            font-family: 'Helvetica Neue', Helvetica, Roboto, Arial, sans-serif;
        }

        #body_content {
            background-color: #ffffff;
        }

        #body_content table td {
            padding: 30px;
        }

        #body_content table td td {
            padding: 12px;
        }

        #body_content table td th {
            padding: 12px;
        }

        #body_content p {
            margin: 0 0 16px;
        }

        .button {
            font-size: 13px;
            font-weight: bold;
            background: #007cba;
            color: #fff;
            text-decoration: none;
            display: inline-block;
            margin: 0;
            border: 0;
            cursor: pointer;
            -webkit-appearance: none;
            height: 36px;
            padding: 6px 24px;
            border-radius: 2px;
            vertical-align: middle;
            white-space: nowrap;
            line-height: 36px;
            outline: 1px solid transparent;
            font-family: 'Helvetica Neue', Helvetica, Roboto, Arial, sans-serif;
        }

        #body_content_inner {
            color: #505050;
            font-family: 'Helvetica Neue', Helvetica, Roboto, Arial, sans-serif;
            font-size: 14px;
            line-height: 150%;
        }

        .td {
            color: #505050;
            border: 1px solid #E5E5E5;
        }

        .text {
            color: #505050;
            font-family: 'Helvetica Neue', Helvetica, Roboto, Arial, sans-serif;
        }

        .link {
            color: #232323;
        }

        #header_wrapper {
            padding: 24px 48px 24px 48px;
            display: block;
            border-bottom: 1px solid #F1F1F1;
            text-align: center;
        }

        h1 {
            color: #232323;
            font-family: 'Helvetica Neue', Helvetica, Roboto, Arial, sans-serif;
            font-size: 18px;
            margin: 0;
            -webkit-font-smoothing: antialiased;
        }

        h2 {
            color: #232323;
            display: block;
            font-family: 'Helvetica Neue', Helvetica, Roboto, Arial, sans-serif;
            font-size: 18px;
            font-weight: bold;
            line-height: 130%;
            margin: 16px 0 8px;
        }

        h3 {
            color: #232323;
            display: block;
            font-family: 'Helvetica Neue', Helvetica, Roboto, Arial, sans-serif;
            font-size: 16px;
            font-weight: bold;
            line-height: 130%;
            margin: 16px 0 8px;
        }

        a {
            color: #232323;
            font-weight: normal;
            text-decoration: underline;
        }

        img {
            border: none;
            display: inline;
            font-size: 14px;
            font-weight: bold;
            height: auto;
            line-height: 100%;
            outline: none;
            text-decoration: none;
            text-transform: capitalize;
        }
    </style>";
    $body .= '<body leftmargin="0" marginwidth="0" topmargin="0" marginheight="0" offset="0">
        <div id="wrapper">
            <table border="0" cellpadding="0" cellspacing="0" height="100%" width="100%">
                <tr>
                    <td align="center" valign="top">
                        <table border="0" cellpadding="0" cellspacing="0" width="600" id="template_container">
                            <tr>
                                <td align="center" valign="top">
                                    <!-- Header -->
                                    <table border="0" cellpadding="0" cellspacing="0" width="600" id="template_header">
                                        <tr>
                                            <td id="header_wrapper">
                                                <h1>' . __('404 Error Reporting', 'wp-seopress-pro') . '</h1>
                                            </td>
                                        </tr>
                                    </table>
                                    <!-- End Header -->
                                </td>
                            </tr>
                            <tr>
                                <td align="center" valign="top">
                                    <!-- Body -->
                                    <table border="0" cellpadding="0" cellspacing="0" width="600" id="template_body">
                                        <tr>
                                            <td valign="top" id="body_content">
                                                <!-- Content -->
                                                <table border="0" cellpadding="20" cellspacing="0" width="100%">
                                                    <tr>
                                                        <td valign="top">
                                                            <div id="body_content_inner">
                                                                <p>' . __('You are receiving this email because 404 error notifications are enabled on your WordPress site.', 'wp-seopress-pro') . '</p>
                                                                ' . $content . '
                                                            </div>
                                                        </td>
                                                    </tr>
                                                    <tr>
                                                        <td valign="top" align="center">
                                                            <div id="body_content_inner">
                                                                <a class="button" href="' . get_home_url() . '/wp-admin/edit.php?post_type=seopress_404&action=-1&m=0&redirect-cat=0&redirection-type=404&redirection-enabled&filter_action=Filter&paged=1&action2=-1&post_status=404">' . __('View all 404 errors', 'wp-seopress-pro') . '</a>
                                                            </div>
                                                        </td>
                                                    </tr>
                                                </table>
                                                <!-- End Content -->
                                            </td>
                                        </tr>
                                    </table>
                                    <!-- End Body -->
                                </td>
                            </tr>
                            <tr>
                                <td align="center" valign="top">
                                    <!-- Footer -->
                                    <table border="0" cellpadding="10" cellspacing="0" width="600" id="template_footer">
                                        <tr>
                                            <td valign="top">
                                                <table border="0" cellpadding="10" cellspacing="0" width="100%">
                                                    <tr>
                                                        <td colspan="2" id="credit" style="border:0;color: #878787; border-top: 1px solid #F1F1F1;" valign="middle">
                                                            <p><a href="' . get_home_url() . '">' . get_bloginfo('name') . '</a></p>
                                                        </td>
                                                    </tr>
                                                </table>
                                            </td>
                                        </tr>
                                    </table>
                                    <!-- End Footer -->
                                </td>
                            </tr>
                        </table>
                    </td>
                </tr>
            </table>
        </div>
    </body>';

    wp_mail($to, $subject, $body);

    remove_filter('wp_mail_content_type', 'seopress_404_send_alert_content_type');
}

/**
 * Send 404 email alerts by CRON.
 *
 * @since 6.3
 *
 * @author Benjamin
 */
function seopress_404_send_alert_cron() {
    if ((function_exists('seopress_get_toggle_option') && '1' === seopress_get_toggle_option('404')) && '1' === seopress_pro_get_service('OptionPro')->get404RedirectEnableMails() && '' !== seopress_pro_get_service('OptionPro')->get404RedirectEnableMailsFrom()) {
        seopress_404_send_alert();
    }
}
add_action('seopress_404_email_alerts_cron', 'seopress_404_send_alert_cron');

///////////////////////////////////////////////////////////////////////////////////////////////////
// 404 Cleaning CRON
///////////////////////////////////////////////////////////////////////////////////////////////////
//Enable CRON 404 cleaning
function seopress_404_cleaning_option() {
    $seopress_404_cleaning_option = get_option('seopress_pro_option_name');
    if ( ! empty($seopress_404_cleaning_option)) {
        foreach ($seopress_404_cleaning_option as $key => $seopress_404_cleaning_value) {
            $options[$key] = $seopress_404_cleaning_value;
        }
        if (isset($seopress_404_cleaning_option['seopress_404_cleaning'])) {
            return $seopress_404_cleaning_option['seopress_404_cleaning'];
        }
    }
}

function seopress_404_cron_cleaning_action($force = false) {
    if ('1' === seopress_404_cleaning_option() || true === $force) {
        $args = [
            'date_query' => [
                [
                    'column' => 'post_date_gmt',
                    'before' => '1 month ago',
                ],
            ],
            'posts_per_page' => -1,
            'post_type' => 'seopress_404',
            'meta_key' => '_seopress_redirections_type',
            'meta_compare' => 'NOT EXISTS',
        ];

        $args = apply_filters('seopress_404_cleaning_query', $args);

        // The Query
        $old_404_query = new WP_Query($args);

        // The Loop
        if ($old_404_query->have_posts()) {
            while ($old_404_query->have_posts()) {
                $old_404_query->the_post();
                wp_delete_post(get_the_ID(), true);
            }
            /* Restore original Post Data */
            wp_reset_postdata();
        }
    }
}
add_action('seopress_404_cron_cleaning', 'seopress_404_cron_cleaning_action', 10, 1);

///////////////////////////////////////////////////////////////////////////////////////////////////
//Daily Get Insights from Google Search Console
///////////////////////////////////////////////////////////////////////////////////////////////////
function seopress_get_insights_gsc_cron() {
    //Check if GSC toggle is ON
    if (seopress_get_service('ToggleOption')->getToggleInspectUrl() !=='1') {
        return;
    }

    //Get Google API Key
    $options = get_option('seopress_instant_indexing_option_name');
    $google_api_key = isset($options['seopress_instant_indexing_google_api_key']) ? $options['seopress_instant_indexing_google_api_key'] : '';

    if (empty($google_api_key)) {
        return;
    }

    try {
        $service = seopress_pro_get_service('SearchConsole');

        $response = $service->handle();
        if($response['status'] === 'error'){
            return;
        }

        foreach($response['data'] as $row){
            $result = $service->saveDataFromRowResult($row);
        }

    } catch (\Exception $e) {
        // No need to do anything here
    }
}
add_action('seopress_insights_gsc_cron', 'seopress_get_insights_gsc_cron');