This commit is contained in:
2023-10-17 20:13:29 +08:00
parent 72638acc7c
commit 689c883830
4 changed files with 62 additions and 38 deletions
+24 -24
View File
@@ -7,39 +7,39 @@ use Kiri\Router\Handler;
use Psr\Http\Message\ResponseInterface;
use Psr\Http\Message\ServerRequestInterface;
use Psr\Http\Server\MiddlewareInterface;
use ReflectionException;
abstract class AbstractHandler
{
public int $offset = 0;
public int $offset = 0;
/**
* @param array $middlewares
* @param Handler $handler
*/
public function __construct(public array $middlewares, public Handler $handler)
{
}
/**
* @param array $middlewares
* @param Handler $handler
*/
public function __construct(public array $middlewares, public Handler $handler)
{
}
/**
* @param ServerRequestInterface $request
* @return ResponseInterface
* @throws ReflectionException
*/
public function execute(ServerRequestInterface $request): ResponseInterface
{
if (!isset($this->middlewares[$this->offset])) {
return $this->handler->handle($request);
}
/**
* @param ServerRequestInterface $request
* @return ResponseInterface
* @throws \ReflectionException
*/
public function execute(ServerRequestInterface $request): ResponseInterface
{
if (!isset($this->middlewares[$this->offset])) {
return $this->handler->handle($request);
}
/** @var MiddlewareInterface $middleware */
$middleware = di($this->middlewares[$this->offset]);
$this->offset += 1;
/** @var MiddlewareInterface $middleware */
$middleware = di($this->middlewares[$this->offset]);
$this->offset += 1;
return $middleware->process($request, $this);
}
return $middleware->process($request, $this);
}
}
+21 -10
View File
@@ -13,16 +13,27 @@ class HttpRequestHandler extends AbstractHandler implements RequestHandlerInterf
{
/**
* @param ServerRequestInterface $request
* @return ResponseInterface
* @throws ReflectionException
*/
public function handle(ServerRequestInterface $request): ResponseInterface
{
// TODO: Implement handle() method.
return $this->execute($request);
}
/**
* @param ServerRequestInterface $request
* @return ResponseInterface
* @throws ReflectionException
*/
public function run(ServerRequestInterface $request): ResponseInterface
{
$this->offset = 0;
return $this->handle($request);
}
/**
* @param ServerRequestInterface $request
* @return ResponseInterface
* @throws ReflectionException
*/
public function handle(ServerRequestInterface $request): ResponseInterface
{
// TODO: Implement handle() method.
return $this->execute($request);
}
}
+3 -1
View File
@@ -191,9 +191,11 @@ class Router
{
$router = Kiri::getDi()->get(DataGrip::class)->get(static::$type);
$middleware = \Kiri::getDi()->get(MiddlewareManager::class);
foreach ($router->getMethods() as $method) {
foreach ($router->getMethods() as $name => $method) {
$middlewares = $middleware->get($method->getClass(), $method->getMethod());
$method->setMiddlewares($middlewares);
$router->setMethod($name, $method);
}
}
+14 -3
View File
@@ -66,6 +66,17 @@ class RouterCollector implements \ArrayAccess, \IteratorAggregate
}
/**
* @param string $method
* @param HttpRequestHandler $handler
* @return void
*/
public function setMethod(string $method, HttpRequestHandler $handler): void
{
$this->methods[$method] = $handler;
}
/**
* @return array
*/
@@ -213,11 +224,11 @@ class RouterCollector implements \ArrayAccess, \IteratorAggregate
/**
* @param string $path
* @param string $method
* @return Handler
* @return HttpRequestHandler
*/
public function query(string $path, string $method): Handler
public function query(string $path, string $method): HttpRequestHandler
{
return $this->methods[$method . '_' . $path] ?? $this->found;
return $this->methods[$method . '_' . $path] ?? new HttpRequestHandler([], $this->found);
}