![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/old/vendor/web-token/jwt-framework/src/Component/Encryption/ |
<?php declare(strict_types=1); namespace Jose\Component\Encryption; use Jose\Component\Checker\HeaderCheckerManager; use Jose\Component\Core\JWK; use Jose\Component\Core\JWKSet; use Jose\Component\Encryption\Serializer\JWESerializerManager; use RuntimeException; use Throwable; /** * @see \Jose\Tests\Component\Encryption\JWELoaderTest */ class JWELoader { public function __construct( private readonly JWESerializerManager $serializerManager, private readonly JWEDecrypter $jweDecrypter, private readonly ?HeaderCheckerManager $headerCheckerManager ) { } /** * Returns the JWE Decrypter object. */ public function getJweDecrypter(): JWEDecrypter { return $this->jweDecrypter; } /** * Returns the header checker manager if set. */ public function getHeaderCheckerManager(): ?HeaderCheckerManager { return $this->headerCheckerManager; } /** * Returns the serializer manager. */ public function getSerializerManager(): JWESerializerManager { return $this->serializerManager; } /** * This method will try to load and decrypt the given token using a JWK. If succeeded, the methods will populate the * $recipient variable and returns the JWE. */ public function loadAndDecryptWithKey(string $token, JWK $key, ?int &$recipient): JWE { $keyset = new JWKSet([$key]); return $this->loadAndDecryptWithKeySet($token, $keyset, $recipient); } /** * This method will try to load and decrypt the given token using a JWKSet. If succeeded, the methods will populate * the $recipient variable and returns the JWE. */ public function loadAndDecryptWithKeySet(string $token, JWKSet $keyset, ?int &$recipient): JWE { try { $jwe = $this->serializerManager->unserialize($token); $nbRecipients = $jwe->countRecipients(); for ($i = 0; $i < $nbRecipients; ++$i) { if ($this->processRecipient($jwe, $keyset, $i)) { $recipient = $i; return $jwe; } } } catch (Throwable) { // Nothing to do. Exception thrown just after } throw new RuntimeException('Unable to load and decrypt the token.'); } private function processRecipient(JWE &$jwe, JWKSet $keyset, int $recipient): bool { try { if ($this->headerCheckerManager !== null) { $this->headerCheckerManager->check($jwe, $recipient); } return $this->jweDecrypter->decryptUsingKeySet($jwe, $keyset, $recipient); } catch (Throwable) { return false; } } }