- <?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\Http\EventListener;
- use Symfony\Component\EventDispatcher\EventSubscriberInterface;
- use Symfony\Component\Security\Core\Encoder\EncoderFactoryInterface;
- use Symfony\Component\Security\Core\Exception\BadCredentialsException;
- use Symfony\Component\Security\Http\Authenticator\Passport\Badge\PasswordUpgradeBadge;
- use Symfony\Component\Security\Http\Authenticator\Passport\Credentials\CustomCredentials;
- use Symfony\Component\Security\Http\Authenticator\Passport\Credentials\PasswordCredentials;
- use Symfony\Component\Security\Http\Authenticator\Passport\UserPassportInterface;
- use Symfony\Component\Security\Http\Event\CheckPassportEvent;
- /**
-  * This listeners uses the interfaces of authenticators to
-  * determine how to check credentials.
-  *
-  * @author Wouter de Jong <wouter@driveamber.com>
-  *
-  * @final
-  * @experimental in 5.2
-  */
- class CheckCredentialsListener implements EventSubscriberInterface
- {
-     private $encoderFactory;
-     public function __construct(EncoderFactoryInterface $encoderFactory)
-     {
-         $this->encoderFactory = $encoderFactory;
-     }
-     public function checkPassport(CheckPassportEvent $event): void
-     {
-         $passport = $event->getPassport();
-         if ($passport instanceof UserPassportInterface && $passport->hasBadge(PasswordCredentials::class)) {
-             // Use the password encoder to validate the credentials
-             $user = $passport->getUser();
-             /** @var PasswordCredentials $badge */
-             $badge = $passport->getBadge(PasswordCredentials::class);
-             if ($badge->isResolved()) {
-                 return;
-             }
-             $presentedPassword = $badge->getPassword();
-             if ('' === $presentedPassword) {
-                 throw new BadCredentialsException('The presented password cannot be empty.');
-             }
-             if (null === $user->getPassword()) {
-                 throw new BadCredentialsException('The presented password is invalid.');
-             }
-             if (!$this->encoderFactory->getEncoder($user)->isPasswordValid($user->getPassword(), $presentedPassword, $user->getSalt())) {
-                 throw new BadCredentialsException('The presented password is invalid.');
-             }
-             $badge->markResolved();
-             if (!$passport->hasBadge(PasswordUpgradeBadge::class)) {
-                 $passport->addBadge(new PasswordUpgradeBadge($presentedPassword));
-             }
-             return;
-         }
-         if ($passport->hasBadge(CustomCredentials::class)) {
-             /** @var CustomCredentials $badge */
-             $badge = $passport->getBadge(CustomCredentials::class);
-             if ($badge->isResolved()) {
-                 return;
-             }
-             $badge->executeCustomChecker($passport->getUser());
-             return;
-         }
-     }
-     public static function getSubscribedEvents(): array
-     {
-         return [CheckPassportEvent::class => 'checkPassport'];
-     }
- }
-