ReferenceResolver::stringifyReference()   A
last analyzed

Complexity

Conditions 4
Paths 3

Size

Total Lines 12
Code Lines 5

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 6
CRAP Score 4

Importance

Changes 3
Bugs 0 Features 0
Metric Value
cc 4
eloc 5
c 3
b 0
f 0
nc 3
nop 1
dl 0
loc 12
ccs 6
cts 6
cp 1
crap 4
rs 10
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
The doc comment array<array-key, ParameterResolverInterface> at position 2 could not be parsed: Unknown type name 'array-key' at position 2 in array<array-key, ParameterResolverInterface>.
Loading history...
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