Viewing file: Cors.php (1.78 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
/* * This file is part of asm89/stack-cors. * * (c) Alexander <iam.asm89@gmail.com> * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */
namespace Asm89\Stack;
use Symfony\Component\HttpKernel\HttpKernelInterface; use Symfony\Component\HttpFoundation\Request; use Symfony\Component\HttpFoundation\Response;
class Cors implements HttpKernelInterface { /** * @var \Symfony\Component\HttpKernel\HttpKernelInterface */ private $app;
/** * @var \Asm89\Stack\CorsService */ private $cors;
private $defaultOptions = array( 'allowedHeaders' => array(), 'allowedMethods' => array(), 'allowedOrigins' => array(), 'allowedOriginsPatterns' => array(), 'exposedHeaders' => false, 'maxAge' => false, 'supportsCredentials' => false, );
public function __construct(HttpKernelInterface $app, array $options = array()) { $this->app = $app; $this->cors = new CorsService(array_merge($this->defaultOptions, $options)); }
public function handle(Request $request, $type = HttpKernelInterface::MASTER_REQUEST, $catch = true) { if (!$this->cors->isCorsRequest($request)) { return $this->app->handle($request, $type, $catch); }
if ($this->cors->isPreflightRequest($request)) { return $this->cors->handlePreflightRequest($request); }
if (!$this->cors->isActualRequestAllowed($request)) { return new Response('Not allowed.', 403); }
$response = $this->app->handle($request, $type, $catch);
return $this->cors->addActualRequestHeaders($response, $request); } }
|