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

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. class CorsListener implements EventSubscriberInterface
  10. {
  11.     public static function getSubscribedEvents(): array
  12.     {
  13.         return [
  14.             KernelEvents::REQUEST => ['onKernelRequest'9999],
  15.             KernelEvents::RESPONSE => ['onKernelResponse'9999],
  16.         ];
  17.     }
  18.     public function onKernelRequest(RequestEvent $event): void
  19.     {
  20.         if (!$event->isMainRequest()) {
  21.             return;
  22.         }
  23.         $method $event->getRequest()->getRealMethod();
  24.         if ($method === 'OPTIONS') {
  25.             $response = new Response();
  26.             $event->setResponse($response);
  27.         }
  28.     }
  29.     public function onKernelResponse(ResponseEvent $event): void
  30.     {
  31.         if (!$event->isMainRequest()) {
  32.             return;
  33.         }
  34.         $corsHeaders = [
  35.             'Content-Type',
  36.             'Authorization',
  37.             PlatformRequest::HEADER_CONTEXT_TOKEN,
  38.             PlatformRequest::HEADER_ACCESS_KEY,
  39.             PlatformRequest::HEADER_LANGUAGE_ID,
  40.             PlatformRequest::HEADER_VERSION_ID,
  41.             PlatformRequest::HEADER_INHERITANCE,
  42.             PlatformRequest::HEADER_FAIL_ON_ERROR,
  43.             PlatformRequest::HEADER_INDEXING_BEHAVIOR,
  44.             PlatformRequest::HEADER_SINGLE_OPERATION,
  45.             PlatformRequest::HEADER_INCLUDE_SEO_URLS,
  46.         ];
  47.         $response $event->getResponse();
  48.         $response->headers->set('Access-Control-Allow-Origin''*');
  49.         $response->headers->set('Access-Control-Allow-Methods''GET,POST,PUT,PATCH,DELETE');
  50.         $response->headers->set('Access-Control-Allow-Headers'implode(','$corsHeaders));
  51.         $response->headers->set('Access-Control-Expose-Headers'implode(','$corsHeaders));
  52.     }
  53. }