Passed
Push — main ( f03162...8467a1 )
by Fractal
01:57
created

LoggerOptionsResolver::__construct()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 0

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 0
c 1
b 0
f 0
nc 1
nop 1
dl 0
loc 3
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\OptionsResolver\Resolver;
17
18
use FRZB\Component\DependencyInjection\Attribute\AsService;
19
use FRZB\Component\DependencyInjection\Attribute\AsTagged;
20
use FRZB\Component\MetricsPower\Attribute\LoggerOptions;
21
use FRZB\Component\MetricsPower\Attribute\OptionsInterface;
22
use FRZB\Component\MetricsPower\Logger\MetricsPowerLoggerInterface;
23
use Symfony\Component\Messenger\Event\AbstractWorkerMessageEvent;
24
use Symfony\Component\Messenger\Event\SendMessageToTransportsEvent;
25
use Symfony\Component\Messenger\Event\WorkerMessageFailedEvent;
26
27
#[AsService, AsTagged(OptionsResolverInterface::class)]
28
class LoggerOptionsResolver
29
{
30
    public function __construct(
31
        private readonly MetricsPowerLoggerInterface $logger,
32
    ) {}
33
34
    public function __invoke(AbstractWorkerMessageEvent|SendMessageToTransportsEvent $event, OptionsInterface $options): void
35
    {
36
        match ($event::class) {
37
            WorkerMessageFailedEvent::class => $this->logger->logError($event, $options, $event->getThrowable()),
0 ignored issues
show
Bug introduced by
The method getThrowable() does not exist on Symfony\Component\Messen...essageToTransportsEvent. ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-call  annotation

37
            WorkerMessageFailedEvent::class => $this->logger->logError($event, $options, $event->/** @scrutinizer ignore-call */ getThrowable()),

This check looks for calls to methods that do not seem to exist on a given type. It looks for the method on the type itself as well as in inherited classes or implemented interfaces.

This is most likely a typographical error or the method has been renamed.

Loading history...
Bug introduced by
The method getThrowable() does not exist on Symfony\Component\Messen...tractWorkerMessageEvent. It seems like you code against a sub-type of Symfony\Component\Messen...tractWorkerMessageEvent such as Symfony\Component\Messen...orkerMessageFailedEvent. ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-call  annotation

37
            WorkerMessageFailedEvent::class => $this->logger->logError($event, $options, $event->/** @scrutinizer ignore-call */ getThrowable()),
Loading history...
Bug introduced by
Are you sure the usage of $this->logger->logError(...$event->getThrowable()) targeting FRZB\Component\MetricsPo...erInterface::logError() seems to always return null.

This check looks for function or method calls that always return null and whose return value is used.

class A
{
    function getObject()
    {
        return null;
    }

}

$a = new A();
if ($a->getObject()) {

The method getObject() can return nothing but null, so it makes no sense to use the return value.

The reason is most likely that a function or method is imcomplete or has been reduced for debug purposes.

Loading history...
38
            default => $this->logger->logInfo($event, $options),
0 ignored issues
show
Bug introduced by
Are you sure the usage of $this->logger->logInfo($event, $options) targeting FRZB\Component\MetricsPo...gerInterface::logInfo() seems to always return null.

This check looks for function or method calls that always return null and whose return value is used.

class A
{
    function getObject()
    {
        return null;
    }

}

$a = new A();
if ($a->getObject()) {

The method getObject() can return nothing but null, so it makes no sense to use the return value.

The reason is most likely that a function or method is imcomplete or has been reduced for debug purposes.

Loading history...
39
        };
40
    }
41
42
    public static function getType(): string
43
    {
44
        return LoggerOptions::class;
45
    }
46
}
47