PHP 8.2.29
Preview: class-wp-speculation-rules.php Size: 7.35 KB
/home/medyaist/vetplusveteriner.com/wp-includes/class-wp-speculation-rules.php
<?php
/**
 * Class 'WP_Speculation_Rules'.
 *
 * @package WordPress
 * @subpackage Speculative Loading
 * @since 6.8.0
 */

/**
 * Class representing a set of speculation rules.
 *
 * @since 6.8.0
 * @access private
 */
final class WP_Speculation_Rules implements JsonSerializable {

	/**
	 * Stored rules, as a map of `$mode => $rules` pairs.
	 *
	 * Every `$rules` value is a map of `$id => $rule` pairs.
	 *
	 * @since 6.8.0
	 * @var array<string, array<string, mixed>>
	 */
	private $rules_by_mode = array();

	/**
	 * The allowed speculation rules modes as a map, used for validation.
	 *
	 * @since 6.8.0
	 * @var array<string, bool>
	 */
	private static $mode_allowlist = array(
		'prefetch'  => true,
		'prerender' => true,
	);

	/**
	 * The allowed speculation rules eagerness levels as a map, used for validation.
	 *
	 * @since 6.8.0
	 * @var array<string, bool>
	 */
	private static $eagerness_allowlist = array(
		'immediate'    => true,
		'eager'        => true,
		'moderate'     => true,
		'conservative' => true,
	);

	/**
	 * The allowed speculation rules sources as a map, used for validation.
	 *
	 * @since 6.8.0
	 * @var array<string, bool>
	 */
	private static $source_allowlist = array(
		'list'     => true,
		'document' => true,
	);

	/**
	 * Adds a speculation rule to the speculation rules to consider.
	 *
	 * @since 6.8.0
	 *
	 * @param string               $mode Speculative loading mode. Either 'prefetch' or 'prerender'.
	 * @param string               $id   Unique string identifier for the speculation rule.
	 * @param array<string, mixed> $rule Associative array of rule arguments.
	 * @return bool True on success, false if invalid parameters are provided.
	 */
	public function add_rule( string $mode, string $id, array $rule ): bool {
		if ( ! self::is_valid_mode( $mode ) ) {
			_doing_it_wrong(
				__METHOD__,
				sprintf(
					/* translators: %s: invalid mode value */
					__( 'The value "%s" is not a valid speculation rules mode.' ),
					esc_html( $mode )
				),
				'6.8.0'
			);
			return false;
		}

		if ( ! $this->is_valid_id( $id ) ) {
			_doing_it_wrong(
				__METHOD__,
				sprintf(
					/* translators: %s: invalid ID value */
					__( 'The value "%s" is not a valid ID for a speculation rule.' ),
					esc_html( $id )
				),
				'6.8.0'
			);
			return false;
		}

		if ( $this->has_rule( $mode, $id ) ) {
			_doing_it_wrong(
				__METHOD__,
				sprintf(
					/* translators: %s: invalid ID value */
					__( 'A speculation rule with ID "%s" already exists.' ),
					esc_html( $id )
				),
				'6.8.0'
			);
			return false;
		}

		/*
		 * Perform some basic speculation rule validation.
		 * Every rule must have either a 'where' key or a 'urls' key, but not both.
		 * The presence of a 'where' key implies a 'source' of 'document', while the presence of a 'urls' key implies
		 * a 'source' of 'list'.
		 */
		if (
			( ! isset( $rule['where'] ) && ! isset( $rule['urls'] ) ) ||
			( isset( $rule['where'] ) && isset( $rule['urls'] ) )
		) {
			_doing_it_wrong(
				__METHOD__,
				sprintf(
					/* translators: 1: allowed key, 2: alternative allowed key */
					__( 'A speculation rule must include either a "%1$s" key or a "%2$s" key, but not both.' ),
					'where',
					'urls'
				),
				'6.8.0'
			);
			return false;
		}
		if ( isset( $rule['source'] ) ) {
			if ( ! self::is_valid_source( $rule['source'] ) ) {
				_doing_it_wrong(
					__METHOD__,
					sprintf(
						/* translators: %s: invalid source value */
						__( 'The value "%s" is not a valid source for a speculation rule.' ),
						esc_html( $rule['source'] )
					),
					'6.8.0'
				);
				return false;
			}

			if ( 'list' === $rule['source'] && isset( $rule['where'] ) ) {
				_doing_it_wrong(
					__METHOD__,
					sprintf(
						/* translators: 1: source value, 2: forbidden key */
						__( 'A speculation rule of source "%1$s" must not include a "%2$s" key.' ),
						'list',
						'where'
					),
					'6.8.0'
				);
				return false;
			}

			if ( 'document' === $rule['source'] && isset( $rule['urls'] ) ) {
				_doing_it_wrong(
					__METHOD__,
					sprintf(
						/* translators: 1: source value, 2: forbidden key */
						__( 'A speculation rule of source "%1$s" must not include a "%2$s" key.' ),
						'document',
						'urls'
					),
					'6.8.0'
				);
				return false;
			}
		}

		// If there is an 'eagerness' key specified, make sure it's valid.
		if ( isset( $rule['eagerness'] ) ) {
			if ( ! self::is_valid_eagerness( $rule['eagerness'] ) ) {
				_doing_it_wrong(
					__METHOD__,
					sprintf(
						/* translators: %s: invalid eagerness value */
						__( 'The value "%s" is not a valid eagerness for a speculation rule.' ),
						esc_html( $rule['eagerness'] )
					),
					'6.8.0'
				);
				return false;
			}

			if ( isset( $rule['where'] ) && 'immediate' === $rule['eagerness'] ) {
				_doing_it_wrong(
					__METHOD__,
					sprintf(
						/* translators: %s: forbidden eagerness value */
						__( 'The eagerness value "%s" is forbidden for document-level speculation rules.' ),
						'immediate'
					),
					'6.8.0'
				);
				return false;
			}
		}

		if ( ! isset( $this->rules_by_mode[ $mode ] ) ) {
			$this->rules_by_mode[ $mode ] = array();
		}

		$this->rules_by_mode[ $mode ][ $id ] = $rule;
		return true;
	}

	/**
	 * Checks whether a speculation rule for the given mode and ID already exists.
	 *
	 * @since 6.8.0
	 *
	 * @param string $mode Speculative loading mode. Either 'prefetch' or 'prerender'.
	 * @param string $id   Unique string identifier for the speculation rule.
	 * @return bool True if the rule already exists, false otherwise.
	 */
	public function has_rule( string $mode, string $id ): bool {
		return isset( $this->rules_by_mode[ $mode ][ $id ] );
	}

	/**
	 * Returns the speculation rules data ready to be JSON-encoded.
	 *
	 * @since 6.8.0
	 *
	 * @return array<string, array<string, mixed>> Speculation rules data.
	 */
	#[ReturnTypeWillChange]
	public function jsonSerialize() {
		// Strip the IDs for JSON output, since they are not relevant for the Speculation Rules API.
		return array_map(
			static function ( array $rules ) {
				return array_values( $rules );
			},
			array_filter( $this->rules_by_mode )
		);
	}

	/**
	 * Checks whether the given ID is valid.
	 *
	 * @since 6.8.0
	 *
	 * @param string $id Unique string identifier for the speculation rule.
	 * @return bool True if the ID is valid, false otherwise.
	 */
	private function is_valid_id( string $id ): bool {
		return (bool) preg_match( '/^[a-z][a-z0-9_-]+$/', $id );
	}

	/**
	 * Checks whether the given speculation rules mode is valid.
	 *
	 * @since 6.8.0
	 *
	 * @param string $mode Speculation rules mode.
	 * @return bool True if valid, false otherwise.
	 */
	public static function is_valid_mode( string $mode ): bool {
		return isset( self::$mode_allowlist[ $mode ] );
	}

	/**
	 * Checks whether the given speculation rules eagerness is valid.
	 *
	 * @since 6.8.0
	 *
	 * @param string $eagerness Speculation rules eagerness.
	 * @return bool True if valid, false otherwise.
	 */
	public static function is_valid_eagerness( string $eagerness ): bool {
		return isset( self::$eagerness_allowlist[ $eagerness ] );
	}

	/**
	 * Checks whether the given speculation rules source is valid.
	 *
	 * @since 6.8.0
	 *
	 * @param string $source Speculation rules source.
	 * @return bool True if valid, false otherwise.
	 */
	public static function is_valid_source( string $source ): bool {
		return isset( self::$source_allowlist[ $source ] );
	}
}

Directory Contents

Dirs: 29 × Files: 157
Name Size Perms Modified Actions
- drwxr-xr-x 2025-12-03 17:56:28
Edit Download
assets DIR
- drwxr-xr-x 2025-10-15 22:49:44
Edit Download
- drwxr-xr-x 2026-01-14 05:09:42
Edit Download
- drwxr-xr-x 2026-01-14 22:15:15
Edit Download
- drwxr-xr-x 2026-01-14 22:15:33
Edit Download
blocks DIR
- drwxr-xr-x 2026-01-14 15:46:12
Edit Download
- drwxr-xr-x 2026-01-09 23:52:28
Edit Download
css DIR
- drwxr-xr-x 2025-10-15 22:49:45
Edit Download
customize DIR
- drwxr-xr-x 2026-01-14 10:05:37
Edit Download
fonts DIR
- drwxr-xr-x 2026-01-13 23:32:46
Edit Download
html-api DIR
- drwxr-xr-x 2026-01-14 19:45:51
Edit Download
ID3 DIR
- drwxr-xr-x 2026-01-13 23:26:22
Edit Download
images DIR
- drwxr-xr-x 2026-01-09 23:58:18
Edit Download
- drwxr-xr-x 2026-01-15 00:20:13
Edit Download
IXR DIR
- drwxr-xr-x 2026-01-14 05:08:41
Edit Download
js DIR
- drwxr-xr-x 2026-01-13 23:29:55
Edit Download
l10n DIR
- drwxr-xr-x 2026-01-14 18:25:54
Edit Download
- drwxr-xr-x 2025-10-15 22:49:45
Edit Download
PHPMailer DIR
- drwxr-xr-x 2026-01-13 23:29:58
Edit Download
pomo DIR
- drwxr-xr-x 2025-10-15 22:49:45
Edit Download
Requests DIR
- drwxr-xr-x 2025-10-15 22:49:45
Edit Download
rest-api DIR
- drwxr-xr-x 2026-01-07 18:29:15
Edit Download
SimplePie DIR
- drwxr-xr-x 2026-01-10 00:55:04
Edit Download
sitemaps DIR
- drwxr-xr-x 2025-10-15 22:49:45
Edit Download
- drwxr-xr-x 2026-01-14 06:43:17
Edit Download
- drwxr-xr-x 2026-01-10 00:39:22
Edit Download
Text DIR
- drwxr-xr-x 2025-10-15 22:49:45
Edit Download
- drwxr-xr-x 2026-01-07 18:07:15
Edit Download
widgets DIR
- drwxr-xr-x 2026-01-14 06:44:22
Edit Download
7.80 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
18.94 KB lrw-r--r-- 2025-12-03 17:56:34
Edit Download
7.35 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
12.90 KB lrw-r--r-- 2024-11-29 19:46:22
Edit Download
61.02 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
112.05 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
42.63 KB lrw-r--r-- 2025-12-03 17:56:34
Edit Download
6.61 KB lrw-r--r-- 2024-09-17 18:08:16
Edit Download
2.18 KB lrw-r--r-- 2023-04-05 10:12:26
Edit Download
13.89 KB lrw-r--r-- 2024-03-18 12:46:14
Edit Download
7.43 KB lrw-r--r-- 2023-09-14 09:46:20
Edit Download
17.46 KB lrw-r--r-- 2024-07-17 21:52:18
Edit Download
5.14 KB lrw-r--r-- 2022-09-12 12:47:14
Edit Download
8.28 KB lrw-r--r-- 2025-12-03 17:56:34
Edit Download
1.32 KB lrw-r--r-- 2022-09-12 12:47:14
Edit Download
4.60 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
11.62 KB lrw-r--r-- 2025-03-05 19:17:24
Edit Download
2.50 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
1.97 KB lrw-r--r-- 2024-09-19 22:55:36
Edit Download
11.25 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
10.60 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
67.84 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
6.34 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
5.49 KB lrw-r--r-- 2025-03-04 10:06:28
Edit Download
1.99 KB lrw-r--r-- 2024-09-19 23:07:12
Edit Download
7.02 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
4.91 KB lrw-r--r-- 2025-12-03 17:56:34
Edit Download
16.86 KB lrw-r--r-- 2024-05-01 21:01:10
Edit Download
24.23 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
3.97 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
47.66 KB lrw-r--r-- 2025-12-03 17:56:34
Edit Download
9.22 KB lrw-r--r-- 2025-02-11 10:40:30
Edit Download
25.51 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
198.38 KB lrw-r--r-- 2025-12-03 17:56:34
Edit Download
56.65 KB lrw-r--r-- 2025-12-03 17:56:34
Edit Download
10.46 KB lrw-r--r-- 2025-01-22 16:48:26
Edit Download
10.95 KB lrw-r--r-- 2024-10-13 16:09:12
Edit Download
29.26 KB lrw-r--r-- 2025-01-22 16:48:26
Edit Download
70.91 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
35.30 KB lrw-r--r-- 2025-12-03 17:56:34
Edit Download
15.02 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
2.57 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
39.83 KB lrw-r--r-- 2024-06-14 09:18:12
Edit Download
70.64 KB lrw-r--r-- 2025-04-25 15:28:30
Edit Download
15.56 KB lrw-r--r-- 2025-04-14 11:31:24
Edit Download
7.33 KB lrw-r--r-- 2023-02-21 13:39:20
Edit Download
253 B lrw-r--r-- 2024-09-27 16:28:14
Edit Download
7.96 KB lrw-r--r-- 2024-10-22 07:16:16
Edit Download
3.23 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
969 B lrw-r--r-- 2024-09-30 19:50:20
Edit Download
16.28 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
7.22 KB lrw-r--r-- 2023-06-24 14:17:24
Edit Download
12.95 KB lrw-r--r-- 2025-12-03 17:56:34
Edit Download
6.53 KB lrw-r--r-- 2023-06-22 11:57:24
Edit Download
3.42 KB lrw-r--r-- 2022-09-12 12:47:14
Edit Download
5.84 KB lrw-r--r-- 2023-06-22 11:36:26
Edit Download
1.97 KB lrw-r--r-- 2022-12-15 18:32:18
Edit Download
4.30 KB lrw-r--r-- 2023-10-11 04:05:26
Edit Download
2.91 KB lrw-r--r-- 2022-09-12 12:47:14
Edit Download
16.46 KB lrw-r--r-- 2023-09-21 15:29:12
Edit Download
40.60 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
20.22 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
36.11 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
7.27 KB lrw-r--r-- 2024-02-27 19:38:16
Edit Download
6.62 KB lrw-r--r-- 2025-12-03 17:56:34
Edit Download
16.49 KB lrw-r--r-- 2025-02-25 19:40:22
Edit Download
1.79 KB lrw-r--r-- 2024-02-05 22:25:14
Edit Download
29.82 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
6.67 KB lrw-r--r-- 2023-05-11 08:15:24
Edit Download
8.98 KB lrw-r--r-- 2025-12-03 17:56:34
Edit Download
19.42 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
12.01 KB lrw-r--r-- 2024-09-13 19:12:16
Edit Download
17.11 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
1.06 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
6.74 KB lrw-r--r-- 2024-03-06 02:05:12
Edit Download
30.93 KB lrw-r--r-- 2025-12-03 17:56:34
Edit Download
4.99 KB lrw-r--r-- 2024-09-03 15:19:14
Edit Download
4.25 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
24.72 KB lrw-r--r-- 2025-03-17 19:40:26
Edit Download
29.96 KB lrw-r--r-- 2025-02-09 08:09:22
Edit Download
6.34 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
159.91 KB lrw-r--r-- 2025-12-03 17:56:34
Edit Download
6.72 KB lrw-r--r-- 2022-10-04 00:59:14
Edit Download
10.92 KB lrw-r--r-- 2023-05-02 12:45:22
Edit Download
4.77 KB lrw-r--r-- 2025-02-17 08:24:22
Edit Download
3.38 KB lrw-r--r-- 2022-09-12 12:47:14
Edit Download
11.18 KB lrw-r--r-- 2025-02-23 08:11:22
Edit Download
62.19 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
2.46 KB lrw-r--r-- 2023-09-08 06:32:24
Edit Download
9.17 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
31.13 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
33.38 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
7.15 KB lrw-r--r-- 2025-02-11 08:14:22
Edit Download
3.47 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
1.87 KB lrw-r--r-- 2025-01-22 16:48:26
Edit Download
30.91 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
7.29 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
7.35 KB lrw-r--r-- 2025-02-18 19:32:22
Edit Download
11.86 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
19.12 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
18.12 KB lrw-r--r-- 2025-03-26 19:07:28
Edit Download
39.99 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
5.17 KB lrw-r--r-- 2022-09-12 12:47:14
Edit Download
979 B lrw-r--r-- 2024-02-14 16:27:10
Edit Download
18.44 KB lrw-r--r-- 2025-01-22 16:48:26
Edit Download
10.24 KB lrw-r--r-- 2024-11-19 23:50:24
Edit Download
1.77 KB lrw-r--r-- 2024-06-04 08:55:14
Edit Download
34.90 KB lrw-r--r-- 2024-11-03 23:34:16
Edit Download
7.19 KB lrw-r--r-- 2024-06-06 05:02:16
Edit Download
160.50 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
64.27 KB lrw-r--r-- 2025-04-08 11:18:28
Edit Download
27.95 KB lrw-r--r-- 2024-07-19 20:44:16
Edit Download
4.69 KB lrw-r--r-- 2025-02-18 19:32:22
Edit Download
13.01 KB lrw-r--r-- 2024-07-26 04:56:14
Edit Download
3.27 KB lrw-r--r-- 2022-09-12 12:47:14
Edit Download
18.00 KB lrw-r--r-- 2024-11-02 12:01:20
Edit Download
210.40 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
25.86 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
373 B lrw-r--r-- 2022-09-20 11:17:12
Edit Download
343 B lrw-r--r-- 2022-09-20 11:17:12
Edit Download
338 B lrw-r--r-- 2022-09-20 11:17:12
Edit Download
130.93 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
37.02 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
2.24 KB lrw-r--r-- 2025-01-22 16:48:26
Edit Download
4.02 KB lrw-r--r-- 2023-05-02 12:45:22
Edit Download
214.68 KB lrw-r--r-- 2026-03-02 09:20:26
Edit Download
5.38 KB lrw-r--r-- 2024-03-04 09:41:10
Edit Download
1.16 KB lrw-r--r-- 2020-01-28 21:45:18
Edit Download
4.04 KB lrw-r--r-- 2024-03-04 09:41:10
Edit Download
9.56 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
281.84 KB lrw-r--r-- 2025-12-03 17:56:34
Edit Download
14.95 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
8.44 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
20.71 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
5.72 KB lrw-r--r-- 2025-02-24 10:43:24
Edit Download
81.72 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
25.24 KB lrw-r--r-- 2025-01-22 16:48:26
Edit Download
4.81 KB lrw-r--r-- 2024-06-13 17:50:14
Edit Download
6.48 KB lrw-r--r-- 2023-02-23 22:23:20
Edit Download
2.79 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
89.69 KB lrw-r--r-- 2025-12-03 17:56:34
Edit Download
4.11 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
6.94 KB lrw-r--r-- 2024-05-27 13:29:16
Edit Download
289.13 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
200 B lrw-r--r-- 2020-11-12 08:17:08
Edit Download
255 B lrw-r--r-- 2020-11-16 19:52:06
Edit Download
22.66 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
9.68 KB lrw-r--r-- 2025-12-03 17:56:34
Edit Download
23.49 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
3.16 KB lrw-r--r-- 2021-05-15 14:38:06
Edit Download
544 B lrw-r--r-- 2023-09-30 21:22:28
Edit Download
2.84 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
6.09 KB lrw-r--r-- 2025-02-17 14:49:20
Edit Download
6.41 KB lrw-r--r-- 2025-01-22 16:48:26
Edit Download
69.46 KB lrw-r--r-- 2025-12-03 17:56:33
Edit Download
445 B lrw-r--r-- 2022-07-21 19:45:12
Edit Download
799 B lrw-r--r-- 2025-01-22 16:48:26
Edit Download
If ZipArchive is unavailable, a .tar will be created (no compression).