src/EventSubscriber/MaintenanceElement/MaintenanceElementPreWriteSubscriber.php line 49

Open in your IDE?
  1. <?php
  2. /**
  3.  * Created by PhpStorm.
  4.  * User: SUSAN MEDINA
  5.  * Date: 15/04/2019
  6.  * Time: 09:39 PM
  7.  */
  8. namespace App\EventSubscriber\MaintenanceElement;
  9. use Symfony\Contracts\Translation\TranslatorInterface;
  10. use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorageInterface;
  11. use Symfony\Component\Security\Core\Authorization\AuthorizationCheckerInterface;
  12. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  13. use Symfony\Component\HttpKernel\Event\ViewEvent;
  14. use Symfony\Component\HttpFoundation\Request;
  15. use Symfony\Component\HttpKernel\KernelEvents;
  16. use ApiPlatform\Core\EventListener\EventPriorities;
  17. use App\Exception\AccessDeniedException;
  18. use App\Exception\NotFoundException;
  19. use App\Services\VendorService;
  20. use App\Services\UtilsService;
  21. use App\Entity\App\MaintenanceElement;
  22. use App\Entity\App\User;
  23. use App\Entity\App\Role;
  24. class MaintenanceElementPreWriteSubscriber implements EventSubscriberInterface
  25. {
  26.     private $tokenStorage;
  27.     private $authorizationChecker;
  28.     private $utilsService;
  29.     private $vendorService;
  30.     private $translator;
  31.     public function __construct(
  32.         TokenStorageInterface $tokenStorage,
  33.         AuthorizationCheckerInterface $checker,
  34.         UtilsService $utilsService,
  35.         VendorService $vendorService,
  36.         TranslatorInterface $translator
  37.     ){
  38.         $this->tokenStorage $tokenStorage;
  39.         $this->authorizationChecker $checker;
  40.         $this->utilsService $utilsService;
  41.         $this->vendorService $vendorService;
  42.         $this->translator $translator;
  43.     }
  44.     public function onKernelView(ViewEvent $event)
  45.     {
  46.         if ($this->utilsService->isAPublicRequest($event)) {
  47.             return;
  48.         }
  49.         $maintenanceElement $event->getControllerResult();
  50.         $request $event->getRequest();
  51.         $method $request->getMethod();
  52.         $userCurrent $this->tokenStorage->getToken()->getUser();
  53.         if (!($maintenanceElement instanceof MaintenanceElement) ||
  54.             (Request::METHOD_POST !== $method && Request::METHOD_PUT !== $method && Request::METHOD_DELETE !== $method)
  55.         )
  56.             return;
  57.         if ($this->authorizationChecker->isGranted('ROLE_SUPERADMIN'))
  58.             return;
  59.         if(!($userCurrent instanceof User))
  60.             throw new NotFoundException($this->translator->trans('User current not found'));
  61.         $vendor $maintenanceElement->getVendor();
  62.         $vendorStaff $this->vendorService->getVendorStaff(null$userCurrent$vendor);
  63.         if ($vendorStaff === null) {
  64.             throw new AccessDeniedException(
  65.                 $this->translator->trans('Access denied. it does not belong to the vendor'),
  66.                 ['%vendor%' => $vendor->getName()]
  67.             );
  68.         }
  69.         $controlAccess = [Role::ROLE_ADMIN];
  70.         if (!$this->vendorService->isUserRoleInToVendor($vendor$userCurrent$controlAccess)) {
  71.             $controlAccessTranslator = [];
  72.             foreach ($controlAccess as $roleName) {
  73.                 $controlAccessTranslator[] = $this->translator->trans($roleName);
  74.             }
  75.             throw new AccessDeniedException(
  76.                 $this->translator->trans('access_allowed_only_for') . (implode(', '$controlAccessTranslator))
  77.             );
  78.         }
  79.         return;
  80.     }
  81.     public static function getSubscribedEvents()
  82.     {
  83.         return [
  84.             KernelEvents::VIEW => ['onKernelView'EventPriorities::PRE_WRITE]
  85.         ];
  86.     }
  87. }