-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathRunner.php
95 lines (84 loc) · 2.99 KB
/
Runner.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
<?php
declare(strict_types=1);
/**
* CakePHP(tm) : Rapid Development Framework (https://cakephp.org)
* Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
*
* Licensed under The MIT License
* For full copyright and license information, please see the LICENSE.txt
* Redistributions of files must retain the above copyright notice.
*
* @copyright Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
* @link https://cakephp.org CakePHP(tm) Project
* @since 3.3.0
* @license https://opensource.org/licenses/mit-license.php MIT License
*/
namespace Cake\Http;
use Cake\Routing\Router;
use Cake\Routing\RoutingApplicationInterface;
use Psr\Http\Message\ResponseInterface;
use Psr\Http\Message\ServerRequestInterface;
use Psr\Http\Server\RequestHandlerInterface;
/**
* Executes the middleware queue and provides the `next` callable
* that allows the queue to be iterated.
*/
class Runner implements RequestHandlerInterface
{
/**
* The middleware queue being run.
*
* @var \Cake\Http\MiddlewareQueue
*/
protected $queue;
/**
* Fallback handler to use if middleware queue does not generate response.
*
* @var \Psr\Http\Server\RequestHandlerInterface|null
*/
protected $fallbackHandler;
/**
* @param \Cake\Http\MiddlewareQueue $queue The middleware queue
* @param \Psr\Http\Message\ServerRequestInterface $request The Server Request
* @param \Psr\Http\Server\RequestHandlerInterface|null $fallbackHandler Fallback request handler.
* @return \Psr\Http\Message\ResponseInterface A response object
*/
public function run(
MiddlewareQueue $queue,
ServerRequestInterface $request,
?RequestHandlerInterface $fallbackHandler = null
): ResponseInterface {
$this->queue = $queue;
$this->queue->rewind();
$this->fallbackHandler = $fallbackHandler;
if (
$fallbackHandler instanceof RoutingApplicationInterface &&
$request instanceof ServerRequest
) {
Router::setRequest($request);
}
return $this->handle($request);
}
/**
* Handle incoming server request and return a response.
*
* @param \Psr\Http\Message\ServerRequestInterface $request The server request
* @return \Psr\Http\Message\ResponseInterface An updated response
*/
public function handle(ServerRequestInterface $request): ResponseInterface
{
if ($this->queue->valid()) {
$middleware = $this->queue->current();
$this->queue->next();
return $middleware->process($request, $this);
}
if ($this->fallbackHandler) {
return $this->fallbackHandler->handle($request);
}
return new Response([
'body' => 'Middleware queue was exhausted without returning a response '
. 'and no fallback request handler was set for Runner',
'status' => 500,
]);
}
}