Passed
Push — develop ( ad498d...18a364 )
by BENARD
09:25
created

ConfirmRegistration::__invoke()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 16
Code Lines 9

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 2
eloc 9
nc 2
nop 1
dl 0
loc 16
rs 9.9666
c 0
b 0
f 0
1
<?php
2
3
namespace ProjetNormandie\UserBundle\Controller\Security;
4
5
use ProjetNormandie\UserBundle\Manager\UserManager;
6
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
7
use Symfony\Component\HttpFoundation\Exception\BadRequestException;
8
use Symfony\Component\HttpFoundation\JsonResponse;
9
use Symfony\Component\HttpFoundation\Request;
10
use Symfony\Component\HttpFoundation\Response;
11
use Symfony\Contracts\Translation\TranslatorInterface;
12
13
class ConfirmRegistration extends AbstractController
14
{
15
    public function __construct(
16
        private readonly UserManager $userManager,
17
        private readonly TranslatorInterface $translator
18
    ) {
19
    }
20
21
22
    /**
23
     * @param Request $request
24
     * @return Response
25
     */
26
    public function __invoke(Request $request): Response
27
    {
28
        $data = json_decode($request->getContent(), true);
29
        $token = $data['token'];
30
31
        $user = $this->userManager->findUserByConfirmationToken($token);
32
33
        if (null === $user) {
34
            throw new BadRequestException($this->translator->trans('registration.token_invalid', [], 'PnUser'));
35
        }
36
37
        $user->setEnabled(true);
38
        $user->setConfirmationToken(null);
39
        $this->userManager->updateUser($user);
40
41
        return new JsonResponse(['success' => true]);
42
    }
43
}
44