hydra-sql/vendor/symfony/security-core/Encoder/LegacyEncoderTrait.php
2022-05-03 08:54:45 +02:00

57 lines
1.4 KiB
PHP

<?php
/*
* This file is part of the Symfony package.
*
* (c) Fabien Potencier <fabien@symfony.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Symfony\Component\Security\Core\Encoder;
use Symfony\Component\PasswordHasher\Exception\InvalidPasswordException;
use Symfony\Component\PasswordHasher\LegacyPasswordHasherInterface;
use Symfony\Component\PasswordHasher\PasswordHasherInterface;
use Symfony\Component\Security\Core\Exception\BadCredentialsException;
/**
* @internal
*/
trait LegacyEncoderTrait
{
/**
* @var PasswordHasherInterface|LegacyPasswordHasherInterface
*/
private $hasher;
/**
* {@inheritdoc}
*/
public function encodePassword(string $raw, ?string $salt): string
{
try {
return $this->hasher->hash($raw, $salt);
} catch (InvalidPasswordException $e) {
throw new BadCredentialsException('Bad credentials.');
}
}
/**
* {@inheritdoc}
*/
public function isPasswordValid(string $encoded, string $raw, ?string $salt): bool
{
return $this->hasher->verify($encoded, $raw, $salt);
}
/**
* {@inheritdoc}
*/
public function needsRehash(string $encoded): bool
{
return $this->hasher->needsRehash($encoded);
}
}