Passed
Push — feat/manage-settings ( 112b09 )
by
unknown
06:30
created

GetCompany   A

Complexity

Total Complexity 2

Size/Duplication

Total Lines 20
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
eloc 7
c 0
b 0
f 0
dl 0
loc 20
rs 10
wmc 2

2 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 8 1
A __invoke() 0 5 1
1
<?php
2
3
declare(strict_types=1);
4
5
/*
6
 * This file is part of the G.L.S.R. Apps package.
7
 *
8
 * (c) Dev-Int Création <[email protected]>.
9
 *
10
 * For the full copyright and license information, please view the LICENSE
11
 * file that was distributed with this source code.
12
 */
13
14
namespace Company\UI\Controller\Company;
15
16
use Company\Domain\Storage\Company\ReadCompany;
17
use Core\Controller\AbstractController;
18
use Core\Infrastructure\Response\JsonResponse;
19
use Symfony\Component\HttpFoundation\Response;
0 ignored issues
show
Bug introduced by
The type Symfony\Component\HttpFoundation\Response was not found. Maybe you did not declare it correctly or list all dependencies?

The issue could also be caused by a filter entry in the build configuration. If the path has been excluded in your configuration, e.g. excluded_paths: ["lib/*"], you can move it to the dependency path list as follows:

filter:
    dependency_paths: ["lib/*"]

For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths

Loading history...
20
use Symfony\Component\Serializer\SerializerInterface;
0 ignored issues
show
Bug introduced by
The type Symfony\Component\Serializer\SerializerInterface was not found. Maybe you did not declare it correctly or list all dependencies?

The issue could also be caused by a filter entry in the build configuration. If the path has been excluded in your configuration, e.g. excluded_paths: ["lib/*"], you can move it to the dependency path list as follows:

filter:
    dependency_paths: ["lib/*"]

For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths

Loading history...
21
22
class GetCompany extends AbstractController
23
{
24
    private JsonResponse $jsonResponse;
0 ignored issues
show
introduced by
The private property $jsonResponse is not used, and could be removed.
Loading history...
25
    private ReadCompany $readCompany;
26
27
    public function __construct(
28
        ReadCompany $readCompany,
29
        SerializerInterface $serializer,
30
        JsonResponse $jsonResponse
31
    ) {
32
        parent::__construct($serializer);
0 ignored issues
show
Bug introduced by
The call to Core\Controller\AbstractController::__construct() has too few arguments starting with jsonResponse. ( Ignorable by Annotation )

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

32
        parent::/** @scrutinizer ignore-call */ 
33
                __construct($serializer);

This check compares calls to functions or methods with their respective definitions. If the call has less arguments than are defined, it raises an issue.

If a function is defined several times with a different number of parameters, the check may pick up the wrong definition and report false positives. One codebase where this has been known to happen is Wordpress. Please note the @ignore annotation hint above.

Loading history...
33
34
        $this->readCompany = $readCompany;
35
    }
36
37
    public function __invoke(string $uuid): Response
38
    {
39
        $company = $this->readCompany->findOneByUuid($uuid);
40
41
        return $this->response($this->serialize($company));
0 ignored issues
show
Bug introduced by
It seems like $company can also be of type null; however, parameter $object of Core\Controller\AbstractController::serialize() does only seem to accept object, maybe add an additional type check? ( Ignorable by Annotation )

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

41
        return $this->response($this->serialize(/** @scrutinizer ignore-type */ $company));
Loading history...
42
    }
43
}
44