. */ declare(strict_types=1); namespace App\EventSubscriber\UserSystem; use App\Entity\LogSystem\UserLoginLogEntry; use App\Entity\UserSystem\User; use App\Services\LogSystem\EventLogger; use Symfony\Component\EventDispatcher\EventSubscriberInterface; use Symfony\Component\HttpFoundation\RequestStack; use Symfony\Component\HttpFoundation\Session\Flash\FlashBagInterface; use Symfony\Component\HttpFoundation\Session\Session; use Symfony\Component\HttpFoundation\Session\SessionInterface; use Symfony\Component\Security\Http\Event\InteractiveLoginEvent; use Symfony\Component\Security\Http\SecurityEvents; use Symfony\Contracts\Translation\TranslatorInterface; /** * This event listener shows an login successful flash to the user after login and write the login to event log. */ final class LoginSuccessSubscriber implements EventSubscriberInterface { private TranslatorInterface $translator; private RequestStack $requestStack; private EventLogger $eventLogger; private bool $gpdr_compliance; public function __construct(TranslatorInterface $translator, RequestStack $requestStack, EventLogger $eventLogger, bool $gpdr_compliance) { /** @var Session $session */ $this->translator = $translator; $this->requestStack = $requestStack; $this->eventLogger = $eventLogger; $this->gpdr_compliance = $gpdr_compliance; } public function onLogin(InteractiveLoginEvent $event): void { $ip = $event->getRequest()->getClientIp(); $log = new UserLoginLogEntry($ip, $this->gpdr_compliance); $user = $event->getAuthenticationToken()->getUser(); if ($user instanceof User && $user->getID()) { $log->setTargetElement($user); $this->eventLogger->logAndFlush($log); } /** @var Session $session */ $session = $this->requestStack->getSession(); $flashBag = $session->getFlashBag(); $flashBag->add('notice', $this->translator->trans('flash.login_successful')); } /** * Returns an array of event names this subscriber wants to listen to. * * The array keys are event names and the value can be: * * * The method name to call (priority defaults to 0) * * An array composed of the method name to call and the priority * * An array of arrays composed of the method names to call and respective * priorities, or 0 if unset * * For instance: * * * ['eventName' => 'methodName'] * * ['eventName' => ['methodName', $priority]] * * ['eventName' => [['methodName1', $priority], ['methodName2']]] * * @return array The event names to listen to */ public static function getSubscribedEvents(): array { return [SecurityEvents::INTERACTIVE_LOGIN => 'onLogin']; } }