src/EventSubscriber/ApiRequestSubscriber.php line 13

  1. <?php
  2. // src/EventSubscriber/ApiRequestSubscriber.php
  3. namespace App\EventSubscriber;
  4. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  5. use Symfony\Component\HttpFoundation\Response;
  6. use Symfony\Component\HttpKernel\Event\RequestEvent;
  7. class ApiRequestSubscriber implements EventSubscriberInterface
  8. {
  9.     public function onKernelRequest(RequestEvent $event): void
  10.     {
  11.         $request $event->getRequest();
  12.         $route $request->attributes->get('_route');
  13.         // Čitanje vrijednosti iz env datoteke
  14.         $allowedDomainsEnv $_ENV["ALLOWED_DOMAINS"];
  15.         // Pretvaranje stringa u niz koristeći zarez kao separator
  16.         $allowedDomains explode(','$allowedDomainsEnv);
  17.         // Ukloniti prazne elemente i trimovati svaki element u nizu
  18.         $allowedDomains array_map('trim'array_filter($allowedDomains));
  19.         // Ako nema vrijednosti u env varijabli, postaviti na prazan niz
  20.         if (empty($allowedDomains)) {
  21.             $allowedDomains = [];
  22.         }
  23.         if ($route === 'api_pin_orders') {
  24.             $origin $request->headers->get('Origin');
  25.             if (!$origin) {
  26.                 $event->setResponse(new Response('Forbidden'Response::HTTP_FORBIDDEN));
  27.                 return;
  28.             }
  29.             // Dobijanje domene iz Origin zaglavlja
  30.             $originHost parse_url($originPHP_URL_HOST);
  31.             // Ovdje možete nastaviti s provjerom domena, npr. u odnosu na dozvoljene domene
  32.             if (!in_array($originHost$allowedDomains)) {
  33.                 $event->setResponse(new Response('Forbidden'Response::HTTP_FORBIDDEN));
  34.             }
  35.         }
  36.     }
  37.     public static function getSubscribedEvents()
  38.     {
  39.         return [
  40.             'kernel.request' => 'onKernelRequest',
  41.         ];
  42.     }
  43. }