1 | <?php |
||
2 | |||
3 | /** |
||
4 | * It's free open-source software released under the MIT License. |
||
5 | * |
||
6 | * @author Anatoly Nekhay <[email protected]> |
||
7 | * @copyright Copyright (c) 2018, Anatoly Nekhay |
||
8 | * @license https://github.com/sunrise-php/http-router/blob/master/LICENSE |
||
9 | * @link https://github.com/sunrise-php/http-router |
||
10 | */ |
||
11 | |||
12 | declare(strict_types=1); |
||
13 | |||
14 | namespace Sunrise\Http\Router; |
||
15 | |||
16 | use Psr\Container\ContainerInterface; |
||
17 | use Psr\Http\Server\MiddlewareInterface; |
||
18 | use Psr\Http\Server\RequestHandlerInterface; |
||
19 | |||
20 | use function get_debug_type; |
||
21 | use function is_array; |
||
22 | use function is_callable; |
||
23 | use function is_string; |
||
24 | |||
25 | /** |
||
26 | * @since 2.10.0 |
||
27 | */ |
||
28 | final class ReferenceResolver implements ReferenceResolverInterface |
||
29 | { |
||
30 | 6 | public function __construct( |
|
31 | private readonly MiddlewareResolverInterface $middlewareResolver, |
||
32 | private readonly RequestHandlerResolverInterface $requestHandlerResolver, |
||
33 | ) { |
||
34 | 6 | } |
|
35 | |||
36 | /** |
||
37 | * @param array<array-key, ParameterResolverInterface> $parameterResolvers |
||
0 ignored issues
–
show
Documentation
Bug
introduced
by
![]() |
|||
38 | * @param array<array-key, ResponseResolverInterface> $responseResolvers |
||
39 | */ |
||
40 | 4 | public static function build( |
|
41 | array $parameterResolvers = [], |
||
42 | array $responseResolvers = [], |
||
43 | ?ContainerInterface $container = null, |
||
44 | ): ReferenceResolverInterface { |
||
45 | 4 | $parameterResolver = new ParameterResolverChain($parameterResolvers); |
|
46 | 4 | $responseResolver = new ResponseResolverChain($responseResolvers); |
|
47 | 4 | $classResolver = new ClassResolver($parameterResolver, $container); |
|
48 | 4 | $middlewareResolver = new MiddlewareResolver($classResolver, $parameterResolver, $responseResolver); |
|
49 | 4 | $requestHandlerResolver = new RequestHandlerResolver($classResolver, $parameterResolver, $responseResolver); |
|
50 | |||
51 | 4 | return new self($middlewareResolver, $requestHandlerResolver); |
|
52 | } |
||
53 | |||
54 | /** |
||
55 | * @inheritDoc |
||
56 | */ |
||
57 | 2 | public function resolveMiddleware(mixed $reference): MiddlewareInterface |
|
58 | { |
||
59 | 2 | return $this->middlewareResolver->resolveMiddleware($reference); |
|
60 | } |
||
61 | |||
62 | /** |
||
63 | * @inheritDoc |
||
64 | */ |
||
65 | 2 | public function resolveRequestHandler(mixed $reference): RequestHandlerInterface |
|
66 | { |
||
67 | 2 | return $this->requestHandlerResolver->resolveRequestHandler($reference); |
|
68 | } |
||
69 | |||
70 | 5 | public static function stringifyReference(mixed $reference): string |
|
71 | { |
||
72 | 5 | if (is_string($reference)) { |
|
73 | 1 | return $reference; |
|
74 | } |
||
75 | |||
76 | // https://github.com/php/php-src/blob/3ed526441400060aa4e618b91b3352371fcd02a8/Zend/zend_API.c#L3884-L3932 |
||
77 | 4 | if (is_array($reference) && is_callable($reference, true, $referenceName)) { |
|
78 | 3 | return $referenceName; |
|
79 | } |
||
80 | |||
81 | 1 | return get_debug_type($reference); |
|
82 | } |
||
83 | } |
||
84 |