src/Scabal/RetailBundle/EventSubscriber/TokenSubscriber.php line 13

Open in your IDE?
  1. <?php
  2. namespace Scabal\RetailBundle\EventSubscriber;
  3. use Symfony\Component\HttpKernel\KernelEvents;
  4. use Scabal\RetailBundle\Controller\TokenAuthController;
  5. use Symfony\Component\HttpKernel\Event\FilterControllerEvent;
  6. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  7. use Symfony\Component\HttpFoundation\JsonResponse;
  8. use Scabal\RetailBundle\Helpers\JWTHandler;
  9. class TokenSubscriber implements EventSubscriberInterface
  10. {
  11.     public function onKernelController(FilterControllerEvent $event)
  12.     {
  13.         $controller $event->getController();
  14.         if (is_array($controller)) {
  15.             $controller $controller[0];
  16.         }
  17.         if ($controller instanceof TokenAuthController) {
  18.             $token $this->retrieveUser($event);
  19.             if (!$token) {
  20.                 $event->setController(function() {
  21.                     return new JsonResponse(["error" => "Not authenticated"], 403);
  22.                 });
  23.                 return;
  24.             }
  25.             $event->getRequest()->attributes->set('vendor'$token["vendor"]);
  26.             $event->getRequest()->attributes->set('idCustomer'$token["idCustomer"]);
  27.             $event->getRequest()->attributes->set('priceList'$token["priceList"]);
  28.             $event->getRequest()->attributes->set('organisation'$token["organisation"]);
  29.             $event->getRequest()->attributes->set('branding'$token["branding"]);
  30.             $event->getRequest()->attributes->set('priceVisibility'$token["priceVisibility"]);
  31.             $event->getRequest()->attributes->set('profilePermissions'$token["profilePermissions"]);
  32.         }
  33.     }
  34.     private function retrieveUser($event) {
  35.         $request $event->getRequest();
  36.         $authorization $request->headers->get('Authorization'null);
  37.         if (!$authorization) {
  38.             return null;
  39.         }
  40.         $token explode(' '$authorization)[1];
  41.         $jwtHandler = new JWTHandler();
  42.         $user $jwtHandler->decodeAccessToken($token);
  43.         return $user;
  44.     }
  45.     public static function getSubscribedEvents()
  46.     {
  47.         return [
  48.             KernelEvents::CONTROLLER => 'onKernelController',
  49.         ];
  50.     }
  51. }