Passed
Push — master ( 1d5fb4...e5c3c4 )
by Sam
06:33 queued 01:55
created

RequestPasswordReset::build()   B

Complexity

Conditions 6
Paths 1

Size

Total Lines 50
Code Lines 26

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 22
CRAP Score 6.0029

Importance

Changes 0
Metric Value
eloc 26
dl 0
loc 50
ccs 22
cts 23
cp 0.9565
rs 8.8817
c 0
b 0
f 0
cc 6
nc 1
nop 0
crap 6.0029
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(): array
22
    {
23
        return [
24 1
            'name' => 'requestPasswordReset',
25 1
            'type' => Type::nonNull(Type::boolean()),
26
            '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.',
27
            'args' => [
28 1
                'email' => Type::nonNull(_types()->get(EmailType::class)),
29
            ],
30 1
            'resolve' => function ($root, array $args, SessionInterface $session): bool {
31
                global $container;
32
33 3
                _log()->info(LogRepository::REQUEST_PASSWORD_RESET);
34
35
                /** @var LogRepository $logRepository */
36 3
                $logRepository = _em()->getRepository(Log::class);
37 3
                if ($logRepository->requestPasswordResetOften()) {
38
                    throw new ExceptionWithoutMailLogging('Trop de tentatives de changement de mot de passe. Veuillez réessayer plus tard.');
39
                }
40
41
                /** @var Mailer $mailer */
42 3
                $mailer = $container->get(Mailer::class);
43
44
                /** @var MessageQueuer $messageQueuer */
45 3
                $messageQueuer = $container->get(MessageQueuer::class);
46
47
                /** @var UserRepository $repository */
48 3
                $repository = _em()->getRepository(User::class);
49
50
                /** @var null|User $user */
51 3
                $user = $repository->getOneByEmail($args['email']);
52
53 3
                if ($user) {
54 2
                    $email = $user->getEmail();
55
56
                    // If never had password, it means it was not confirmed yet
57 2
                    $message = null;
58 2
                    if (!$user->getPassword()) {
59 1
                        $message = $messageQueuer->queueRegister($user);
60 1
                    } elseif ($email) {
61 1
                        $message = $messageQueuer->queueResetPassword($user, $email);
62
                    }
63
64 2
                    if ($message) {
65 2
                        $mailer->sendMessageAsync($message);
66
                    }
67
                }
68
69
                // Here we lie to client, and always say we are successful, to avoid data leak
70 3
                return true;
71
            },
72
        ];
73
    }
74
}
75