From 5f09650eef7bea52b7c54c074c0f873f96e53c86 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Nicolas=20L=C5=93uillet?= Date: Fri, 6 Feb 2015 15:18:54 +0100 Subject: [PATCH] add a real relation between user and entry --- src/Wallabag/CoreBundle/Entity/Entry.php | 41 +++++++++--------------- src/Wallabag/CoreBundle/Entity/User.php | 29 ++++++++++++++++- 2 files changed, 44 insertions(+), 26 deletions(-) diff --git a/src/Wallabag/CoreBundle/Entity/Entry.php b/src/Wallabag/CoreBundle/Entity/Entry.php index a00762cad..937213b44 100644 --- a/src/Wallabag/CoreBundle/Entity/Entry.php +++ b/src/Wallabag/CoreBundle/Entity/Entry.php @@ -81,13 +81,6 @@ class Entry */ private $updatedAt; - /** - * @var string - * - * @ORM\Column(name="user_id", type="decimal", precision=10, scale=0, nullable=true) - */ - private $userId; - /** * @var string * @@ -123,6 +116,19 @@ class Entry */ private $isPublic; + /** + * @ORM\ManyToOne(targetEntity="User", inversedBy="entries") + */ + private $user; + + /* + * @param User $user + */ + public function __construct(User $user) + { + $this->user = $user; + } + /** * Get id * @@ -263,26 +269,11 @@ class Entry } /** - * Set userId - * - * @param string $userId - * @return Entry + * @return User */ - public function setUserId($userId) + public function getUser() { - $this->userId = $userId; - - return $this; - } - - /** - * Get userId - * - * @return string - */ - public function getUserId() - { - return $this->userId; + return $this->user; } /** diff --git a/src/Wallabag/CoreBundle/Entity/User.php b/src/Wallabag/CoreBundle/Entity/User.php index 6abfd3ae4..cfbd57f88 100644 --- a/src/Wallabag/CoreBundle/Entity/User.php +++ b/src/Wallabag/CoreBundle/Entity/User.php @@ -2,6 +2,7 @@ namespace Wallabag\CoreBundle\Entity; +use Doctrine\Common\Collections\ArrayCollection; use Doctrine\ORM\Mapping as ORM; use Symfony\Component\Security\Core\User\UserInterface; use Symfony\Component\Security\Core\User\AdvancedUserInterface; @@ -78,10 +79,16 @@ class User implements AdvancedUserInterface, \Serializable */ private $updatedAt; + /** + * @ORM\OneToMany(targetEntity="Entry", mappedBy="user", cascade={"remove"}) + */ + private $entries; + public function __construct() { $this->isActive = true; - $this->salt = md5(uniqid(null, true)); + $this->salt = md5(uniqid(null, true)); + $this->entries = new ArrayCollection(); } /** @@ -231,6 +238,26 @@ class User implements AdvancedUserInterface, \Serializable return $this->updatedAt; } + /** + * @param Entry $entry + * + * @return User + */ + public function addEntry(Entry $entry) + { + $this->entries[] = $entry; + + return $this; + } + + /** + * @return ArrayCollection + */ + public function getEntries() + { + return $this->entries; + } + /** * @inheritDoc */