From b24386271613b3dfb00566e9a5b62b00970b8473 Mon Sep 17 00:00:00 2001 From: Stephen Ball Date: Sun, 14 Mar 2021 13:46:22 +0000 Subject: [PATCH] Cleanup --- resources/lang/de/validation.php | 1 - src/ZxcvbnServiceProvider.php | 4 --- src/ZxcvbnValidator.php | 47 ++++++++++++++++---------------- 3 files changed, 23 insertions(+), 29 deletions(-) diff --git a/resources/lang/de/validation.php b/resources/lang/de/validation.php index de54eaf..2c8b21d 100644 --- a/resources/lang/de/validation.php +++ b/resources/lang/de/validation.php @@ -17,5 +17,4 @@ 'top_100' => 'Das Passwort ist in den Top 100 der häufigsten Passwörter.', 'digits' => 'Durch das Hinzufügen einer Reihe von Ziffern wird die Sicherheit nicht verbessert.', 'reused' => 'Die Wiederverwendung von Informationen wie Name, Benutzername oder E-Mail-Adresse im Kennwort ist nicht sicher.', - ]; diff --git a/src/ZxcvbnServiceProvider.php b/src/ZxcvbnServiceProvider.php index ee06f83..23e03e7 100644 --- a/src/ZxcvbnServiceProvider.php +++ b/src/ZxcvbnServiceProvider.php @@ -11,8 +11,6 @@ class ZxcvbnServiceProvider extends ServiceProvider /** * Bootstrap the application services. - * - * @return void */ public function boot() { @@ -27,8 +25,6 @@ public function boot() /** * Register the application services. - * - * @return void */ public function register() { diff --git a/src/ZxcvbnValidator.php b/src/ZxcvbnValidator.php index 119770a..3c250b5 100644 --- a/src/ZxcvbnValidator.php +++ b/src/ZxcvbnValidator.php @@ -5,6 +5,8 @@ use Illuminate\Translation\Translator; use Illuminate\Validation\Validator; use InvalidArgumentException; +use stdClass; +use ZxcvbnPhp\Matchers\BaseMatch; use ZxcvbnPhp\Zxcvbn; /** @@ -28,15 +30,14 @@ public function __construct(Translator $translator) $this->translator = $translator; } - public function validate(...$args) + public function validate(...$args): bool { - /** @var string $value */ $value = trim($args[1]); /** @var array $parameters */ $parameters = $args[2] ? $args[2] : []; - /** @var \Illuminate\Validation\Validator $validator */ + /** @var Validator $validator */ $validator = $args[3]; $desiredScore = $this->getDesiredScore($parameters); @@ -59,7 +60,7 @@ public function validate(...$args) return false; } - private function getDesiredScore(array $parameters = []) + private function getDesiredScore(array $parameters = []): int { $desiredScore = isset($parameters[0]) ? $parameters[0] : self::DEFAULT_MINIMUM_STRENGTH; @@ -70,7 +71,7 @@ private function getDesiredScore(array $parameters = []) return $desiredScore; } - private function getAdditionalInput(Validator $validator, array $parameters = []) + private function getAdditionalInput(Validator $validator, array $parameters = []): array { $input = $validator->getData(); $otherInput = []; @@ -87,7 +88,7 @@ private function getFeedbackTranslation() { $isOnlyMatch = count($this->result['sequence']) === 1; - $longestMatch = new \stdClass(); + $longestMatch = new stdClass(); $longestMatch->token = ''; foreach ($this->result['sequence'] as $match) { @@ -99,7 +100,7 @@ private function getFeedbackTranslation() return $this->getMatchFeedback($longestMatch, $isOnlyMatch); } - private function getMatchFeedback($match, $isOnlyMatch) + private function getMatchFeedback(BaseMatch $match, $isOnlyMatch) { $pattern = mb_strtolower($match->pattern); $strategy = 'get' . ucfirst($pattern) . 'Warning'; @@ -113,31 +114,28 @@ private function getMatchFeedback($match, $isOnlyMatch) /** * @SuppressWarnings(PHPMD.UnusedPrivateMethod) - * @param $match - * @param $isOnlyMatch - * @return string */ - private function getDictionaryWarning($match, $isOnlyMatch) + private function getDictionaryWarning(BaseMatch $match, bool $isOnlyMatch): string { - $warning = 'common'; // $match->dictionaryName == 'english' if ($match->dictionaryName === 'passwords') { - $warning = $this->getPasswordWarning($match, $isOnlyMatch); - } elseif (in_array($match->dictionaryName, ['surnames', 'male_names', 'female_names'], true)) { - $warning = 'names'; - } elseif ($match->dictionaryName === 'user_inputs') { - $warning = 'reused'; + return $this->getPasswordWarning($match, $isOnlyMatch); } - return $warning; + if (in_array($match->dictionaryName, ['surnames', 'male_names', 'female_names'], true)) { + return 'names'; + } + + if ($match->dictionaryName === 'user_inputs') { + return 'reused'; + } + + return 'common'; } /** * @SuppressWarnings(PHPMD.UnusedPrivateMethod) - * @noinspection PhpMissingReturnTypeInspection - * @param $match - * @return string */ - private function getRegexWarning($match) + private function getRegexWarning(BaseMatch $match): string { $warning = 'year'; @@ -148,11 +146,12 @@ private function getRegexWarning($match) return $warning; } - private function getPasswordWarning($match, $isOnlyMatch) + private function getPasswordWarning(BaseMatch $match, bool $isOnlyMatch): string { if (!$isOnlyMatch) { return 'suggestion'; } + if ($match->l33t) { return 'predictable'; } @@ -175,7 +174,7 @@ private function getPasswordWarning($match, $isOnlyMatch) /** * @SuppressWarnings(PHPMD.UnusedPrivateMethod) */ - private function getSpatialWarning($match) + private function getSpatialWarning(BaseMatch $match): string { if ($match->turns === 1) { return 'straight_spatial';