<?php namespace Wallabag\UserBundle\Entity; use Doctrine\Common\Collections\ArrayCollection; use Doctrine\ORM\Mapping as ORM; use FOS\UserBundle\Model\User as BaseUser; use JMS\Serializer\Annotation\Accessor; use JMS\Serializer\Annotation\Groups; use JMS\Serializer\Annotation\XmlRoot; use Scheb\TwoFactorBundle\Model\Email\TwoFactorInterface; use Scheb\TwoFactorBundle\Model\TrustedComputerInterface; use Symfony\Bridge\Doctrine\Validator\Constraints\UniqueEntity; use Symfony\Component\Security\Core\User\UserInterface; use Wallabag\ApiBundle\Entity\Client; use Wallabag\CoreBundle\Entity\Config; use Wallabag\CoreBundle\Entity\Entry; use Wallabag\CoreBundle\Helper\EntityTimestampsTrait; /** * User. * * @XmlRoot("user") * @ORM\Entity(repositoryClass="Wallabag\UserBundle\Repository\UserRepository") * @ORM\Table(name="`user`") * @ORM\HasLifecycleCallbacks() * * @UniqueEntity("email") * @UniqueEntity("username") */ class User extends BaseUser implements TwoFactorInterface, TrustedComputerInterface { use EntityTimestampsTrait; /** @Serializer\XmlAttribute */ /** * @var int * * @ORM\Column(name="id", type="integer") * @ORM\Id * @ORM\GeneratedValue(strategy="AUTO") * * @Groups({"user_api", "user_api_with_client"}) */ protected $id; /** * @var string * * @ORM\Column(name="name", type="text", nullable=true) * * @Groups({"user_api", "user_api_with_client"}) */ protected $name; /** * @var string * * @Groups({"user_api", "user_api_with_client"}) */ protected $username; /** * @var string * * @Groups({"user_api", "user_api_with_client"}) */ protected $email; /** * @var \DateTime * * @ORM\Column(name="created_at", type="datetime") * * @Groups({"user_api", "user_api_with_client"}) */ protected $createdAt; /** * @var \DateTime * * @ORM\Column(name="updated_at", type="datetime") * * @Groups({"user_api", "user_api_with_client"}) */ protected $updatedAt; /** * @ORM\OneToMany(targetEntity="Wallabag\CoreBundle\Entity\Entry", mappedBy="user", cascade={"remove"}) */ protected $entries; /** * @ORM\OneToOne(targetEntity="Wallabag\CoreBundle\Entity\Config", mappedBy="user", cascade={"remove"}) */ protected $config; /** * @var ArrayCollection * * @ORM\OneToMany(targetEntity="Wallabag\CoreBundle\Entity\SiteCredential", mappedBy="user", cascade={"remove"}) */ protected $siteCredentials; /** * @var ArrayCollection * * @ORM\OneToMany(targetEntity="Wallabag\ApiBundle\Entity\Client", mappedBy="user", cascade={"remove"}) */ protected $clients; /** * @see getFirstClient() below * * @Groups({"user_api_with_client"}) * @Accessor(getter="getFirstClient") */ protected $default_client; /** * @ORM\Column(type="integer", nullable=true) */ private $authCode; /** * @var bool * * @ORM\Column(type="boolean") */ private $twoFactorAuthentication = false; /** * @ORM\Column(type="json_array", nullable=true) */ private $trusted; public function __construct() { parent::__construct(); $this->entries = new ArrayCollection(); $this->roles = ['ROLE_USER']; } /** * Set name. * * @param string $name * * @return User */ public function setName($name) { $this->name = $name; return $this; } /** * Get name. * * @return string */ public function getName() { return $this->name; } /** * @return \DateTime */ public function getCreatedAt() { return $this->createdAt; } /** * @return \DateTime */ public function getUpdatedAt() { return $this->updatedAt; } /** * @param Entry $entry * * @return User */ public function addEntry(Entry $entry) { $this->entries[] = $entry; return $this; } /** * @return ArrayCollection<Entry> */ public function getEntries() { return $this->entries; } public function isEqualTo(UserInterface $user) { return $this->username === $user->getUsername(); } /** * Set config. * * @param Config $config * * @return User */ public function setConfig(Config $config = null) { $this->config = $config; return $this; } /** * Get config. * * @return Config */ public function getConfig() { return $this->config; } /** * @return bool */ public function isTwoFactorAuthentication() { return $this->twoFactorAuthentication; } /** * @param bool $twoFactorAuthentication */ public function setTwoFactorAuthentication($twoFactorAuthentication) { $this->twoFactorAuthentication = $twoFactorAuthentication; } public function isEmailAuthEnabled() { return $this->twoFactorAuthentication; } public function getEmailAuthCode() { return $this->authCode; } public function setEmailAuthCode($authCode) { $this->authCode = $authCode; } public function addTrustedComputer($token, \DateTime $validUntil) { $this->trusted[$token] = $validUntil->format('r'); } public function isTrustedComputer($token) { if (isset($this->trusted[$token])) { $now = new \DateTime(); $validUntil = new \DateTime($this->trusted[$token]); return $now < $validUntil; } return false; } /** * @param Client $client * * @return User */ public function addClient(Client $client) { $this->clients[] = $client; return $this; } /** * @return ArrayCollection<Entry> */ public function getClients() { return $this->clients; } /** * Only used by the API when creating a new user it'll also return the first client (which was also created at the same time). * * @return Client */ public function getFirstClient() { if (!empty($this->clients)) { return $this->clients->first(); } } }