vendor/pimcore/pimcore/bundles/AdminBundle/EventListener/UserPerspectiveListener.php line 60

Open in your IDE?
  1. <?php
  2. /**
  3.  * Pimcore
  4.  *
  5.  * This source file is available under two different licenses:
  6.  * - GNU General Public License version 3 (GPLv3)
  7.  * - Pimcore Commercial License (PCL)
  8.  * Full copyright and license information is available in
  9.  * LICENSE.md which is distributed with this source code.
  10.  *
  11.  *  @copyright  Copyright (c) Pimcore GmbH (http://www.pimcore.org)
  12.  *  @license    http://www.pimcore.org/license     GPLv3 and PCL
  13.  */
  14. namespace Pimcore\Bundle\AdminBundle\EventListener;
  15. use Pimcore\Bundle\AdminBundle\Security\User\TokenStorageUserResolver;
  16. use Pimcore\Bundle\CoreBundle\EventListener\Traits\PimcoreContextAwareTrait;
  17. use Pimcore\Http\Request\Resolver\PimcoreContextResolver;
  18. use Pimcore\Model\User;
  19. use Psr\Log\LoggerAwareInterface;
  20. use Psr\Log\LoggerAwareTrait;
  21. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  22. use Symfony\Component\HttpFoundation\Request;
  23. use Symfony\Component\HttpKernel\Event\RequestEvent;
  24. use Symfony\Component\HttpKernel\KernelEvents;
  25. /**
  26.  * @internal
  27.  */
  28. class UserPerspectiveListener implements EventSubscriberInterfaceLoggerAwareInterface
  29. {
  30.     use LoggerAwareTrait;
  31.     use PimcoreContextAwareTrait;
  32.     /**
  33.      * @var TokenStorageUserResolver
  34.      */
  35.     protected $userResolver;
  36.     /**
  37.      * @param TokenStorageUserResolver $userResolver
  38.      */
  39.     public function __construct(TokenStorageUserResolver $userResolver)
  40.     {
  41.         $this->userResolver $userResolver;
  42.     }
  43.     /**
  44.      * {@inheritdoc}
  45.      */
  46.     public static function getSubscribedEvents()
  47.     {
  48.         return [
  49.             KernelEvents::REQUEST => 'onKernelRequest',
  50.         ];
  51.     }
  52.     public function onKernelRequest(RequestEvent $event)
  53.     {
  54.         $request $event->getRequest();
  55.         if (!$event->isMainRequest()) {
  56.             return;
  57.         }
  58.         if (!$this->matchesPimcoreContext($requestPimcoreContextResolver::CONTEXT_ADMIN)) {
  59.             return;
  60.         }
  61.         if ($user $this->userResolver->getUser()) {
  62.             $this->setRequestedPerspective($user$request);
  63.         }
  64.     }
  65.     /**
  66.      * @param User $user
  67.      * @param Request $request
  68.      */
  69.     protected function setRequestedPerspective(User $userRequest $request)
  70.     {
  71.         // update perspective settings
  72.         $requestedPerspective $request->get('perspective');
  73.         if ($requestedPerspective) {
  74.             if ($requestedPerspective !== $user->getActivePerspective()) {
  75.                 $existingPerspectives array_keys(\Pimcore\Perspective\Config::get()->toArray());
  76.                 if (!in_array($requestedPerspective$existingPerspectives)) {
  77.                     $this->logger->warning('Requested perspective {perspective} for {user} does not exist.', [
  78.                         'user' => $user->getName(),
  79.                         'perspective' => $requestedPerspective,
  80.                     ]);
  81.                     $requestedPerspective null;
  82.                 }
  83.             }
  84.         }
  85.         if (!$requestedPerspective || !$user->isAllowed($requestedPerspective'perspective')) {
  86.             $previouslyRequested $requestedPerspective;
  87.             // choose active perspective or a first allowed
  88.             $requestedPerspective $user->isAllowed($user->getActivePerspective(), 'perspective')
  89.                 ? $user->getActivePerspective()
  90.                 : $user->getFirstAllowedPerspective();
  91.             if ($previouslyRequested) {
  92.                 $this->logger->warning('User {user} is not allowed requested perspective {requestedPerspective}. Falling back to {perspective}.', [
  93.                     'user' => $user->getName(),
  94.                     'requestedPerspective' => $previouslyRequested,
  95.                     'perspective' => $requestedPerspective,
  96.                 ]);
  97.             } else {
  98.                 $this->logger->debug('Perspective for user {user} was not requested. Falling back to {perspective}.', [
  99.                     'user' => $user->getName(),
  100.                     'perspective' => $requestedPerspective,
  101.                 ]);
  102.             }
  103.         }
  104.         if ($requestedPerspective !== $user->getActivePerspective()) {
  105.             $this->logger->info('Setting active perspective for user {user} to {perspective}.', [
  106.                 'user' => $user->getName(),
  107.                 'perspective' => $requestedPerspective,
  108.             ]);
  109.             $user->setActivePerspective($requestedPerspective);
  110.             $user->save();
  111.         }
  112.     }
  113. }