<?php
namespace App\Security;
use App\Entity\User;
use App\Form\LoginType;
use Symfony\Component\Form\FormFactoryInterface;
use Symfony\Component\HttpFoundation\Cookie;
use Symfony\Component\HttpFoundation\RedirectResponse;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
use Symfony\Component\Security\Core\Security;
use Symfony\Component\Security\Http\Authenticator\AbstractLoginFormAuthenticator;
use Symfony\Component\Security\Http\Authenticator\Passport\Badge\CsrfTokenBadge;
use Symfony\Component\Security\Http\Authenticator\Passport\Badge\UserBadge;
use Symfony\Component\Security\Http\Authenticator\Passport\Badge\RememberMeBadge;
use Symfony\Component\Security\Http\Authenticator\Passport\Credentials\PasswordCredentials;
use Symfony\Component\Security\Http\Authenticator\Passport\Passport;
use Symfony\Component\Security\Http\Authenticator\Passport\PassportInterface;
use Symfony\Component\Security\Http\Util\TargetPathTrait;
class AppAuthenticator extends AbstractLoginFormAuthenticator
{
use TargetPathTrait;
public const LOGIN_ROUTE = 'app_login';
private UrlGeneratorInterface $urlGenerator;
/**
* @var FormFactoryInterface
*/
private $formFactory;
public function __construct(UrlGeneratorInterface $urlGenerator, FormFactoryInterface $formFactory)
{
$this->urlGenerator = $urlGenerator;
$this->formFactory = $formFactory;
}
public function authenticate(Request $request): PassportInterface
{
//$email = $request->request->get('email', '');
$loginForm = $this->formFactory->create(LoginType::class);
$loginForm->handleRequest($request);
$email = $loginForm->get('_username')->getData();
$request->getSession()->set(Security::LAST_USERNAME, $email);
return new Passport(
new UserBadge($email),
//new PasswordCredentials($request->request->get('password', '')),
new PasswordCredentials($loginForm->get('_password')->getData()),
[
//new CsrfTokenBadge('authenticate', $request->get('_csrf_token')),
new CsrfTokenBadge('authenticate', $request->get('_csrf_token')),
new RememberMeBadge(),
]
);
}
public function onAuthenticationSuccess(Request $request, TokenInterface $token, string $firewallName): ?Response
{
$user = $token->getUser();
$response = new RedirectResponse($this->urlGenerator->generate('home'));
if ($targetPath = $this->getTargetPath($request->getSession(), $firewallName)) {
$response= new RedirectResponse($targetPath);
} elseif (array_search(User::ROLE_ADMIN, $user->getRoles()) !== false) {
$response = new RedirectResponse($this->urlGenerator->generate('admin'));
}
return $response;
}
protected function getLoginUrl(Request $request): string
{
return $this->urlGenerator->generate(self::LOGIN_ROUTE);
}
}