114 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			114 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| /*
 | |
|  * This file is part of the Symfony package.
 | |
|  *
 | |
|  * (c) Fabien Potencier <fabien@symfony.com>
 | |
|  *
 | |
|  * For the full copyright and license information, please view the LICENSE
 | |
|  * file that was distributed with this source code.
 | |
|  */
 | |
| 
 | |
| namespace Symfony\Component\Ldap\Security;
 | |
| 
 | |
| use Symfony\Component\Ldap\Entry;
 | |
| use Symfony\Component\Security\Core\User\EquatableInterface;
 | |
| use Symfony\Component\Security\Core\User\PasswordAuthenticatedUserInterface;
 | |
| use Symfony\Component\Security\Core\User\UserInterface;
 | |
| 
 | |
| /**
 | |
|  * @author Robin Chalas <robin.chalas@gmail.com>
 | |
|  *
 | |
|  * @final
 | |
|  */
 | |
| class LdapUser implements UserInterface, PasswordAuthenticatedUserInterface, EquatableInterface
 | |
| {
 | |
|     private Entry $entry;
 | |
|     private string $identifier;
 | |
|     private ?string $password;
 | |
|     private array $roles;
 | |
|     private array $extraFields;
 | |
| 
 | |
|     public function __construct(Entry $entry, string $identifier, #[\SensitiveParameter] ?string $password, array $roles = [], array $extraFields = [])
 | |
|     {
 | |
|         if (!$identifier) {
 | |
|             throw new \InvalidArgumentException('The username cannot be empty.');
 | |
|         }
 | |
| 
 | |
|         $this->entry = $entry;
 | |
|         $this->identifier = $identifier;
 | |
|         $this->password = $password;
 | |
|         $this->roles = $roles;
 | |
|         $this->extraFields = $extraFields;
 | |
|     }
 | |
| 
 | |
|     public function getEntry(): Entry
 | |
|     {
 | |
|         return $this->entry;
 | |
|     }
 | |
| 
 | |
|     public function getRoles(): array
 | |
|     {
 | |
|         return $this->roles;
 | |
|     }
 | |
| 
 | |
|     public function getPassword(): ?string
 | |
|     {
 | |
|         return $this->password;
 | |
|     }
 | |
| 
 | |
|     public function getSalt(): ?string
 | |
|     {
 | |
|         return null;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @internal for compatibility with Symfony 5.4
 | |
|      */
 | |
|     public function getUsername(): string
 | |
|     {
 | |
|         return $this->getUserIdentifier();
 | |
|     }
 | |
| 
 | |
|     public function getUserIdentifier(): string
 | |
|     {
 | |
|         return $this->identifier;
 | |
|     }
 | |
| 
 | |
|     public function eraseCredentials(): void
 | |
|     {
 | |
|         $this->password = null;
 | |
|     }
 | |
| 
 | |
|     public function getExtraFields(): array
 | |
|     {
 | |
|         return $this->extraFields;
 | |
|     }
 | |
| 
 | |
|     public function setPassword(#[\SensitiveParameter] string $password): void
 | |
|     {
 | |
|         $this->password = $password;
 | |
|     }
 | |
| 
 | |
|     public function isEqualTo(UserInterface $user): bool
 | |
|     {
 | |
|         if (!$user instanceof self) {
 | |
|             return false;
 | |
|         }
 | |
| 
 | |
|         if ($this->getPassword() !== $user->getPassword()) {
 | |
|             return false;
 | |
|         }
 | |
| 
 | |
|         if ($this->getSalt() !== $user->getSalt()) {
 | |
|             return false;
 | |
|         }
 | |
| 
 | |
|         if ($this->getUserIdentifier() !== $user->getUserIdentifier()) {
 | |
|             return false;
 | |
|         }
 | |
| 
 | |
|         return true;
 | |
|     }
 | |
| }
 |