File: /var/www/html/pmw24/wp-content/plugins/google-site-kit/includes/Core/Util/Tracking.php
<?php
/**
* Class Google\Site_Kit\Core\Util\Tracking
*
* @package Google\Site_Kit
* @copyright 2021 Google LLC
* @license https://www.apache.org/licenses/LICENSE-2.0 Apache License 2.0
* @link https://sitekit.withgoogle.com
*/
namespace Google\Site_Kit\Core\Util;
use Google\Site_Kit\Context;
use Google\Site_Kit\Core\Admin\Screen;
use Google\Site_Kit\Core\Admin\Screens;
use Google\Site_Kit\Core\Permissions\Permissions;
use Google\Site_Kit\Core\REST_API\REST_Route;
use Google\Site_Kit\Core\REST_API\REST_Routes;
use Google\Site_Kit\Core\Storage\User_Options;
use Google\Site_Kit\Core\Util\Method_Proxy_Trait;
use WP_REST_Server;
use WP_REST_Request;
use WP_REST_Response;
/**
* Class managing admin tracking.
*
* @since 1.0.0
* @access private
* @ignore
*/
final class Tracking {
use Method_Proxy_Trait;
const TRACKING_ID = 'UA-130569087-3';
/**
* Screens instance.
*
* @since 1.11.0
*
* @var Screens
*/
protected $screens;
/**
* Tracking_Consent instance.
*
* @var Tracking_Consent
*/
protected $consent;
/**
* Constructor.
*
* @since 1.4.0
* @since 1.11.0 Added `Screens` instance.
*
* @param Context $context Context instance.
* @param User_Options $user_options Optional. User_Options instance. Default is a new instance.
* @param Screens $screens Optional. Screens instance. Default is a new instance.
*/
public function __construct(
Context $context,
User_Options $user_options = null,
Screens $screens = null
) {
$user_options = $user_options ?: new User_Options( $context );
$this->screens = $screens ?: new Screens( $context );
$this->consent = new Tracking_Consent( $user_options );
}
/**
* Registers functionality through WordPress hooks.
*
* @since 1.0.0
*/
public function register() {
$this->consent->register();
add_filter( 'googlesitekit_inline_base_data', $this->get_method_proxy( 'inline_js_base_data' ) );
add_filter( 'googlesitekit_rest_routes', $this->get_method_proxy( 'get_rest_routes' ) );
add_filter(
'googlesitekit_apifetch_preload_paths',
function( $routes ) {
return array_merge(
$routes,
array(
'/' . REST_Routes::REST_ROOT . '/core/user/data/tracking',
)
);
}
);
}
/**
* Is tracking active for the current user?
*
* @since 1.0.0
* @since 1.3.0 Tracking is now user-specific.
*
* @return bool True if tracking enabled, and False if not.
*/
public function is_active() {
return (bool) $this->consent->get();
}
/**
* Modifies the base data to pass to JS.
*
* @since 1.3.0
*
* @param array $data Inline JS data.
* @return array Filtered $data.
*/
private function inline_js_base_data( $data ) {
global $hook_suffix;
$data['trackingAllowed'] = $this->screens->get_screen( $hook_suffix ) instanceof Screen;
$data['trackingEnabled'] = $this->is_active();
$data['trackingID'] = self::TRACKING_ID;
return $data;
}
/**
* Gets tracking routes.
*
* @since 1.28.0
*
* @param array $routes Array of routes.
* @return array Modified array of routes that contains tracking related routes.
*/
private function get_rest_routes( $routes ) {
$can_authenticate = function() {
return current_user_can( Permissions::AUTHENTICATE );
};
$tracking_callback = function( WP_REST_Request $request ) {
return new WP_REST_Response(
array(
'enabled' => $this->is_active(),
)
);
};
return array_merge(
$routes,
array(
new REST_Route(
'core/user/data/tracking',
array(
array(
'methods' => WP_REST_Server::READABLE,
'callback' => $tracking_callback,
'permission_callback' => $can_authenticate,
),
array(
'methods' => WP_REST_Server::CREATABLE,
'callback' => function( WP_REST_Request $request ) use ( $tracking_callback ) {
$data = $request->get_param( 'data' );
$enabled = ! empty( $data['enabled'] );
$this->consent->set( $enabled );
return $tracking_callback( $request );
},
'permission_callback' => $can_authenticate,
'args' => array(
'data' => array(
'type' => 'object',
'required' => true,
'properties' => array(
'enabled' => array(
'type' => 'boolean',
'required' => true,
),
),
),
),
),
)
),
)
);
}
}