34 lines
1.1 KiB
PHP
34 lines
1.1 KiB
PHP
<?php
|
|
|
|
|
|
namespace App\Controller\Admin;
|
|
|
|
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
|
use Symfony\Component\HttpFoundation\Response;
|
|
use Symfony\Component\Routing\Attribute\Route;
|
|
use Symfony\Component\Security\Http\Authentication\AuthenticationUtils;
|
|
|
|
final class SecurityController extends AbstractController
|
|
{
|
|
#[Route('/admin/login', name: 'admin_login')]
|
|
public function login(AuthenticationUtils $authUtils): Response
|
|
{
|
|
// Wenn bereits eingeloggt → direkt ins Dashboard
|
|
if ($this->getUser()) {
|
|
return $this->redirectToRoute('admin_dashboard');
|
|
}
|
|
|
|
return $this->render('admin/security/login.html.twig', [
|
|
'last_username' => $authUtils->getLastUsername(),
|
|
'error' => $authUtils->getLastAuthenticationError(),
|
|
]);
|
|
}
|
|
|
|
#[Route('/admin/logout', name: 'admin_logout')]
|
|
public function logout(): void
|
|
{
|
|
// Symfony interceptet diese Route, daher bleibt sie leer.
|
|
throw new \LogicException('This method can be blank - it will be intercepted by the logout key on your firewall.');
|
|
}
|
|
}
|