Created
December 13, 2021 13:33
-
-
Save guillaumebdx/733ab1f694f61dd13719c9598a711660 to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
namespace App\Entity; | |
use App\Repository\UserRepository; | |
use Doctrine\ORM\Mapping as ORM; | |
use Symfony\Bridge\Doctrine\Validator\Constraints\UniqueEntity; | |
use Symfony\Component\Security\Core\User\PasswordAuthenticatedUserInterface; | |
use Symfony\Component\Security\Core\User\UserInterface; | |
use DateTime; | |
/** | |
* @ORM\Entity(repositoryClass=UserRepository::class) | |
* @UniqueEntity(fields={"email"}, message="There is already an account with this email") | |
* @ORM\HasLifecycleCallbacks() | |
*/ | |
class User implements UserInterface, PasswordAuthenticatedUserInterface | |
{ | |
/** | |
* @ORM\Id | |
* @ORM\GeneratedValue | |
* @ORM\Column(type="integer") | |
*/ | |
private $id; | |
/** | |
* @ORM\Column(type="string", length=180, unique=true) | |
*/ | |
private $email; | |
/** | |
* @ORM\Column(type="json") | |
*/ | |
private $roles = []; | |
/** | |
* @var string The hashed password | |
* @ORM\Column(type="string") | |
*/ | |
private $password; | |
/** | |
* @ORM\Column(type="datetime") | |
*/ | |
private $createdAt; | |
/** | |
* @ORM\Column(type="datetime") | |
*/ | |
private $updatedAt; | |
/** | |
* @ORM\PrePersist | |
*/ | |
public function onPrePersist() | |
{ | |
$this->createdAt = new DateTime(); | |
$this->updatedAt = new DateTime(); | |
} | |
/** | |
* @ORM\PreUpdate | |
*/ | |
public function onPreUpdate() | |
{ | |
$this->updatedAt = new DateTime(); | |
} | |
public function getId(): ?int | |
{ | |
return $this->id; | |
} | |
public function getEmail(): ?string | |
{ | |
return $this->email; | |
} | |
public function setEmail(string $email): self | |
{ | |
$this->email = $email; | |
return $this; | |
} | |
/** | |
* A visual identifier that represents this user. | |
* | |
* @see UserInterface | |
*/ | |
public function getUserIdentifier(): string | |
{ | |
return (string) $this->email; | |
} | |
/** | |
* @deprecated since Symfony 5.3, use getUserIdentifier instead | |
*/ | |
public function getUsername(): string | |
{ | |
return (string) $this->email; | |
} | |
/** | |
* @see UserInterface | |
*/ | |
public function getRoles(): array | |
{ | |
$roles = $this->roles; | |
// guarantee every user at least has ROLE_USER | |
$roles[] = 'ROLE_USER'; | |
return array_unique($roles); | |
} | |
public function setRoles(array $roles): self | |
{ | |
$this->roles = $roles; | |
return $this; | |
} | |
/** | |
* @see PasswordAuthenticatedUserInterface | |
*/ | |
public function getPassword(): string | |
{ | |
return $this->password; | |
} | |
public function setPassword(string $password): self | |
{ | |
$this->password = $password; | |
return $this; | |
} | |
/** | |
* Returning a salt is only needed, if you are not using a modern | |
* hashing algorithm (e.g. bcrypt or sodium) in your security.yaml. | |
* | |
* @see UserInterface | |
*/ | |
public function getSalt(): ?string | |
{ | |
return null; | |
} | |
/** | |
* @see UserInterface | |
*/ | |
public function eraseCredentials() | |
{ | |
// If you store any temporary, sensitive data on the user, clear it here | |
// $this->plainPassword = null; | |
} | |
public function getCreatedAt(): ?\DateTimeInterface | |
{ | |
return $this->createdAt; | |
} | |
public function setCreatedAt(\DateTimeInterface $createdAt): self | |
{ | |
$this->createdAt = $createdAt; | |
return $this; | |
} | |
public function getUpdatedAt(): ?\DateTimeInterface | |
{ | |
return $this->updatedAt; | |
} | |
public function setUpdatedAt(\DateTimeInterface $updatedAt): self | |
{ | |
$this->updatedAt = $updatedAt; | |
return $this; | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment