vendor/gollumsf/url-tokenizer-bundle/src/EventSubscriber/ValidTokenSubscriber.php line 29

  1. <?php
  2. namespace GollumSF\UrlTokenizerBundle\EventSubscriber;
  3. use GollumSF\UrlTokenizerBundle\Annotation\ValidToken;
  4. use GollumSF\UrlTokenizerBundle\Checker\CheckerInterface;
  5. use GollumSF\UrlTokenizerBundle\Exception\ExpiredTokentHttpException;
  6. use GollumSF\UrlTokenizerBundle\Exception\InvalidTokentHttpException;
  7. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  8. use Symfony\Component\HttpKernel\Event\ControllerEvent;
  9. use Symfony\Component\HttpKernel\KernelEvents;
  10. class ValidTokenSubscriber implements EventSubscriberInterface {
  11.     
  12.     /** @var CheckerInterface */
  13.     private $checker;
  14.     
  15.     public function __construct(CheckerInterface $checker) {
  16.         $this->checker $checker;
  17.     }
  18.     public static function getSubscribedEvents() {
  19.         return [
  20.             KernelEvents::CONTROLLER => [
  21.                 ['onKernelController', -1],
  22.             ],
  23.         ];
  24.     }
  25.     
  26.     public function onKernelController(ControllerEvent $event) {
  27.         
  28.         $request $event->getRequest();
  29.         
  30.         /** @var ValidToken $validToken */
  31.         $validToken $request->attributes->get('_'.ValidToken::ALIAS_NAME);
  32.         
  33.         if ($validToken) {
  34.             if (!$this->checker->checkTokenMasterRequest($validToken->isFullUrl(), $validToken->getKey())) {
  35.                 throw new InvalidTokentHttpException('Token url invalid');
  36.             }
  37.             $lifeTime $validToken->getLifeTime();
  38.             if ($lifeTime !== null && !$this->checker->checkTokenTimeMasterRequest($lifeTime)) {
  39.                 throw new ExpiredTokentHttpException('Token url expired');
  40.             }
  41.         }
  42.         
  43.     }
  44.     
  45. }