before recepie upgrade
This commit is contained in:
		| @@ -7,12 +7,12 @@ use Doctrine\ORM\EntityManagerInterface; | ||||
| use JetBrains\PhpStorm\ArrayShape; | ||||
| use Symfony\Component\HttpFoundation\RedirectResponse; | ||||
| use Symfony\Component\HttpFoundation\Request; | ||||
| use Symfony\Component\PasswordHasher\Hasher\UserPasswordHasherInterface; | ||||
| use Symfony\Component\Routing\Generator\UrlGeneratorInterface; | ||||
| use Symfony\Component\Security\Core\Authentication\Token\TokenInterface; | ||||
| use Symfony\Component\Security\Core\Encoder\UserPasswordEncoderInterface; | ||||
| use Symfony\Component\Security\Core\Exception\AuthenticationException; | ||||
| use Symfony\Component\Security\Core\Exception\InvalidCsrfTokenException; | ||||
| use Symfony\Component\Security\Core\Exception\UsernameNotFoundException; | ||||
| use Symfony\Component\Security\Core\Exception\UserNotFoundException; | ||||
| use Symfony\Component\Security\Core\Security; | ||||
| use Symfony\Component\Security\Core\User\UserInterface; | ||||
| use Symfony\Component\Security\Core\User\UserProviderInterface; | ||||
| @@ -22,23 +22,27 @@ use Symfony\Component\Security\Guard\Authenticator\AbstractFormLoginAuthenticato | ||||
| use Symfony\Component\Security\Guard\PasswordAuthenticatedInterface; | ||||
| use Symfony\Component\Security\Http\Util\TargetPathTrait; | ||||
|  | ||||
| /** | ||||
|  * Class AppAuthenticator | ||||
|  * @package App\Security | ||||
|  */ | ||||
| class AppAuthenticator extends AbstractFormLoginAuthenticator implements PasswordAuthenticatedInterface | ||||
| { | ||||
| 	use TargetPathTrait; | ||||
| 	 | ||||
| 	public const LOGIN_ROUTE = 'app_login'; | ||||
| 	 | ||||
| 	private $entityManager; | ||||
| 	private $urlGenerator; | ||||
| 	private $csrfTokenManager; | ||||
| 	private $passwordEncoder; | ||||
| 	private EntityManagerInterface $entityManager; | ||||
| 	private UrlGeneratorInterface $urlGenerator; | ||||
| 	private CsrfTokenManagerInterface $csrfTokenManager; | ||||
| 	private UserPasswordHasherInterface $passwordHasher; | ||||
| 	 | ||||
| 	public function __construct(EntityManagerInterface $entityManager, UrlGeneratorInterface $urlGenerator, CsrfTokenManagerInterface $csrfTokenManager, UserPasswordEncoderInterface $passwordEncoder) | ||||
| 	public function __construct(EntityManagerInterface $entityManager, UrlGeneratorInterface $urlGenerator, CsrfTokenManagerInterface $csrfTokenManager, UserPasswordHasherInterface $passwordHasher) | ||||
| 	{ | ||||
| 		$this->entityManager = $entityManager; | ||||
| 		$this->urlGenerator = $urlGenerator; | ||||
| 		$this->csrfTokenManager = $csrfTokenManager; | ||||
| 		$this->passwordEncoder = $passwordEncoder; | ||||
| 		$this->passwordHasher = $passwordHasher; | ||||
| 	} | ||||
| 	 | ||||
| 	/** | ||||
| @@ -109,7 +113,7 @@ class AppAuthenticator extends AbstractFormLoginAuthenticator implements Passwor | ||||
| 	 * @throws AuthenticationException | ||||
| 	 * | ||||
| 	 */ | ||||
| 	public function getUser($credentials, UserProviderInterface $userProvider) | ||||
| 	public function getUser($credentials, UserProviderInterface $userProvider): ?UserInterface | ||||
| 	{ | ||||
| 		$token = new CsrfToken('authenticate', $credentials['csrf_token']); | ||||
| 		if (!$this->csrfTokenManager->isTokenValid($token)) { | ||||
| @@ -125,7 +129,7 @@ class AppAuthenticator extends AbstractFormLoginAuthenticator implements Passwor | ||||
| 		} | ||||
| 		 | ||||
| 		if (!$user) { | ||||
| 			throw new UsernameNotFoundException('Username or email could not be found.'); | ||||
| 			throw new UserNotFoundException('Username or email could not be found.'); | ||||
| 		} else { | ||||
| 			return $user; | ||||
| 		} | ||||
| @@ -149,7 +153,7 @@ class AppAuthenticator extends AbstractFormLoginAuthenticator implements Passwor | ||||
| 	public function checkCredentials($credentials, UserInterface $user): bool | ||||
| 	{ | ||||
| 		//return true; | ||||
| 		return $this->passwordEncoder->isPasswordValid($user, $credentials['password']); | ||||
| 		return $this->passwordHasher->isPasswordValid($user, $credentials['password']); | ||||
| 	} | ||||
| 	 | ||||
| 	/** | ||||
| @@ -160,6 +164,17 @@ class AppAuthenticator extends AbstractFormLoginAuthenticator implements Passwor | ||||
| 		return $credentials['password']; | ||||
| 	} | ||||
| 	 | ||||
| 	/** | ||||
| 	 * Called when authentication executed and was successful! | ||||
| 	 * | ||||
| 	 * This should return the Response sent back to the user, like a | ||||
| 	 * RedirectResponse to the last page they visited. | ||||
| 	 * | ||||
| 	 * If you return null, the current request will continue, and the user | ||||
| 	 * will be authenticated. This makes sense, for example, with an API. | ||||
| 	 * | ||||
| 	 * @return Response|null | ||||
| 	 */ | ||||
| 	public function onAuthenticationSuccess(Request $request, TokenInterface $token, string $providerKey) | ||||
| 	{ | ||||
| 		if ($targetPath = $this->getTargetPath($request->getSession(), $providerKey)) { | ||||
| @@ -174,15 +189,3 @@ class AppAuthenticator extends AbstractFormLoginAuthenticator implements Passwor | ||||
| 		return $this->urlGenerator->generate(self::LOGIN_ROUTE); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| /* | ||||
|  | ||||
| comment: | ||||
| author => user, | ||||
| createdAt, | ||||
| editedAt, | ||||
| editedby => user, | ||||
| editreason | ||||
|  | ||||
| */ | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user