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

MetricsPowerLogger::logError()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 11
Code Lines 7

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 7
c 1
b 0
f 0
nc 1
nop 3
dl 0
loc 11
rs 10
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 FRZB\Component\DependencyInjection\Attribute\AsService;
19
use FRZB\Component\MetricsPower\Attribute\OptionsInterface;
20
use Psr\Log\LoggerInterface;
21
22
#[AsService]
23
class MetricsPowerLogger implements MetricsPowerLoggerInterface
24
{
25
    private const MESSAGE_INFO = '[MetricsPower] [INFO] [OPTIONS_CLASS: {options_class}] Metrics registration success for [MESSAGE_CLASS: {message_class}]';
26
    private const MESSAGE_ERROR = '[MetricsPower] [ERROR] [OPTIONS_CLASS: {options_class}] Metrics registration failed for [MESSAGE_CLASS: {message_class}] [REASON: {reason_message}] [OPTIONS_VALUES: {option_values}]';
27
28
    public function __construct(
29
        private readonly ContextExtractorLocatorInterface $contextExtractorLocator,
30
        private readonly LoggerInterface $logger,
31
    ) {}
32
33
    public function info(object $target, OptionsInterface $options): void
34
    {
35
        $context = $this->contextExtractorLocator
36
            ->get($target::class)
37
            ->extract($target, $options);
38
39
        $this->logger->info($context->message, $context->context);
40
    }
41
42
    public function error(object $target, OptionsInterface $options, \Throwable $exception): void
43
    {
44
        $context = $this->contextExtractorLocator
45
            ->get($target::class)
46
            ->extract($target, $options, $exception);
47
48
        $this->logger->error($context->message, $context->context);
49
    }
50
}
51