__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
<?php
declare(strict_types=1);
namespace Jose\Component\KeyManagement\Analyzer;
use InvalidArgumentException;
use Jose\Component\Core\JWK;
use Jose\Component\Core\Util\Base64UrlSafe;
use function is_array;
use function is_string;
final class RsaAnalyzer implements KeyAnalyzer
{
public function analyze(JWK $jwk, MessageBag $bag): void
{
if ($jwk->get('kty') !== 'RSA') {
return;
}
$this->checkExponent($jwk, $bag);
$this->checkModulus($jwk, $bag);
}
private function checkExponent(JWK $jwk, MessageBag $bag): void
{
$e = $jwk->get('e');
if (! is_string($e)) {
$bag->add(Message::high('The exponent is not valid.'));
return;
}
$exponent = unpack('l', str_pad(Base64UrlSafe::decodeNoPadding($e), 4, "\0"));
if (! is_array($exponent) || ! isset($exponent[1])) {
throw new InvalidArgumentException('Unable to get the private key');
}
if ($exponent[1] < 65537) {
$bag->add(Message::high('The exponent is too low. It should be at least 65537.'));
}
}
private function checkModulus(JWK $jwk, MessageBag $bag): void
{
$n = $jwk->get('n');
if (! is_string($n)) {
$bag->add(Message::high('The modulus is not valid.'));
return;
}
$n = 8 * mb_strlen(Base64UrlSafe::decodeNoPadding($n), '8bit');
if ($n < 2048) {
$bag->add(Message::high('The key length is less than 2048 bits.'));
}
if ($jwk->has('d') && (! $jwk->has('p') || ! $jwk->has('q') || ! $jwk->has('dp') || ! $jwk->has(
'dq'
) || ! $jwk->has('qi'))) {
$bag->add(
Message::medium(
'The key is a private RSA key, but Chinese Remainder Theorem primes are missing. These primes are not mandatory, but signatures and decryption processes are faster when available.'
)
);
}
}
}
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| AlgorithmAnalyzer.php | File | 367 B | 0664 |
|
| ES256KeyAnalyzer.php | File | 558 B | 0664 |
|
| ES384KeyAnalyzer.php | File | 558 B | 0664 |
|
| ES512KeyAnalyzer.php | File | 558 B | 0664 |
|
| ESKeyAnalyzer.php | File | 1.98 KB | 0664 |
|
| HS256KeyAnalyzer.php | File | 305 B | 0664 |
|
| HS384KeyAnalyzer.php | File | 305 B | 0664 |
|
| HS512KeyAnalyzer.php | File | 305 B | 0664 |
|
| HSKeyAnalyzer.php | File | 1.12 KB | 0664 |
|
| KeyAnalyzer.php | File | 304 B | 0664 |
|
| KeyAnalyzerManager.php | File | 743 B | 0664 |
|
| KeyIdentifierAnalyzer.php | File | 371 B | 0664 |
|
| KeysetAnalyzer.php | File | 320 B | 0664 |
|
| KeysetAnalyzerManager.php | File | 777 B | 0664 |
|
| Message.php | File | 1.4 KB | 0664 |
|
| MessageBag.php | File | 961 B | 0664 |
|
| MixedKeyTypes.php | File | 912 B | 0664 |
|
| MixedPublicAndPrivateKeys.php | File | 942 B | 0664 |
|
| NoneAnalyzer.php | File | 519 B | 0664 |
|
| OctAnalyzer.php | File | 744 B | 0664 |
|
| RsaAnalyzer.php | File | 1.97 KB | 0664 |
|
| UsageAnalyzer.php | File | 1.25 KB | 0664 |
|
| ZxcvbnKeyAnalyzer.php | File | 1.48 KB | 0664 |
|