__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ 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 Brick\Math\BigInteger;
use Jose\Component\Core\JWK;
use Jose\Component\Core\Util\Base64UrlSafe;
use Jose\Component\Core\Util\Ecc\Curve;
use function is_string;
abstract class ESKeyAnalyzer implements KeyAnalyzer
{
public function analyze(JWK $jwk, MessageBag $bag): void
{
if ($jwk->get('kty') !== 'EC') {
return;
}
if (! $jwk->has('crv')) {
$bag->add(Message::high('Invalid key. The components "crv" is missing.'));
return;
}
if ($jwk->get('crv') !== $this->getCurveName()) {
return;
}
$x = $jwk->get('x');
if (! is_string($x)) {
$bag->add(Message::high('Invalid key. The components "x" shall be a string.'));
return;
}
$x = Base64UrlSafe::decodeNoPadding($x);
$xLength = 8 * mb_strlen($x, '8bit');
$y = $jwk->get('y');
if (! is_string($y)) {
$bag->add(Message::high('Invalid key. The components "y" shall be a string.'));
return;
}
$y = Base64UrlSafe::decodeNoPadding($y);
$yLength = 8 * mb_strlen($y, '8bit');
if ($yLength !== $xLength || $yLength !== $this->getKeySize()) {
$bag->add(
Message::high(sprintf(
'Invalid key. The components "x" and "y" size shall be %d bits.',
$this->getKeySize()
))
);
}
$xBI = BigInteger::fromBase(bin2hex($x), 16);
$yBI = BigInteger::fromBase(bin2hex($y), 16);
if (! $this->getCurve()->contains($xBI, $yBI)) {
$bag->add(Message::high('Invalid key. The point is not on the curve.'));
}
}
abstract protected function getAlgorithmName(): string;
abstract protected function getCurveName(): string;
abstract protected function getCurve(): Curve;
abstract protected function getKeySize(): int;
}
| 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 |
|