Приложение User Demo использует ORM Doctrine для управления базой данных. О том, как использовать Doctrine, мы уже узнали в главе Управление базой данных с помощью ORM Doctrine.
Для хранения в базе данных информации о пользователях, мы создадим сущность User
. Она сопоставляется
с таблицей БД user
и является типичным классом сущности Doctrine.
Создайте файл User.php в каталоге Entity под корневым каталогом модуля. Поместите в этот файл следующий код:
<?php
namespace User\Entity;
use Doctrine\ORM\Mapping as ORM;
/**
* Этот класс представляет собой зарегистрированного пользователя.
* @ORM\Entity()
* @ORM\Table(name="user")
*/
class User
{
// Константы статуса пользователя.
const STATUS_ACTIVE = 1; // Активный пользователь.
const STATUS_RETIRED = 2; // Неактивный пользователь.
/**
* @ORM\Id
* @ORM\Column(name="id")
* @ORM\GeneratedValue
*/
protected $id;
/**
* @ORM\Column(name="email")
*/
protected $email;
/**
* @ORM\Column(name="full_name")
*/
protected $fullName;
/**
* @ORM\Column(name="password")
*/
protected $password;
/**
* @ORM\Column(name="status")
*/
protected $status;
/**
* @ORM\Column(name="date_created")
*/
protected $dateCreated;
/**
* @ORM\Column(name="pwd_reset_token")
*/
protected $passwordResetToken;
/**
* @ORM\Column(name="pwd_reset_token_creation_date")
*/
protected $passwordResetTokenCreationDate;
/**
* Возвращает ID пользователя.
* @return integer
*/
public function getId()
{
return $this->id;
}
/**
* Задает ID пользователя.
* @param int $id
*/
public function setId($id)
{
$this->id = $id;
}
/**
* Возвращает адрес эл. почты.
* @return string
*/
public function getEmail()
{
return $this->email;
}
/**
* Задает адрес эл. почты.
* @param string $email
*/
public function setEmail($email)
{
$this->email = $email;
}
/**
* Возвращает полное имя.
* @return string
*/
public function getFullName()
{
return $this->fullName;
}
/**
* Задает полное имя.
* @param string $fullName
*/
public function setFullName($fullName)
{
$this->fullName = $fullName;
}
/**
* Возвращает статус.
* @return int
*/
public function getStatus()
{
return $this->status;
}
/**
* Возвращает возможные статусы в виде массива.
* @return array
*/
public static function getStatusList()
{
return [
self::STATUS_ACTIVE => 'Active',
self::STATUS_RETIRED => 'Retired'
];
}
/**
* Возвращает статус пользователя в виде строки.
* @return string
*/
public function getStatusAsString()
{
$list = self::getStatusList();
if (isset($list[$this->status]))
return $list[$this->status];
return 'Unknown';
}
/**
* Устанавливает статус.
* @param int $status
*/
public function setStatus($status)
{
$this->status = $status;
}
/**
* Возвращает пароль.
* @return string
*/
public function getPassword()
{
return $this->password;
}
/**
* Задает пароль.
* @param string $password
*/
public function setPassword($password)
{
$this->password = $password;
}
/**
* Возвращает дату создания пользователя.
* @return string
*/
public function getDateCreated()
{
return $this->dateCreated;
}
/**
* Задает дату создания пользователя.
* @param string $dateCreated
*/
public function setDateCreated($dateCreated)
{
$this->dateCreated = $dateCreated;
}
/**
* Возвращает токен сброса пароля.
* @return string
*/
public function getResetPasswordToken()
{
return $this->passwordResetToken;
}
/**
* Задает токен сброса пароля.
* @param string $token
*/
public function setPasswordResetToken($token)
{
$this->passwordResetToken = $token;
}
/**
* Возвращает дату создания токена сброса пароля.
* @return string
*/
public function getPasswordResetTokenCreationDate()
{
return $this->passwordResetTokenCreationDate;
}
/**
* Задает дату создания токена сброса пароля.
* @param string $date
*/
public function setPasswordResetTokenCreationDate($date)
{
$this->passwordResetTokenCreationDate = $date;
}
}
Как можете понять из фрагмента кода выше, сущность User - это типичная сущность Doctrine, содержащая свойства с аннотациями, а также геттеры и сеттеры для извлечения/задания этих свойств.