src/Controller/SecurityController.php line 39

Open in your IDE?
  1. <?php
  2. namespace App\Controller;
  3. use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
  4. use Symfony\Component\HttpFoundation\Response;
  5. use Symfony\Component\Routing\Annotation\Route;
  6. use Symfony\Component\Security\Http\Authentication\AuthenticationUtils;
  7. use Symfony\Component\Asset\Package;
  8. use Symfony\Component\Asset\VersionStrategy\EmptyVersionStrategy;
  9. class SecurityController extends AbstractController
  10. {
  11.     #[Route(path'/login'name'app_login')]
  12.     public function login(AuthenticationUtils $authenticationUtils): Response
  13.     {
  14.         $package = new Package(new EmptyVersionStrategy());
  15.         if ( $this->getUser() ) {
  16.             return $this->redirectToRoute('dashboard');
  17.         }
  18.         // get the login error if there is one
  19.         $error $authenticationUtils->getLastAuthenticationError();
  20.         // last username entered by the user
  21.         $lastUsername $authenticationUtils->getLastUsername(); 
  22.         return $this->render('security/login.html.twig', ['last_username' => $lastUsername'error' => $error'login_css' => $package->getUrl('./public/css/login.css'), 'logo' => $package->getUrl('/images/logo-sm.png')]);
  23.     }
  24.     #[Route(path'/logout'name'app_logout')]
  25.     public function logout(): void
  26.     {
  27.         throw new \LogicException('This method can be blank - it will be intercepted by the logout key on your firewall.');
  28.     }
  29.     #[Route(path'/'name'app_home')]
  30.     public function index(): Response 
  31.     {
  32.         if ( $this->getUser() ) {
  33.             return $this->redirectToRoute('dashboard');
  34.         }else{
  35.             return $this->redirectToRoute('app_login');
  36.         }
  37.     }
  38. }