<?php
namespace App\Entity\Users;
use Symfony\Component\Security\Core\User\UserInterface;
use Symfony\Component\Validator\Constraints AS Constraints;
use Symfony\Component\Validator\Constraints AS Assert;
use Doctrine\ORM\Mapping AS ORM;
use Ramsey\Uuid\Uuid;
/**
* @ORM\Entity(repositoryClass="App\Repository\Users\UserRepository")
* @ORM\Table(name="users_user")
* @ORM\HasLifecycleCallbacks()
* @ORM\InheritanceType("JOINED")
* @ORM\DiscriminatorColumn(name="class_name", type="string")
* @ORM\DiscriminatorMap({
"user" = "App\Entity\Users\User",
"admin" = "App\Entity\Users\Administrator",
"member" = "App\Entity\Members\Member"
})
*/
class User implements UserInterface
{
/**
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
* @ORM\Column(type="integer")
*/
private $id;
/**
* @ORM\Column(type="uuid")
* @Assert\Uuid
*/
protected $uuid;
/**
* @var \DateTime
*
* @ORM\Column(type="datetime", nullable=false)
*/
private $created;
/**
* @var \DateTime
*
* @ORM\Column(type="datetime", nullable=true)
*/
private $lastActive;
/**
* @ORM\Column(type="string", unique=true)
* @Constraints\Email()
*/
private $email;
/**
* @ORM\Column(type="string", length=255, nullable=true)
*/
private $password;
/**
* @ORM\Column(type="string", length=60, nullable=false)
*/
private $firstNames;
/**
* @ORM\Column(type="string", length=60, nullable=true)
*/
private $lastName;
/**
* @ORM\Column(type="string", length=32, nullable=false)
*/
private $resetToken;
/**
* @ORM\ManyToOne(targetEntity="Group", inversedBy="users")
* @ORM\JoinColumn(name="group_id", referencedColumnName="id")
**/
private $group;
/**
* @ORM\ManyToMany(targetEntity="Role", inversedBy="users")
* @ORM\JoinTable(name="users_userrole")
* @ORM\JoinColumn(name="user_id", referencedColumnName="id", unique=false)
**/
private $userRoles;
public function __construct()
{
// UUID
if(!$this->getUuid())
{
$uuid = Uuid::uuid1();
$this->setUuid($uuid->toString());
}
// Reset token
if(!$this->resetToken)
$this->resetToken = MD5(uniqid());
// Set some defaults
$this->setCreated(new \DateTime());
}
public function hasPermission($permissionIdentifier = null)
{
if(!$permissionIdentifier)
return false;
if($this->getGroup())
{
if(count($this->getGroup()->getPermissions()))
{
foreach($this->getGroup()->getPermissions() AS $somePermission)
{
if($somePermission->getIdentifier() == $permissionIdentifier)
return true;
}
}
}
return false;
}
public function getName()
{
return $this->getFirstNames();
}
public function getFullName()
{
return implode(" ", array_filter(array(
$this->getFirstNames(),
$this->getLastName()
)));
}
public function getId()
{
return $this->id;
}
public function setUuid($uuid)
{
$this->uuid = $uuid;
return $this;
}
public function getUuid()
{
return $this->uuid;
}
public function setResetToken($resetToken)
{
$this->resetToken = strtoupper($resetToken);
return $this;
}
public function getResetToken()
{
return $this->resetToken;
}
public function getUsername()
{
return $this->email;
}
public function getRoles()
{
return array(
'ROLE_USER'
);
}
public function setPassword(string $password = null)
{
$this->password = $password;
}
public function getPassword()
{
return $this->password;
}
public function getSalt()
{
return null;
}
public function eraseCredentials()
{
}
public function setCreated(\DateTime $created)
{
$this->created = $created;
}
public function getCreated()
{
return $this->created;
}
public function setLastActive(\DateTime $lastActive)
{
$this->lastActive = $lastActive;
}
public function getLastActive()
{
return $this->lastActive;
}
public function getEmail()
{
return $this->email;
}
public function setEmail(string $email)
{
$this->email = $email;
}
public function getLastName()
{
return $this->lastName;
}
public function setLastName(string $lastName)
{
$this->lastName = $lastName;
}
public function getFirstNames()
{
return $this->firstNames;
}
public function setFirstNames(string $firstNames)
{
$this->firstNames = $firstNames;
}
public function setGroup(\App\Entity\Users\Group $group = null)
{
$this->group = $group;
return $this;
}
public function getGroup()
{
return $this->group;
}
public function getUserRoles()
{
return $this->userRoles;
}
public function addUserRole(\App\Entity\Users\Role $userRole)
{
if($this->userRoles->contains($userRole))
return true;
// Add it
$this->userRoles->add($userRole);
$userRole->addUser($this);
}
public function removeUserRole(\App\Entity\Users\Role $userRole)
{
$this->userRoles->removeElement($userRole);
}
}