This commit is contained in:
2023-08-02 14:00:25 +08:00
parent 9dace3e357
commit 4af7d69556
4 changed files with 36 additions and 12 deletions
+7 -1
View File
@@ -6,6 +6,7 @@ namespace Kiri\Router\Annotate;
use Exception;
use Kiri\Router\Constrict\RequestMethod;
use Kiri\Router\Interface\InjectRouteInterface;
use Kiri\Router\OptionsController;
use Kiri\Router\Router;
use ReflectionException;
@@ -17,8 +18,9 @@ class Delete extends AbstractRequestMethod implements InjectRouteInterface
/**
* @param string $path
* @param string $version
* @param bool $enableOption
*/
public function __construct(readonly public string $path, readonly public string $version = 'v1')
public function __construct(readonly public string $path, readonly public string $version = 'v1', readonly public bool $enableOption = true)
{
}
@@ -36,6 +38,10 @@ class Delete extends AbstractRequestMethod implements InjectRouteInterface
$path = '/' . ltrim($this->path, '/');
Router::addRoute(RequestMethod::REQUEST_DELETE, $path, [$class, $method]);
if ($this->enableOption) {
$options = [di(OptionsController::class), 'index'];
Router::addRoute([RequestMethod::REQUEST_OPTIONS], $path, $options);
}
}
+11 -5
View File
@@ -6,6 +6,7 @@ namespace Kiri\Router\Annotate;
use Exception;
use Kiri\Router\Constrict\RequestMethod;
use Kiri\Router\Interface\InjectRouteInterface;
use Kiri\Router\OptionsController;
use Kiri\Router\Router;
use ReflectionException;
@@ -14,11 +15,12 @@ class Get extends AbstractRequestMethod implements InjectRouteInterface
{
/**
* @param string $path
* @param string $version
*/
public function __construct(readonly public string $path, readonly public string $version = 'v1')
/**
* @param string $path
* @param string $version
* @param bool $enableOption
*/
public function __construct(readonly public string $path, readonly public string $version = 'v1', readonly public bool $enableOption = true)
{
}
@@ -36,6 +38,10 @@ class Get extends AbstractRequestMethod implements InjectRouteInterface
$path = '/' . ltrim($this->path, '/');
Router::addRoute(RequestMethod::REQUEST_GET, $path, [$class, $method]);
if ($this->enableOption) {
$options = [di(OptionsController::class), 'index'];
Router::addRoute([RequestMethod::REQUEST_OPTIONS], $path, $options);
}
}
}
+11 -5
View File
@@ -6,6 +6,7 @@ namespace Kiri\Router\Annotate;
use Exception;
use Kiri\Router\Constrict\RequestMethod;
use Kiri\Router\Interface\InjectRouteInterface;
use Kiri\Router\OptionsController;
use Kiri\Router\Router;
use ReflectionException;
@@ -14,11 +15,12 @@ class Post extends AbstractRequestMethod implements InjectRouteInterface
{
/**
* @param string $path
* @param string $version
*/
public function __construct(readonly public string $path, readonly public string $version = 'v1')
/**
* @param string $path
* @param string $version
* @param bool $enableOption
*/
public function __construct(readonly public string $path, readonly public string $version = 'v1', readonly public bool $enableOption = true)
{
}
@@ -36,6 +38,10 @@ class Post extends AbstractRequestMethod implements InjectRouteInterface
$path = '/' . ltrim($this->path, '/');
Router::addRoute(RequestMethod::REQUEST_POST, $path, [$class, $method]);
if ($this->enableOption) {
$options = [di(OptionsController::class), 'index'];
Router::addRoute([RequestMethod::REQUEST_OPTIONS], $path, $options);
}
}
+7 -1
View File
@@ -6,6 +6,7 @@ namespace Kiri\Router\Annotate;
use Exception;
use Kiri\Router\Constrict\RequestMethod;
use Kiri\Router\Interface\InjectRouteInterface;
use Kiri\Router\OptionsController;
use Kiri\Router\Router;
use ReflectionException;
@@ -17,8 +18,9 @@ class Put extends AbstractRequestMethod implements InjectRouteInterface
/**
* @param string $path
* @param string $version
* @param bool $enableOption
*/
public function __construct(readonly public string $path, readonly public string $version = 'v1')
public function __construct(readonly public string $path, readonly public string $version = 'v1', readonly public bool $enableOption = true)
{
}
@@ -36,6 +38,10 @@ class Put extends AbstractRequestMethod implements InjectRouteInterface
$path = '/' . ltrim($this->path, '/');
Router::addRoute(RequestMethod::REQUEST_PUT, $path, [$class, $method]);
if ($this->enableOption) {
$options = [di(OptionsController::class), 'index'];
Router::addRoute([RequestMethod::REQUEST_OPTIONS], $path, $options);
}
}
}