RequestPasswordReset   A
last analyzed

Complexity

Total Complexity 6

Size/Duplication

Total Lines 51
Duplicated Lines 0 %

Test Coverage

Coverage 96.15%

Importance

Changes 0
Metric Value
wmc 6
eloc 26
dl 0
loc 51
ccs 25
cts 26
cp 0.9615
rs 10
c 0
b 0
f 0

1 Method

Rating   Name   Duplication   Size   Complexity  
B build() 0 49 6
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Application\Api\Field\Mutation;
6
7
use Application\Model\Log;
8
use Application\Model\User;
9
use Application\Repository\LogRepository;
10
use Application\Repository\UserRepository;
11
use Application\Service\MessageQueuer;
12
use Ecodev\Felix\Api\ExceptionWithoutMailLogging;
13
use Ecodev\Felix\Api\Field\FieldInterface;
14
use Ecodev\Felix\Api\Scalar\EmailType;
15
use Ecodev\Felix\Service\Mailer;
16
use GraphQL\Type\Definition\Type;
17
use Mezzio\Session\SessionInterface;
18
19
abstract class RequestPasswordReset implements FieldInterface
20
{
21 3
    public static function build(): iterable
22
    {
23 1
        yield 'requestPasswordReset' => fn () => [
24 1
            'type' => Type::nonNull(Type::boolean()),
25 1
            'description' => 'Request to send an email to reset the password for the given user. It will **always** return a successful response, even if the user is not found.',
26 1
            'args' => [
27 1
                'email' => Type::nonNull(_types()->get(EmailType::class)),
28 1
            ],
29 1
            'resolve' => function ($root, array $args, SessionInterface $session): bool {
30
                global $container;
31
32 3
                _log()->info(LogRepository::REQUEST_PASSWORD_RESET);
33
34
                /** @var LogRepository $logRepository */
35 3
                $logRepository = _em()->getRepository(Log::class);
36 3
                if ($logRepository->requestPasswordResetOften()) {
37
                    throw new ExceptionWithoutMailLogging('Trop de tentatives de changement de mot de passe. Veuillez réessayer plus tard.');
38
                }
39
40
                /** @var Mailer $mailer */
41 3
                $mailer = $container->get(Mailer::class);
42
43
                /** @var MessageQueuer $messageQueuer */
44 3
                $messageQueuer = $container->get(MessageQueuer::class);
45
46
                /** @var UserRepository $repository */
47 3
                $repository = _em()->getRepository(User::class);
48
49
                /** @var null|User $user */
50 3
                $user = $repository->getOneByEmail($args['email']);
51
52 3
                if ($user) {
53 2
                    $email = $user->getEmail();
54
55
                    // If never had password, it means it was not confirmed yet
56 2
                    $message = null;
57 2
                    if (!$user->getPassword()) {
58 1
                        $message = $messageQueuer->queueRegister($user);
59 1
                    } elseif ($email) {
60 1
                        $message = $messageQueuer->queueResetPassword($user, $email);
61
                    }
62
63 2
                    if ($message) {
64 2
                        $mailer->sendMessageAsync($message);
65
                    }
66
                }
67
68
                // Here we lie to client, and always say we are successful, to avoid data leak
69 3
                return true;
70 1
            },
71 1
        ];
72
    }
73
}
74