HEX
Server: LiteSpeed
System: Linux premium267.web-hosting.com 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
User: predezso (1249)
PHP: 8.1.33
Disabled: NONE
Upload Files
File: //proc/self/cwd/wp-content/plugins/wordpress-seo/inc/options/class-wpseo-option-tracking-only.php
<?php
/**
 * WPSEO plugin file.
 *
 * @package WPSEO\Internals\Options
 */

/**
 * Option: wpseo_tracking_only.
 *
 * For stuff that their only purpose is tracking.
 */
class WPSEO_Option_Tracking_Only extends WPSEO_Option {

	/**
	 * Option name.
	 *
	 * @var string
	 */
	public $option_name = 'wpseo_tracking_only';

	/**
	 * Array of defaults for the option.
	 *
	 * Shouldn't be requested directly, use $this->get_defaults();
	 *
	 * @var array<string, int|string|array<int>>
	 */
	protected $defaults = [
		'task_list_first_opened_on' => '',
		'task_first_actioned_on'    => '',
	];

	/**
	 * Get the singleton instance of this class.
	 *
	 * @return object
	 */
	public static function get_instance() {
		if ( ! ( self::$instance instanceof self ) ) {
			self::$instance = new self();
		}

		return self::$instance;
	}

	/**
	 * All concrete classes must contain a validate_option() method which validates all
	 * values within the option.
	 *
	 * @phpcs:disable VariableAnalysis.CodeAnalysis.VariableAnalysis.UnusedVariable -- Needed because the function is called with the parameter $old.
	 *
	 * @param array<string, string> $dirty New value for the option.
	 * @param array<string, string> $clean Clean value for the option, normally the defaults.
	 * @param array<string, string> $old   Old value of the option.
	 *
	 * @return array<string, string> The clean option with the saved value.
	 */
	protected function validate_option( $dirty, $clean, $old ) {

		foreach ( $clean as $key => $value ) {
			switch ( $key ) {
				case 'task_list_first_opened_on':
				case 'task_first_actioned_on':
					// These should be set only once and never changed again (unless completely reset to default).

					if ( isset( $dirty[ $key ] ) && $old[ $key ] === $this->get_defaults()[ $key ] ) {
						// Allow setting it for the first time.
						$clean[ $key ] = sanitize_text_field( $dirty[ $key ] );
					}
					elseif ( isset( $dirty[ $key ] ) && $dirty[ $key ] === $this->get_defaults()[ $key ] ) {
						// Allow resetting to default.
						$clean[ $key ] = $dirty[ $key ];
					}
					else {
						// Otherwise keep old value.
						$clean[ $key ] = $old[ $key ];
					}

					break;
			}
		}

		return $clean;
	}
}