vendor/shopware/core/Framework/Api/EventListener/CorsListener.php line 25

Open in your IDE?
  1. <?php declare(strict_types=1);
  2. namespace Shopware\Core\Framework\Api\EventListener;
  3. use Shopware\Core\PlatformRequest;
  4. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  5. use Symfony\Component\HttpFoundation\Response;
  6. use Symfony\Component\HttpKernel\Event\RequestEvent;
  7. use Symfony\Component\HttpKernel\Event\ResponseEvent;
  8. use Symfony\Component\HttpKernel\KernelEvents;
  9. /**
  10.  * @deprecated tag:v6.5.0 - reason:becomes-internal - EventSubscribers will become internal in v6.5.0
  11.  */
  12. class CorsListener implements EventSubscriberInterface
  13. {
  14.     public static function getSubscribedEvents(): array
  15.     {
  16.         return [
  17.             KernelEvents::REQUEST => ['onKernelRequest'9999],
  18.             KernelEvents::RESPONSE => ['onKernelResponse'9999],
  19.         ];
  20.     }
  21.     public function onKernelRequest(RequestEvent $event): void
  22.     {
  23.         if (!$event->isMainRequest()) {
  24.             return;
  25.         }
  26.         $method $event->getRequest()->getRealMethod();
  27.         if ($method === 'OPTIONS') {
  28.             $response = new Response();
  29.             $event->setResponse($response);
  30.         }
  31.     }
  32.     public function onKernelResponse(ResponseEvent $event): void
  33.     {
  34.         if (!$event->isMainRequest()) {
  35.             return;
  36.         }
  37.         $corsHeaders = [
  38.             'Content-Type',
  39.             'Authorization',
  40.             PlatformRequest::HEADER_CONTEXT_TOKEN,
  41.             PlatformRequest::HEADER_ACCESS_KEY,
  42.             PlatformRequest::HEADER_LANGUAGE_ID,
  43.             PlatformRequest::HEADER_VERSION_ID,
  44.             PlatformRequest::HEADER_INHERITANCE,
  45.             PlatformRequest::HEADER_FAIL_ON_ERROR,
  46.             PlatformRequest::HEADER_INDEXING_BEHAVIOR,
  47.             PlatformRequest::HEADER_SINGLE_OPERATION,
  48.             PlatformRequest::HEADER_INCLUDE_SEO_URLS,
  49.         ];
  50.         $response $event->getResponse();
  51.         $response->headers->set('Access-Control-Allow-Origin''*');
  52.         $response->headers->set('Access-Control-Allow-Methods''GET,POST,PUT,PATCH,DELETE');
  53.         $response->headers->set('Access-Control-Allow-Headers'implode(','$corsHeaders));
  54.         $response->headers->set('Access-Control-Expose-Headers'implode(','$corsHeaders));
  55.     }
  56. }