Passed
Push — master ( 5e96c0...23583c )
by Angel Fernando Quiroz
08:21
created

KeycloakAuthenticator   A

Complexity

Total Complexity 6

Size/Duplication

Total Lines 53
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
eloc 27
dl 0
loc 53
rs 10
c 0
b 0
f 0
wmc 6

3 Methods

Rating   Name   Duplication   Size   Complexity  
A supports() 0 3 1
A getCustomBadge() 0 3 1
A userLoader() 0 39 4
1
<?php
2
3
/* For licensing terms, see /license.txt */
4
5
declare(strict_types=1);
6
7
namespace Chamilo\CoreBundle\Security\Authenticator\OAuth2;
8
9
use Chamilo\CoreBundle\Entity\User;
10
use Chamilo\CoreBundle\Entity\UserAuthSource;
11
use Chamilo\CoreBundle\Security\Badge\OAuth2Badge;
12
use League\OAuth2\Client\Token\AccessToken;
13
use Stevenmaguire\OAuth2\Client\Provider\KeycloakResourceOwner;
14
use Symfony\Component\HttpFoundation\Request;
15
use Symfony\Component\Security\Http\Authenticator\Passport\Badge\BadgeInterface;
16
17
class KeycloakAuthenticator extends AbstractAuthenticator
18
{
19
    protected string $providerName = 'keycloak';
20
21
    public function supports(Request $request): ?bool
22
    {
23
        return 'chamilo.oauth2_keycloak_check' === $request->attributes->get('_route');
24
    }
25
26
    protected function userLoader(AccessToken $accessToken): User
27
    {
28
        /** @var KeycloakResourceOwner $resourceOwner */
29
        $resourceOwner = $this->client->fetchUserFromToken($accessToken);
30
31
        $user = $this->userRepository->findOneBy(['username' => $resourceOwner->getUsername()])
32
            ?:
33
            $this->userRepository->findOneBy(['username' => $resourceOwner->getId()]);
34
35
        if (!$user) {
36
            $user = (new User())
37
                ->setCreatorId($this->userRepository->getRootUser()->getId())
38
            ;
39
        }
40
41
        $username = $resourceOwner->getUsername() ?: $resourceOwner->getId();
42
43
        $user
44
            ->setFirstname($resourceOwner->getFirstName())
45
            ->setLastname($resourceOwner->getLastName())
46
            ->setEmail($resourceOwner->getEmail())
47
            ->setUsername($username)
48
            ->setPlainPassword('keycloak')
49
            ->setStatus(STUDENT)
50
            ->addAuthSourceByAuthentication(
51
                UserAuthSource::KEYCLOAK,
52
                $this->accessUrlHelper->getCurrent()
53
            )
54
            ->setRoleFromStatus(STUDENT)
55
        ;
56
57
        $this->userRepository->updateUser($user);
58
59
        $url = $this->accessUrlHelper->getCurrent();
60
        $url->addUser($user);
61
62
        $this->entityManager->flush();
63
64
        return $user;
65
    }
66
67
    protected function getCustomBadge(): ?BadgeInterface
68
    {
69
        return new Oauth2Badge(UserAuthSource::KEYCLOAK);
70
    }
71
}
72