Passed
Push — main ( 1bfc55...29d6ba )
by Fractal
02:09
created

ContextExtractorLocator::get()   A

Complexity

Conditions 2
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 2
eloc 2
nc 1
nop 1
dl 0
loc 4
rs 10
c 1
b 0
f 0
1
<?php
2
3
declare(strict_types=1);
4
5
/**
6
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
7
 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
8
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
9
 *
10
 * Copyright (c) 2024 Mykhailo Shtanko [email protected]
11
 *
12
 * For the full copyright and license information, please view the LICENSE.MD
13
 * file that was distributed with this source code.
14
 */
15
16
namespace FRZB\Component\MetricsPower\Logger;
17
18
use Fp\Collections\HashMap;
19
use FRZB\Component\DependencyInjection\Attribute\AsService;
20
use FRZB\Component\MetricsPower\Logger\ContextExtractor\ContextExtractorInterface;
21
use FRZB\Component\MetricsPower\Logger\ContextExtractor\DefaultContextExtractor;
22
use Symfony\Component\DependencyInjection\Attribute\TaggedIterator;
23
24
#[AsService]
25
final class ContextExtractorLocator implements ContextExtractorLocatorInterface
26
{
27
    /** @var HashMap<string, ContextExtractorInterface> */
28
    private readonly HashMap $resolvers;
29
30
    public function __construct(
31
        #[TaggedIterator(ContextExtractorInterface::class, defaultIndexMethod: 'getType')]
32
        iterable $resolvers,
33
    ) {
34
        $this->resolvers = HashMap::collect($resolvers);
0 ignored issues
show
Bug introduced by
The property resolvers is declared read-only in FRZB\Component\MetricsPo...ContextExtractorLocator.
Loading history...
35
    }
36
37
    public function get(object|string $target): ContextExtractorInterface
38
    {
39
        return $this->resolvers->get(\is_object($target) ? $target::class : $target)->get()
40
            ?? $this->resolvers->get(DefaultContextExtractor::DEFAULT_TYPE)->getUnsafe();
41
    }
42
}
43