|
1
|
|
|
<?php |
|
2
|
|
|
|
|
3
|
|
|
namespace Kaliop\IdentityManagementBundle\Security\User\Provider; |
|
4
|
|
|
|
|
5
|
|
|
use eZ\Publish\API\Repository\Exceptions\NotFoundException; |
|
6
|
|
|
use eZ\Publish\Core\MVC\Symfony\Security\User; |
|
7
|
|
|
use eZ\Publish\Core\MVC\Symfony\Security\UserInterface; |
|
8
|
|
|
use Symfony\Component\Security\Core\Exception\UsernameNotFoundException; |
|
9
|
|
|
use eZ\Publish\Core\MVC\Symfony\Security\User\Provider; |
|
10
|
|
|
|
|
11
|
|
|
/** |
|
12
|
|
|
* Used to log in users by either their email or login |
|
13
|
|
|
*/ |
|
14
|
|
|
class EmailUser extends Provider |
|
15
|
|
|
{ |
|
16
|
|
|
/** |
|
17
|
|
|
* Loads the user for the given user 'ID'. |
|
18
|
|
|
* $user can be either the user ID or an instance of \eZ\Publish\Core\MVC\Symfony\Security\User |
|
19
|
|
|
* (anonymous user we try to check access via SecurityContext::isGranted()). |
|
20
|
|
|
* |
|
21
|
|
|
* @param string|\eZ\Publish\Core\MVC\Symfony\Security\User $user Either the user ID to load an instance of User object. A value of -1 represents an anonymous user. |
|
22
|
|
|
* |
|
23
|
|
|
* @return \eZ\Publish\Core\MVC\Symfony\Security\UserInterface |
|
24
|
|
|
* |
|
25
|
|
|
* @throws \Symfony\Component\Security\Core\Exception\UsernameNotFoundException if the user is not found |
|
26
|
|
|
*/ |
|
27
|
|
|
public function loadUserByUsername($user) |
|
28
|
|
|
{ |
|
29
|
|
|
try { |
|
30
|
|
|
// SecurityContext always tries to authenticate anonymous users when checking granted access. |
|
31
|
|
|
// In that case $user is an instance of \eZ\Publish\Core\MVC\Symfony\Security\User. |
|
32
|
|
|
// We don't need to reload the user here. |
|
33
|
|
|
if ($user instanceof UserInterface) { |
|
34
|
|
|
return $user; |
|
35
|
|
|
} |
|
36
|
|
|
// 1st try to find user by login |
|
37
|
|
|
return new User($this->repository->getUserService()->loadUserByLogin($user), array('ROLE_USER')); |
|
38
|
|
|
} catch (NotFoundException $e) { |
|
39
|
|
|
// Then we try to find the user via email address |
|
40
|
|
|
$users = $this->repository->getUserService()->loadUsersByEmail($user); |
|
41
|
|
|
if (!count($users)) { |
|
42
|
|
|
throw new UsernameNotFoundException(); |
|
43
|
|
|
} |
|
44
|
|
|
/// @todo log a warning if many users do match the email |
|
45
|
|
|
return new User($users[0], array('ROLE_USER')); |
|
46
|
|
|
} |
|
47
|
|
|
} |
|
48
|
|
|
} |