Verify::__invoke()   A
last analyzed

Complexity

Conditions 3
Paths 6

Size

Total Lines 17
Code Lines 9

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 9
CRAP Score 3

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 3
eloc 9
c 1
b 0
f 0
nc 6
nop 2
dl 0
loc 17
ccs 9
cts 9
cp 1
crap 3
rs 9.9666
1
<?php
2
3
declare(strict_types=1);
4
5
namespace App\Http\Controllers\Api\Profile\Email;
6
7
use App\Auth\Dispensary\Exceptions\TokenExpiredException;
8
use App\Auth\EmailDispensary;
9
use App\Contracts\Http\Responses\ResponseFactory;
10
use App\Http\Requests\Api\Profile\Email\VerifyRequest;
11
use Illuminate\Contracts\Auth\Guard;
12
use Illuminate\Http\Response;
13
14
final class Verify
15
{
16
    private EmailDispensary $dispensary;
17
18
    private ResponseFactory $responseFactory;
19
20
    public function __construct(EmailDispensary $dispensary, ResponseFactory $responseFactory)
21
    {
22
        $this->dispensary = $dispensary;
23
        $this->responseFactory = $responseFactory;
24
    }
25
26 4
    public function __invoke(Guard $guard, VerifyRequest $request): Response
27
    {
28 4
        /** @var \App\Models\User $user */
29 4
        $user = $guard->user();
30 4
31
        $email = $request->input('email');
32 3
33
        try {
34
            if ($this->dispensary->verify($user, $email, $request->input('token'))) {
35 3
                $user->update(['email' => $email]);
36
37 3
                return $this->responseFactory->noContent(Response::HTTP_OK);
38
            }
39
40 3
            return $this->responseFactory->noContent(Response::HTTP_BAD_REQUEST);
41 1
        } catch (TokenExpiredException $e) {
42
            return $this->responseFactory->noContent(Response::HTTP_BAD_REQUEST);
43 1
        }
44
    }
45
}
46