rest_find_one_matching_schema

函数
rest_find_one_matching_schema ( $value, $args, $param, $stop_after_first_match = false )
参数
  • (mixed) $value The value to validate.
    Required:
  • (array) $args The schema array to use.
    Required:
  • (string) $param The parameter name, used in error messages.
    Required:
  • (bool) $stop_after_first_match Optional. Whether the process should stop after the first successful match.
    Required:
    Default: false
返回值
  • (array|WP_Error) The matching schema or WP_Error instance if the number of matching schemas is not equal to one.
定义位置
相关方法
rest_find_any_matching_schemarest_find_matching_pattern_property_schemarest_handle_multi_type_schemaget_block_metadata_i18n_schemarest_get_endpoint_args_for_schema
引入
5.6.0
弃用
-

rest_find_one_matching_schema: 这个函数用于查找与给定数据相匹配的模式。它接收一个数据对象和一个模式对象的数组,并返回与数据相匹配的第一个模式对象。

在"oneOf"模式中找到匹配的模式。

function rest_find_one_matching_schema( $value, $args, $param, $stop_after_first_match = false ) {
	$matching_schemas = array();
	$errors           = array();

	foreach ( $args['oneOf'] as $index => $schema ) {
		if ( ! isset( $schema['type'] ) && isset( $args['type'] ) ) {
			$schema['type'] = $args['type'];
		}

		$is_valid = rest_validate_value_from_schema( $value, $schema, $param );
		if ( ! is_wp_error( $is_valid ) ) {
			if ( $stop_after_first_match ) {
				return $schema;
			}

			$matching_schemas[] = array(
				'schema_object' => $schema,
				'index'         => $index,
			);
		} else {
			$errors[] = array(
				'error_object' => $is_valid,
				'schema'       => $schema,
				'index'        => $index,
			);
		}
	}

	if ( ! $matching_schemas ) {
		return rest_get_combining_operation_error( $value, $param, $errors );
	}

	if ( count( $matching_schemas ) > 1 ) {
		$schema_positions = array();
		$schema_titles    = array();

		foreach ( $matching_schemas as $schema ) {
			$schema_positions[] = $schema['index'];

			if ( isset( $schema['schema_object']['title'] ) ) {
				$schema_titles[] = $schema['schema_object']['title'];
			}
		}

		// If each schema has a title, include those titles in the error message.
		if ( count( $schema_titles ) === count( $matching_schemas ) ) {
			return new WP_Error(
				'rest_one_of_multiple_matches',
				/* translators: 1: Parameter, 2: Schema titles. */
				wp_sprintf( __( '%1$s matches %2$l, but should match only one.' ), $param, $schema_titles ),
				array( 'positions' => $schema_positions )
			);
		}

		return new WP_Error(
			'rest_one_of_multiple_matches',
			/* translators: %s: Parameter. */
			sprintf( __( '%s matches more than one of the expected formats.' ), $param ),
			array( 'positions' => $schema_positions )
		);
	}

	return $matching_schemas[0]['schema_object'];
}

常见问题

FAQs
查看更多 >