Passed
Push — develop ( 577144...bf5480 )
by
unknown
01:39
created

GetCompanies   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 28
Duplicated Lines 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 10
c 1
b 0
f 0
dl 0
loc 28
rs 10
wmc 3

2 Methods

Rating   Name   Duplication   Size   Complexity  
A __invoke() 0 12 2
A __construct() 0 9 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;
15
16
use Company\Domain\Storage\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 GetCompanies extends AbstractController
23
{
24
    private JsonResponse $jsonResponse;
25
    private ReadCompany $readCompany;
26
27
    public function __construct(
28
        ReadCompany $readCompany,
29
        SerializerInterface $serializer,
30
        JsonResponse $jsonResponse
31
    ) {
32
        parent::__construct($serializer);
33
34
        $this->jsonResponse = $jsonResponse;
35
        $this->readCompany = $readCompany;
36
    }
37
38
    public function __invoke(): Response
39
    {
40
        /**
41
         * @todo manage this controller to give company for the current user
42
         */
43
        $companies = $this->readCompany->findAll();
0 ignored issues
show
Bug introduced by
The method findAll() does not exist on Company\Domain\Storage\ReadCompany. Since it exists in all sub-types, consider adding an abstract or default implementation to Company\Domain\Storage\ReadCompany. ( Ignorable by Annotation )

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

43
        /** @scrutinizer ignore-call */ 
44
        $companies = $this->readCompany->findAll();
Loading history...
44
45
        if (empty($companies)) {
46
            return $this->jsonResponse->response('No data found', Response::HTTP_ACCEPTED);
47
        }
48
49
        return $this->jsonResponse->response($this->serialize($companies));
50
    }
51
}
52