Passed
Pull Request — master (#27)
by Burak
05:50
created

ContactController::__construct()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 2
CRAP Score 1

Importance

Changes 0
Metric Value
cc 1
eloc 1
nc 1
nop 1
dl 0
loc 3
ccs 2
cts 2
cp 1
crap 1
rs 10
c 0
b 0
f 0
1
<?php
2
3
namespace App\Http\Controllers;
4
5
use App\Http\Resources\ContactResource;
6
use App\Interfaces\ContactServiceInterface;
7
use Illuminate\Http\Request;
8
use Illuminate\Support\Facades\Auth;
9
10
class ContactController extends Controller
11
{
12
    /**
13
     * @var ContactServiceInterface
14
     */
15
    private ContactServiceInterface $service;
16
17
    /**
18
     * ContactController constructor.
19
     *
20
     * @param ContactServiceInterface $service
21
     */
22 2
    public function __construct(ContactServiceInterface $service)
23
    {
24 2
        $this->service = $service;
25 2
    }
26
27
    /**
28
     * Returns user by id.
29
     *
30
     * @param string $id
31
     * @return ContactResource
32
     */
33 1
    public function show(string $id)
34
    {
35 1
        return new ContactResource(
36 1
            $this->service->contact($id)
37
        );
38
    }
39
40
    /**
41
     * Returns contacts by user.
42
     *
43
     * @return \Illuminate\Http\Resources\Json\AnonymousResourceCollection
44
     */
45 1
    public function index()
46
    {
47 1
        $user = Auth::user();
48
49 1
        return ContactResource::collection($this->service->contacts($user));
0 ignored issues
show
Bug introduced by
It seems like $user can also be of type null; however, parameter $user of App\Interfaces\ContactServiceInterface::contacts() does only seem to accept App\Models\User, 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

49
        return ContactResource::collection($this->service->contacts(/** @scrutinizer ignore-type */ $user));
Loading history...
50
    }
51
}
52