vendor/ibexa/admin-ui/src/lib/EventListener/CredentialsExpirationWarningListener.php line 55

Open in your IDE?
  1. <?php
  2. /**
  3.  * @copyright Copyright (C) Ibexa AS. All rights reserved.
  4.  * @license For full copyright and license information view LICENSE file distributed with this source code.
  5.  */
  6. declare(strict_types=1);
  7. namespace Ibexa\AdminUi\EventListener;
  8. use DateTime;
  9. use DateTimeInterface;
  10. use Ibexa\AdminUi\Specification\SiteAccess\IsAdmin;
  11. use Ibexa\Contracts\AdminUi\Notification\NotificationHandlerInterface;
  12. use Ibexa\Contracts\Core\Repository\UserService;
  13. use Ibexa\Core\MVC\Symfony\Security\UserInterface;
  14. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  15. use Symfony\Component\HttpFoundation\Request;
  16. use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
  17. use Symfony\Component\Security\Http\Event\InteractiveLoginEvent;
  18. use Symfony\Component\Security\Http\SecurityEvents;
  19. use Symfony\Contracts\Translation\TranslatorInterface;
  20. final class CredentialsExpirationWarningListener implements EventSubscriberInterface
  21. {
  22.     /** @var \Ibexa\Contracts\AdminUi\Notification\NotificationHandlerInterface */
  23.     private $notificationHandler;
  24.     /** @var \Symfony\Contracts\Translation\TranslatorInterface */
  25.     private $translator;
  26.     /** @var \Symfony\Component\Routing\Generator\UrlGeneratorInterface */
  27.     private $urlGenerator;
  28.     /** @var \Ibexa\Contracts\Core\Repository\UserService */
  29.     private $userService;
  30.     /** @var string[][] */
  31.     private $siteAccessGroups;
  32.     public function __construct(
  33.         NotificationHandlerInterface $notificationHandler,
  34.         TranslatorInterface $translator,
  35.         UrlGeneratorInterface $urlGenerator,
  36.         UserService $userService,
  37.         array $siteAccessGroups
  38.     ) {
  39.         $this->notificationHandler $notificationHandler;
  40.         $this->translator $translator;
  41.         $this->urlGenerator $urlGenerator;
  42.         $this->siteAccessGroups $siteAccessGroups;
  43.         $this->userService $userService;
  44.     }
  45.     public function onAuthenticationSuccess(InteractiveLoginEvent $event): void
  46.     {
  47.         if (!$this->isAdminSiteAccess($event->getRequest())) {
  48.             return;
  49.         }
  50.         $user $event->getAuthenticationToken()->getUser();
  51.         if (!($user instanceof UserInterface)) {
  52.             return;
  53.         }
  54.         $apiUser $user->getAPIUser();
  55.         $passwordInfo $this->userService->getPasswordInfo($apiUser);
  56.         if ($passwordInfo->hasExpirationWarningDate()) {
  57.             $expirationWarningDate $passwordInfo->getExpirationWarningDate();
  58.             if ($expirationWarningDate <= new DateTime()) {
  59.                 $this->generateNotification($passwordInfo->getExpirationDate());
  60.             }
  61.         }
  62.     }
  63.     public static function getSubscribedEvents(): array
  64.     {
  65.         return [
  66.             SecurityEvents::INTERACTIVE_LOGIN => ['onAuthenticationSuccess'12],
  67.         ];
  68.     }
  69.     private function generateNotification(DateTimeInterface $passwordExpiresAt): void
  70.     {
  71.         $passwordExpiresIn = (new DateTime())->diff($passwordExpiresAt);
  72.         if ($passwordExpiresIn->0) {
  73.             $warning $this->translator->trans(
  74.                 /** @Desc("Your current password will expire in %days% day(s). You can change it in User settings/My account settings.") */
  75.                 'authentication.credentials_expire_in.warning',
  76.                 [
  77.                     '%days%' => $passwordExpiresIn->+ ($passwordExpiresIn->>= 12 0),
  78.                     '%url%' => $this->urlGenerator->generate('ibexa.user_profile.change_password'),
  79.                 ],
  80.                 'messages'
  81.             );
  82.         } else {
  83.             $warning $this->translator->trans(
  84.                 /** @Desc("Your current password will expire today. You can change it in User settings/My account settings.") */
  85.                 'authentication.credentials_expire_today.warning',
  86.                 [
  87.                     '%url%' => $this->urlGenerator->generate('ibexa.user_profile.change_password'),
  88.                 ],
  89.                 'messages'
  90.             );
  91.         }
  92.         $this->notificationHandler->warning($warning);
  93.     }
  94.     private function isAdminSiteAccess(Request $request): bool
  95.     {
  96.         return (new IsAdmin($this->siteAccessGroups))->isSatisfiedBy($request->attributes->get('siteaccess'));
  97.     }
  98. }
  99. class_alias(CredentialsExpirationWarningListener::class, 'EzSystems\EzPlatformAdminUi\EventListener\CredentialsExpirationWarningListener');