<?php
namespace PaperKite\Common\Controller;
use LogicException;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\Routing\Annotation\Route;
use Symfony\Component\Security\Http\Authentication\AuthenticationUtils;
class SecurityController extends AbstractController
{
#[Route(path: '/login', name: 'security_login')]
public function login(AuthenticationUtils $authenticationUtils): Response
{
if ($this->getUser()) {
return $this->redirectToRoute('admin_dashboard');
}
// get the login error if there is one
$error = $authenticationUtils->getLastAuthenticationError();
// last username entered by the user
$lastUsername = $authenticationUtils->getLastUsername();
return $this->render('@EasyAdmin/page/login.html.twig', [
'last_username' => $lastUsername,
'error' => $error,
'csrf_token_intention' => 'authenticate',
'page_title' => 'Connexion',
'target_path' => $this->generateUrl('admin_dashboard'),
'username_label' => 'Username',
'password_label' => 'Password',
'username_parameter' => 'username',
'password_parameter' => 'password',
]);
}
#[Route(path: '/logout', name: 'security_logout')]
public function logout()
{
throw new LogicException('This should never be reached!');
}
}