primo commit
This commit is contained in:
55
libraries/vendor/web-token/jwt-library/KeyManagement/Analyzer/ZxcvbnKeyAnalyzer.php
vendored
Normal file
55
libraries/vendor/web-token/jwt-library/KeyManagement/Analyzer/ZxcvbnKeyAnalyzer.php
vendored
Normal file
@ -0,0 +1,55 @@
|
||||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace Jose\Component\KeyManagement\Analyzer;
|
||||
|
||||
use Jose\Component\Core\JWK;
|
||||
use Jose\Component\Core\Util\Base64UrlSafe;
|
||||
use Throwable;
|
||||
use ZxcvbnPhp\Zxcvbn;
|
||||
use function is_string;
|
||||
|
||||
final class ZxcvbnKeyAnalyzer implements KeyAnalyzer
|
||||
{
|
||||
public function analyze(JWK $jwk, MessageBag $bag): void
|
||||
{
|
||||
if ($jwk->get('kty') !== 'oct') {
|
||||
return;
|
||||
}
|
||||
$k = $jwk->get('k');
|
||||
if (! is_string($k)) {
|
||||
$bag->add(Message::high('The key is not valid'));
|
||||
|
||||
return;
|
||||
}
|
||||
$k = Base64UrlSafe::decodeNoPadding($k);
|
||||
if (! class_exists(Zxcvbn::class)) {
|
||||
return;
|
||||
}
|
||||
$zxcvbn = new Zxcvbn();
|
||||
try {
|
||||
$strength = $zxcvbn->passwordStrength($k);
|
||||
switch (true) {
|
||||
case $strength['score'] < 3:
|
||||
$bag->add(
|
||||
Message::high(
|
||||
'The octet string is weak and easily guessable. Please change your key as soon as possible.'
|
||||
)
|
||||
);
|
||||
|
||||
break;
|
||||
|
||||
case $strength['score'] === 3:
|
||||
$bag->add(Message::medium('The octet string is safe, but a longer key is preferable.'));
|
||||
|
||||
break;
|
||||
|
||||
default:
|
||||
break;
|
||||
}
|
||||
} catch (Throwable) {
|
||||
$bag->add(Message::medium('The test of the weakness cannot be performed.'));
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user