mirror of
https://github.com/WordPress/WordPress.git
synced 2025-01-12 19:30:38 +01:00
95f823d933
This is a major release and contains breaking changes. Most important changes to be aware of for this release: * All code is now namespaced. Though there is a full backward compatibility layer available and the old class names are still supported, using them will generate a deprecation notice (which can be silenced by plugins if they'd need to support multiple WP versions). See the [https://requests.ryanmccue.info/docs/upgrading.html upgrade guide] for more details. * A lot of classes have been marked `final`. This should generally not affect userland code as care has been taken to not apply the `final` keyword to classes which are known to be extended in userland code. * Extensive input validation has been added to Requests. When Requests is used as documented though, this will be unnoticable. * A new `WpOrg\Requests\Requests::has_capabilities()` method has been introduced which can be used to address #37708. * A new `WpOrg\Requests\Response::decode_body()` method has been introduced which may be usable to simplify some of the WP native wrapper code. * Remaining PHP 8.0 compatibility fixed (support for named parameters). * PHP 8.1 compatibility. Release notes: https://github.com/WordPress/Requests/releases/tag/v2.0.0 For a full list of changes in this update, see the Requests GitHub: https://github.com/WordPress/Requests/compare/v1.8.1...v2.0.0 Follow-up to [50842], [51078]. Props jrf, schlessera, datagutten, wojsmol, dd32, dustinrue, soulseekah, costdev, szepeviktor. Fixes #54504. Built from https://develop.svn.wordpress.org/trunk@52244 git-svn-id: http://core.svn.wordpress.org/trunk@51836 1a063a9b-81f0-0310-95a4-ce76da25c4cd
110 lines
2.5 KiB
PHP
110 lines
2.5 KiB
PHP
<?php
|
|
/**
|
|
* Input validation utilities.
|
|
*
|
|
* @package Requests\Utilities
|
|
*/
|
|
|
|
namespace WpOrg\Requests\Utility;
|
|
|
|
use ArrayAccess;
|
|
use CurlHandle;
|
|
use Traversable;
|
|
|
|
/**
|
|
* Input validation utilities.
|
|
*
|
|
* @package Requests\Utilities
|
|
*/
|
|
final class InputValidator {
|
|
|
|
/**
|
|
* Verify that a received input parameter is of type string or is "stringable".
|
|
*
|
|
* @param mixed $input Input parameter to verify.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public static function is_string_or_stringable($input) {
|
|
return is_string($input) || self::is_stringable_object($input);
|
|
}
|
|
|
|
/**
|
|
* Verify whether a received input parameter is usable as an integer array key.
|
|
*
|
|
* @param mixed $input Input parameter to verify.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public static function is_numeric_array_key($input) {
|
|
if (is_int($input)) {
|
|
return true;
|
|
}
|
|
|
|
if (!is_string($input)) {
|
|
return false;
|
|
}
|
|
|
|
return (bool) preg_match('`^-?[0-9]+$`', $input);
|
|
}
|
|
|
|
/**
|
|
* Verify whether a received input parameter is "stringable".
|
|
*
|
|
* @param mixed $input Input parameter to verify.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public static function is_stringable_object($input) {
|
|
return is_object($input) && method_exists($input, '__toString');
|
|
}
|
|
|
|
/**
|
|
* Verify whether a received input parameter is _accessible as if it were an array_.
|
|
*
|
|
* @param mixed $input Input parameter to verify.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public static function has_array_access($input) {
|
|
return is_array($input) || $input instanceof ArrayAccess;
|
|
}
|
|
|
|
/**
|
|
* Verify whether a received input parameter is "iterable".
|
|
*
|
|
* @internal The PHP native `is_iterable()` function was only introduced in PHP 7.1
|
|
* and this library still supports PHP 5.6.
|
|
*
|
|
* @param mixed $input Input parameter to verify.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public static function is_iterable($input) {
|
|
return is_array($input) || $input instanceof Traversable;
|
|
}
|
|
|
|
/**
|
|
* Verify whether a received input parameter is a Curl handle.
|
|
*
|
|
* The PHP Curl extension worked with resources prior to PHP 8.0 and with
|
|
* an instance of the `CurlHandle` class since PHP 8.0.
|
|
* {@link https://www.php.net/manual/en/migration80.incompatible.php#migration80.incompatible.resource2object}
|
|
*
|
|
* @param mixed $input Input parameter to verify.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public static function is_curl_handle($input) {
|
|
if (is_resource($input)) {
|
|
return get_resource_type($input) === 'curl';
|
|
}
|
|
|
|
if (is_object($input)) {
|
|
return $input instanceof CurlHandle;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
}
|