STRATO-apps/wordpress_03/app/wp-content/plugins/wp-rocket/inc/Engine/Tracking/Subscriber.php

SHA-256: 7348eb3f14e9efccface2705f8db48d5342a6c9dab179d6e22300758da7479a1
<?php
declare(strict_types=1);

namespace WP_Rocket\Engine\Tracking;

use WP_Rocket\Event_Management\Subscriber_Interface;
use WP_Rocket\Engine\Admin\RocketInsights\Managers\Plan;

class Subscriber implements Subscriber_Interface {
	/**
	 * The tracking service.
	 *
	 * @var Tracking
	 */
	private $tracking;

	/**
	 * Constructor.
	 *
	 * @param Tracking $tracking The tracking service.
	 */
	public function __construct( Tracking $tracking ) {
		$this->tracking = $tracking;
	}

	/**
	 * Returns an array of events this subscriber wants to listen to.
	 *
	 * @return array
	 */
	public static function get_subscribed_events(): array {
		return [
			'update_option_wp_rocket_settings'     => [ 'track_option_change', 10, 2 ],
			'wp_rocket_upgrade'                    => [ 'migrate_optin', 10, 2 ],
			'rocket_dashboard_after_account_data'  => [ 'render_optin', 8 ],
			'wp_ajax_rocket_toggle_optin'          => [ 'ajax_toggle_optin' ],
			'admin_enqueue_scripts'                => [ 'localize_optin_status', 15 ],
			'admin_print_scripts'                  => [ 'inject_mixpanel_script' ],
			'rocket_mixpanel_optin_changed'        => 'track_optin_change',
			'rocket_rocket_insights_job_added'     => [ 'track_rocket_insights_url_added', 10, 3 ],
			'admin_footer-settings_page_wprocket'  => 'track_admin_visits',
			'rocket_rocket_insights_job_failed'    => [ 'track_rocket_insights_test', 10, 3 ],
			'rocket_rocket_insights_job_completed' => [ 'track_rocket_insights_test', 10, 3 ],
		];
	}

	/**
	 * Track option change.
	 *
	 * @param mixed $old_value The old value of the option.
	 * @param mixed $value     The new value of the option.
	 *
	 * @return void
	 */
	public function track_option_change( $old_value, $value ): void {
		$this->tracking->track_option_change( $old_value, $value );
	}

	/**
	 * Migrate opt-in to new package on upgrade
	 *
	 * @param string $new_version The new version of the plugin.
	 * @param string $old_version The old version of the plugin.
	 *
	 * @return void
	 */
	public function migrate_optin( $new_version, $old_version ): void {
		$this->tracking->migrate_optin( $new_version, $old_version );
	}

	/**
	 * Render the opt-in section.
	 *
	 * @return void
	 */
	public function render_optin(): void {
		$this->tracking->render_optin();
	}

	/**
	 * Handle AJAX request to toggle opt-in.
	 *
	 * @return void
	 */
	public function ajax_toggle_optin(): void {
		$this->tracking->ajax_toggle_optin();
	}

	/**
	 * Localize opt-in status to JavaScript.
	 *
	 * @return void
	 */
	public function localize_optin_status(): void {
		$this->tracking->localize_optin_status();
	}

	/**
	 * Inject Mixpanel JavaScript SDK.
	 *
	 * @since 3.19.2
	 * @return void
	 */
	public function inject_mixpanel_script(): void {
		$this->tracking->inject_mixpanel_script();
	}

	/**
	 * Track opt-in change event.
	 *
	 * @param bool $status The new opt-in status.
	 *
	 * @return void
	 */
	public function track_optin_change( $status ): void {
		$this->tracking->track_optin_change( $status );
	}

	/**
	 * Track when a URL is added to Rocket Insights (Performance Monitoring).
	 *
	 * @since 3.20
	 *
	 * @param string $url        The URL that was added for monitoring.
	 * @param string $plan       Plan name.
	 * @param int    $urls_count The current number of URLs being monitored.
	 *
	 * @return void
	 */
	public function track_rocket_insights_url_added( $url, $plan, $urls_count ): void {
		$this->tracking->track_rocket_insights_url_added( $url, $plan, $urls_count );
	}

	/**
	 * Tracks when a performance test is completed or failed in Rocket Insights.
	 *
	 * @since 3.20
	 *
	 * @param object $row_details Details related to the database row.
	 * @param array  $job_details Details related to the job.
	 * @param string $plan Plan name.
	 *
	 * @return void
	 */
	public function track_rocket_insights_test( $row_details, $job_details, $plan ): void {
		$this->tracking->track_rocket_insights_test( $row_details, $job_details, $plan );
	}

	/**
	 * Tracks visits to settings page
	 *
	 * @return void
	 */
	public function track_admin_visits(): void {
		$this->tracking->track_admin_visits();
	}
}