src/Handler/HttpRefererHandler.php line 23

Open in your IDE?
  1. <?php
  2. namespace App\Handler;
  3. use Symfony\Component\HttpFoundation\Request;
  4. use Symfony\Component\HttpFoundation\RequestStack;
  5. use Symfony\Component\HttpFoundation\Session\SessionInterface;
  6. class HttpRefererHandler
  7. {
  8.     public const HTTP_REFERER_SESSION_KEY 'http-referer';
  9.     private RequestStack $requestStack;
  10.     public function __construct(RequestStack $requestStack)
  11.     {
  12.         $this->requestStack $requestStack;
  13.     }
  14.     public function getHttpReferer(): ?string
  15.     {
  16.         return $this->getSession()->get(self::HTTP_REFERER_SESSION_KEY);
  17.     }
  18.     /**
  19.      * TODO: Pour que ce système fonctionne il est nécessaire de repasser sur tout les appels HTTP en JS pour ajouter
  20.      *  l'option 'X-Requested-With': 'XMLHttpRequest' dans le header. Sinon ces appels sont considérés comme "normaux"
  21.      *  et donc pris en compte par le traitement.
  22.      */
  23.     public function setHttpReferer(Request $request): void
  24.     {
  25.         if ($request->isXmlHttpRequest() || preg_match('/_profiler/'$request->getRequestUri())) {
  26.             return;
  27.         }
  28.         $serverBag $request->server;
  29.         $baseUrl $serverBag->get('REQUEST_SCHEME').'://'.$serverBag->get('SERVER_NAME');
  30.         $baseUrlForRegex str_replace('/''\/'$baseUrl);
  31.         $httpReferer $serverBag->get('HTTP_REFERER');
  32.         if (!preg_match('/^'.$baseUrlForRegex.'/'$httpReferer)
  33.             || preg_match('/^'.$baseUrlForRegex.'\/connexion/'$httpReferer)
  34.         ) {
  35.             $httpReferer $baseUrl;
  36.         }
  37.         if ($httpReferer !== $this->getHttpReferer()) {
  38.             $this->getSession()->set(self::HTTP_REFERER_SESSION_KEY$httpReferer);
  39.         }
  40.     }
  41.     private function getSession(): SessionInterface
  42.     {
  43.         return $this->requestStack->getSession();
  44.     }
  45. }