__  __    __   __  _____      _            _          _____ _          _ _ 
 |  \/  |   \ \ / / |  __ \    (_)          | |        / ____| |        | | |
 | \  / |_ __\ V /  | |__) | __ ___   ____ _| |_ ___  | (___ | |__   ___| | |
 | |\/| | '__|> <   |  ___/ '__| \ \ / / _` | __/ _ \  \___ \| '_ \ / _ \ | |
 | |  | | |_ / . \  | |   | |  | |\ V / (_| | ||  __/  ____) | | | |  __/ | |
 |_|  |_|_(_)_/ \_\ |_|   |_|  |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1
 if you need WebShell for Seo everyday contact me on Telegram
 Telegram Address : @jackleet
        
        
For_More_Tools: Telegram: @jackleet | Bulk Smtp support mail sender | Business Mail Collector | Mail Bouncer All Mail | Bulk Office Mail Validator | Html Letter private



Upload:

Command:

[email protected]: ~ $
<?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.'
                )
            );
        }
    }
}

Filemanager

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
Filemanager