diff --git a/src/ApiDecider.php b/src/ApiDecider.php index 5a901b2..2de9243 100644 --- a/src/ApiDecider.php +++ b/src/ApiDecider.php @@ -17,9 +17,9 @@ class ApiDecider private $handlers = []; /** - * @var bool + * @var ApiHandlerInterface */ - private $globalPreflight = false; + private $globalPreflightHandler = null; /** * Get api handler that match input method, version, package and apiAction. @@ -41,11 +41,11 @@ public function getApiHandler($method, $version, $package, $apiAction = '') $handler['handler']->setEndpointIdentifier($endpointIdentifier); return $handler; } - if ($method == 'OPTIONS' && $this->globalPreflight && $identifier->getVersion() == $version && $identifier->getPackage() == $package && $identifier->getApiAction() == $apiAction) { + if ($method == 'OPTIONS' && $this->globalPreflightHandler && $identifier->getVersion() == $version && $identifier->getPackage() == $package && $identifier->getApiAction() == $apiAction) { return [ 'endpoint' => new EndpointIdentifier('OPTION', $version, $package, $apiAction), 'authorization' => new NoAuthorization(), - 'handler' => new CorsPreflightHandler(new Response()), + 'handler' => $this->globalPreflightHandler, ]; } } @@ -56,9 +56,12 @@ public function getApiHandler($method, $version, $package, $apiAction = '') ]; } - public function enableGlobalPreflight() + public function enableGlobalPreflight(ApiHandlerInterface $corsHandler = null) { - $this->globalPreflight = true; + if (!$corsHandler) { + $corsHandler = new CorsPreflightHandler(new Response()); + } + $this->globalPreflightHandler = $corsHandler; } /**