Passed
Push — master ( fd7c1e...90cfdb )
by Adrien
14:46
created

UserByToken   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 28
Duplicated Lines 0 %

Test Coverage

Coverage 58.81%

Importance

Changes 2
Bugs 0 Features 0
Metric Value
wmc 3
eloc 15
dl 0
loc 28
ccs 10
cts 17
cp 0.5881
rs 10
c 2
b 0
f 0

1 Method

Rating   Name   Duplication   Size   Complexity  
A build() 0 26 3
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Application\Api\Field\Query;
6
7
use Application\Model\User;
8
use Application\Repository\UserRepository;
9
use Ecodev\Felix\Api\ExceptionWithoutMailLogging;
10
use Ecodev\Felix\Api\Field\FieldInterface;
11
use GraphQL\Type\Definition\Type;
12
13
abstract class UserByToken implements FieldInterface
14
{
15 1
    public static function build(): array
16
    {
17 1
        return
18 1
            [
19 1
                'name' => 'userByToken',
20 1
                'type' => Type::nonNull(_types()->getOutput(User::class)),
21 1
                'description' => 'Get a user by its temporary token',
22 1
                'args' => [
23 1
                    'token' => Type::nonNull(_types()->get('Token')),
24 1
                ],
25 1
                'resolve' => function ($root, array $args): User {
26
                    /** @var UserRepository $repository */
27
                    $repository = _em()->getRepository(User::class);
28
29
                    /** @var null|User $user */
30
                    $user = $repository->getAclFilter()->runWithoutAcl(fn () => $repository->findOneByToken($args['token']));
31
32
                    if (!$user) {
33
                        throw new ExceptionWithoutMailLogging("Le lien que tu as suivi n'est pas valable ou a déjà été utilisé. Effectue une nouvelle demande de changement de mot de passe ou création de compte. Chaque nouvelle demande invalide les précédentes.");
34
                    }
35
36
                    if (!$user->isTokenValid()) {
37
                        throw new ExceptionWithoutMailLogging('Le lien que tu as suivi est périmé. Effectue une nouvelle demande.');
38
                    }
39
40
                    return $user;
41 1
                },
42 1
            ];
43
    }
44
}
45