Passed
Push — master ( abcdc1...a80a3a )
by Sam
06:58
created

RequestPasswordReset::build()   A

Complexity

Conditions 4
Paths 1

Size

Total Lines 43
Code Lines 22

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 19
CRAP Score 4.002

Importance

Changes 0
Metric Value
eloc 22
dl 0
loc 43
ccs 19
cts 20
cp 0.95
rs 9.568
c 0
b 0
f 0
cc 4
nc 1
nop 0
crap 4.002
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 2
    public static function build(): array
22
    {
23
        return [
24 1
            'name' => 'requestPasswordReset',
25 1
            'type' => Type::nonNull(Type::boolean()),
26 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.',
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 2
                _log()->info(LogRepository::REQUEST_PASSWORD_RESET);
34
35
                /** @var LogRepository $logRepository */
36 2
                $logRepository = _em()->getRepository(Log::class);
37 2
                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 2
                $mailer = $container->get(Mailer::class);
43
44
                /** @var MessageQueuer $messageQueuer */
45 2
                $messageQueuer = $container->get(MessageQueuer::class);
46
47
                /** @var UserRepository $repository */
48 2
                $repository = _em()->getRepository(User::class);
49
50
                /** @var null|User $user */
51 2
                $user = $repository->getOneByEmail($args['email']);
52
53 2
                if ($user) {
54 1
                    $email = $user->getEmail();
55
56 1
                    if ($email) {
57 1
                        $message = $messageQueuer->queueResetPassword($user, $email);
58 1
                        $mailer->sendMessageAsync($message);
59
                    }
60
                }
61
62
                // Here we lie to client, and always say we are successful, to avoid data leak
63 2
                return true;
64 1
            },
65
        ];
66
    }
67
}
68