Passed
Push — v2 ( dec916...f92e78 )
by Daniel
05:10
created

PasswordUpdateAction::__invoke()   A

Complexity

Conditions 3
Paths 4

Size

Total Lines 22
Code Lines 14

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 12

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 14
c 1
b 0
f 0
dl 0
loc 22
ccs 0
cts 13
cp 0
rs 9.7998
cc 3
nc 4
nop 1
crap 12
1
<?php
2
3
/*
4
 * This file is part of the Silverback API Component Bundle Project
5
 *
6
 * (c) Daniel West <[email protected]>
7
 *
8
 * For the full copyright and license information, please view the LICENSE
9
 * file that was distributed with this source code.
10
 */
11
12
declare(strict_types=1);
13
14
namespace Silverback\ApiComponentBundle\Action;
15
16
use Symfony\Component\HttpFoundation\JsonResponse;
17
use Symfony\Component\HttpFoundation\Request;
18
use Symfony\Component\HttpFoundation\Response;
19
use Symfony\Component\Security\Core\Exception\AuthenticationException;
20
21
/**
22
 * @author Daniel West <[email protected]>
23
 */
24
class PasswordUpdateAction extends AbstractPasswordAction
25
{
26
    public function __invoke(Request $request)
27
    {
28
        $data = json_decode($request->getContent(), true, 512, JSON_THROW_ON_ERROR);
29
30
        $username = $data['username'];
31
        $token = $data['token'];
32
        $user = $this->userRepository->findOneByPasswordResetToken(
33
            $username,
34
            $token
35
        );
36
        if (!$user) {
37
            return new JsonResponse([], Response::HTTP_NOT_FOUND);
38
        }
39
40
        try {
41
            $this->passwordManager->passwordReset($user, $data['password']);
42
43
            return new JsonResponse([], Response::HTTP_OK);
44
        } catch (AuthenticationException $exception) {
45
            $errors = $exception->getMessageData();
46
47
            return new JsonResponse($errors, Response::HTTP_BAD_REQUEST);
48
        }
49
    }
50
}
51