namespace Rapsys\UserBundle\Entity;
+use Doctrine\Common\Collections\Collection;
use Doctrine\Common\Collections\ArrayCollection;
use Doctrine\ORM\Event\PreUpdateEventArgs;
use Symfony\Component\Security\Core\User\UserInterface;
+use Symfony\Component\Security\Core\User\PasswordAuthenticatedUserInterface;
use Rapsys\UserBundle\Entity\Civility;
use Rapsys\UserBundle\Entity\Group;
/**
* User
*/
-class User implements UserInterface, \Serializable {
+class User implements UserInterface, PasswordAuthenticatedUserInterface {
/**
- * @var integer
+ * @var ?integer
*/
- protected $id;
+ protected ?int $id;
/**
* @var string
*/
- protected $mail;
+ protected string $mail;
/**
* @var string
*/
- protected $forename;
+ protected string $password;
/**
- * @var string
+ * @var ?string
*/
- protected $surname;
+ protected ?string $forename;
/**
- * @var string
+ * @var ?string
*/
- protected $password;
+ protected ?string $surname;
/**
* @var bool
*/
- protected $active;
+ protected bool $active;
/**
* @var bool
*/
- protected $disabled;
+ protected bool $disabled;
/**
* @var \DateTime
*/
- protected $created;
+ protected \DateTime $created;
/**
* @var \DateTime
*/
- protected $updated;
+ protected \DateTime $updated;
/**
* @var Civility
*/
- protected $civility;
+ protected ?Civility $civility;
/**
- * @var ArrayCollection
+ * @var Doctrine\Common\Collections\Collection
*/
- protected $groups;
+ protected Collection $groups;
/**
* Constructor
*
* @param string $mail The user mail
- */
- public function __construct(string $mail) {
- //Extract names from mail
- $names = explode(' ', ucwords(trim(preg_replace('/[^a-zA-Z]+/', ' ', current(explode('@', $mail))))));
-
+ * @param string $password The user password
+ * @param ?Civility $civility The user civility
+ * @param ?string $forename The user forename
+ * @param ?string $surname The user surname
+ * @param bool $active The user active
+ * @param bool $disabled The user disabled
+ */
+ public function __construct(string $mail, string $password, ?Civility $civility = null, ?string $forename = null, ?string $surname = null, bool $active = false, bool $disabled = false) {
//Set defaults
$this->mail = $mail;
- $this->forename = $names[0];
- $this->surname = $names[1]??$names[0];
- $this->password = $mail;
- $this->active = false;
- $this->disabled = false;
+ $this->password = $password;
+ $this->civility = $civility;
+ $this->forename = $forename;
+ $this->surname = $surname;
+ $this->active = $active;
+ $this->disabled = $disabled;
$this->created = new \DateTime('now');
$this->updated = new \DateTime('now');
/**
* Get id
*
- * @return integer
+ * @return ?int
*/
- public function getId(): int {
+ public function getId(): ?int {
return $this->id;
}
* Set mail
*
* @param string $mail
- *
* @return User
*/
public function setMail(string $mail): User {
+ //Set mail
$this->mail = $mail;
return $this;
/**
* Set forename
*
- * @param string $forename
+ * @param ?string $forename
*
* @return User
*/
- public function setForename(string $forename): User {
+ public function setForename(?string $forename): User {
$this->forename = $forename;
return $this;
/**
* Get forename
*
- * @return string
+ * @return ?string
*/
- public function getForename(): string {
+ public function getForename(): ?string {
return $this->forename;
}
/**
* Set surname
*
- * @param string $surname
+ * @param ?string $surname
*
* @return User
*/
- public function setSurname(string $surname): User {
+ public function setSurname(?string $surname): User {
$this->surname = $surname;
return $this;
/**
* Get surname
*
- * @return string
+ * @return ?string
*/
- public function getSurname(): string {
+ public function getSurname(): ?string {
return $this->surname;
}
* @return User
*/
public function setPassword(string $password): User {
+ //Set password
$this->password = $password;
return $this;
*
* @return string
*/
- public function getPassword(): ?string {
+ public function getPassword(): string {
return $this->password;
}
/**
* Set civility
*/
- public function setCivility(Civility $civility): User {
+ public function setCivility(?Civility $civility = null): User {
$this->civility = $civility;
return $this;
*
* @return User
*/
- public function addGroup(Group $group) {
+ public function addGroup(Group $group): User {
$this->groups[] = $group;
return $this;
* Remove group
*
* @param Group $group
+ *
+ * @return Doctrine\Common\Collections\Collection
*/
- public function removeGroup(Group $group) {
- $this->groups->removeElement($group);
+ public function removeGroup(Group $group): Collection {
+ return $this->groups->removeElement($group);
}
/**
* Get groups
*
- * @return ArrayCollection
+ * @return Doctrine\Common\Collections\Collection
*/
- public function getGroups(): ArrayCollection {
+ public function getGroups(): Collection {
return $this->groups;
}
return $this->mail;
}
+ /**
+ * {@inheritdoc}
+ */
+ public function getUserIdentifier(): string {
+ return $this->mail;
+ }
+
/**
* {@inheritdoc}
*/
/**
* {@inheritdoc}
*/
- public function serialize(): string {
- return serialize([
+ public function __serialize(): array {
+ return [
$this->id,
$this->mail,
$this->forename,
$this->disabled,
$this->created,
$this->updated
- ]);
+ ];
}
/**
* {@inheritdoc}
*/
- public function unserialize($serialized) {
+ public function __unserialize(array $data): void {
list(
$this->id,
$this->mail,
$this->disabled,
$this->created,
$this->updated
- ) = unserialize($serialized);
+ ) = $data;
}
/**
* Check if account is activated
*
- * It was from deprecated AdvancedUserInterface, see if it's used anymore
- *
- * @see vendor/symfony/security-core/User/AdvancedUserInterface.php
+ * @see vendor/rapsys/userbundle/Checker/UserChecker.php
*/
public function isActivated(): bool {
return $this->active;
}
/**
- * Check if account is disabled
- *
- * It was from deprecated AdvancedUserInterface, see if it's used anymore
+ * Check if account is enabled
*
- * @see vendor/symfony/security-core/User/AdvancedUserInterface.php
+ * @see vendor/symfony/security-core/User/InMemoryUserChecker.php
*/
- public function isDisabled(): bool {
- return $this->disabled;
+ public function isEnabled(): bool {
+ return !$this->disabled;
}
/**
}
}
+ /**
+ * Returns a recipient name of the user
+ *
+ * @return string
+ */
+ public function getRecipientName(): string {
+ //Without forename and surname
+ if (empty($this->forename) && empty($this->surname)) {
+ //Return recipient name from mail
+ return ucwords(trim(preg_replace('/[^a-zA-Z]+/', ' ', current(explode('@', $this->mail)))));
+ }
+
+ //Return recipient name from forename and surname
+ return implode(' ', [$this->forename, $this->surname]);
+ }
+
/**
* Returns a string representation of the user
*