Server IP : 66.29.132.124 / Your IP : 3.145.16.251 Web Server : LiteSpeed System : Linux business141.web-hosting.com 4.18.0-553.lve.el8.x86_64 #1 SMP Mon May 27 15:27:34 UTC 2024 x86_64 User : wavevlvu ( 1524) PHP Version : 7.4.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /home/wavevlvu/book24.ng/vendor/aws/aws-sdk-php/src/ |
Upload File : |
<?php namespace Aws; use Aws\Api\Service; use Psr\Http\Message\RequestInterface; /** * @internal Middleware that auto fills parameters with `idempotencyToken` trait */ class IdempotencyTokenMiddleware { /** @var Service */ private $service; /** @var string */ private $bytesGenerator; /** @var callable */ private $nextHandler; /** * Creates a middleware that populates operation parameter * with trait 'idempotencyToken' enabled with a random UUIDv4 * * One of following functions needs to be available * in order to generate random bytes used for UUID * (SDK will attempt to utilize function in following order): * - random_bytes (requires PHP 7.0 or above) * - openssl_random_pseudo_bytes (requires 'openssl' module enabled) * - mcrypt_create_iv (requires 'mcrypt' module enabled) * * You may also supply a custom bytes generator as an optional second * parameter. * * @param \Aws\Api\Service $service * @param callable|null $bytesGenerator * * @return callable */ public static function wrap( Service $service, callable $bytesGenerator = null ) { return function (callable $handler) use ($service, $bytesGenerator) { return new self($handler, $service, $bytesGenerator); }; } public function __construct( callable $nextHandler, Service $service, callable $bytesGenerator = null ) { $this->bytesGenerator = $bytesGenerator ?: $this->findCompatibleRandomSource(); $this->service = $service; $this->nextHandler = $nextHandler; } public function __invoke( CommandInterface $command, RequestInterface $request = null ) { $handler = $this->nextHandler; if ($this->bytesGenerator) { $operation = $this->service->getOperation($command->getName()); $members = $operation->getInput()->getMembers(); foreach ($members as $member => $value) { if ($value['idempotencyToken']) { $bytes = call_user_func($this->bytesGenerator, 16); // populating UUIDv4 only when the parameter is not set $command[$member] = $command[$member] ?: $this->getUuidV4($bytes); // only one member could have the trait enabled break; } } } return $handler($command, $request); } /** * This function generates a random UUID v4 string, * which is used as auto filled token value. * * @param string $bytes 16 bytes of pseudo-random bytes * @return string * More information about UUID v4, see: * https://en.wikipedia.org/wiki/Universally_unique_identifier#Version_4_.28random.29 * https://tools.ietf.org/html/rfc4122#page-14 */ private static function getUuidV4($bytes) { // set version to 0100 $bytes[6] = chr(ord($bytes[6]) & 0x0f | 0x40); // set bits 6-7 to 10 $bytes[8] = chr(ord($bytes[8]) & 0x3f | 0x80); return vsprintf('%s%s-%s-%s-%s-%s%s%s', str_split(bin2hex($bytes), 4)); } /** * This function decides the PHP function used in generating random bytes. * * @return callable|null */ private function findCompatibleRandomSource() { if (function_exists('random_bytes')) { return 'random_bytes'; } if (function_exists('openssl_random_pseudo_bytes')) { return 'openssl_random_pseudo_bytes'; } if (function_exists('mcrypt_create_iv')) { return 'mcrypt_create_iv'; } } }