|
5 | 5 | use Psr\Http\Message\ResponseInterface; |
6 | 6 | use Psr\Http\Message\ServerRequestInterface; |
7 | 7 | use Psr\Http\Server\MiddlewareInterface as PSR15MiddlewareInterface; |
8 | | -use React\EventLoop\LoopInterface; |
9 | 8 | use React\Promise; |
10 | | -use Recoil\React\ReactKernel; |
11 | | -use Throwable; |
| 9 | +use function React\Async\async; |
12 | 10 |
|
13 | 11 | final class GroupedPSR15Middleware |
14 | 12 | { |
15 | 13 | /** |
16 | | - * @var ReactKernel |
| 14 | + * @var array<PSR15MiddlewareInterface> |
17 | 15 | */ |
18 | | - private $kernel; |
| 16 | + private array $middleware = []; |
19 | 17 |
|
20 | | - /** |
21 | | - * @var PSR15MiddlewareInterface[] |
22 | | - */ |
23 | | - private $middleware = []; |
24 | | - |
25 | | - public function __construct(LoopInterface $loop) |
| 18 | + public function withMiddleware(PSR15MiddlewareInterface $middleware): self |
26 | 19 | { |
27 | | - $this->kernel = ReactKernel::create($loop); |
28 | | - } |
29 | | - |
30 | | - public function withMiddleware(string $middleware, array $arguments = [], callable $func = null) |
31 | | - { |
32 | | - if ($func === null) { |
33 | | - $func = function ($middleware) { |
34 | | - return $middleware; |
35 | | - }; |
36 | | - } |
37 | | - |
38 | 20 | $clone = clone $this; |
39 | | - $clone->middleware[] = $func(YieldingMiddlewareFactory::construct($middleware, $arguments)); |
40 | | - |
| 21 | + $clone->middleware[] = $middleware; |
41 | 22 | return $clone; |
42 | 23 | } |
43 | 24 |
|
44 | 25 | public function __invoke(ServerRequestInterface $request, callable $next): Promise\PromiseInterface |
45 | 26 | { |
| 27 | + return async(function (ServerRequestInterface $request, callable $next): ResponseInterface { |
| 28 | + $middleware = array_reverse($this->middleware); |
| 29 | + $requestHandler = new AwaitRequestHandler($next); |
46 | 30 |
|
47 | | - $stack = $this->createStack($next); |
48 | | - |
49 | | - return new Promise\Promise(function ($resolve, $reject) use ($request, $next, $stack) { |
50 | | - $this->kernel->execute(function () use ($resolve, $reject, $request, $next, $stack) { |
51 | | - try { |
52 | | - $response = $stack($request, $next); |
53 | | - if ($response instanceof ResponseInterface) { |
54 | | - $response = Promise\resolve($response); |
55 | | - } |
56 | | - $response = (yield $response); |
57 | | - $resolve($response); |
58 | | - } catch (Throwable $throwable) { |
59 | | - $reject($throwable); |
60 | | - } |
61 | | - }); |
62 | | - }); |
63 | | - } |
64 | | - |
65 | | - private function createStack($next) |
66 | | - { |
67 | | - $stack = function (ServerRequestInterface $request) use ($next) { |
68 | | - $response = $next($request); |
69 | | - if ($response instanceof ResponseInterface) { |
70 | | - $response = Promise\resolve($response); |
| 31 | + foreach ($middleware as $mw) { |
| 32 | + $requestHandler = new PassThroughRequestHandler(static fn (ServerRequestInterface $request): ResponseInterface => $mw->process($request, $requestHandler)); |
71 | 33 | } |
72 | | - return (yield $response); |
73 | | - }; |
74 | | - |
75 | | - $middleware = $this->middleware; |
76 | | - $middleware = array_reverse($middleware); |
77 | | - foreach ($middleware as $mw) { |
78 | | - $mwh = $mw; |
79 | | - $stack = function (ServerRequestInterface $request) use ($stack, $mwh) { |
80 | | - $response = $mwh->process($request, new PassThroughRequestHandler($stack)); |
81 | | - if ($response instanceof ResponseInterface) { |
82 | | - $response = Promise\resolve($response); |
83 | | - } |
84 | | - return (yield $response); |
85 | | - }; |
86 | | - } |
87 | 34 |
|
88 | | - return $stack; |
| 35 | + return $requestHandler->handle($request); |
| 36 | + })($request, $next); |
89 | 37 | } |
90 | 38 | } |
0 commit comments