]> git.immae.eu Git - github/wallabag/wallabag.git/commitdiff
relation between tags and entries
authorNicolas Lœuillet <nicolas@loeuillet.org>
Tue, 24 Feb 2015 06:42:09 +0000 (07:42 +0100)
committerNicolas Lœuillet <nicolas@loeuillet.org>
Fri, 6 Mar 2015 19:50:31 +0000 (20:50 +0100)
src/Wallabag/CoreBundle/DataFixtures/ORM/LoadEntryData.php
src/Wallabag/CoreBundle/DataFixtures/ORM/LoadTagData.php [deleted file]
src/Wallabag/CoreBundle/Entity/Entry.php
src/Wallabag/CoreBundle/Entity/Tag.php
src/Wallabag/CoreBundle/Entity/TagsEntries.php [deleted file]
src/Wallabag/CoreBundle/Repository/EntryRepository.php
src/Wallabag/CoreBundle/Tests/Controller/WallabagRestControllerTest.php

index 3be323ed7fc523756ccd9408276c30e576a49254..edab9adcd87aca1ea6d2d8b91282b4717e416127 100644 (file)
@@ -6,6 +6,7 @@ use Doctrine\Common\DataFixtures\AbstractFixture;
 use Doctrine\Common\DataFixtures\OrderedFixtureInterface;
 use Doctrine\Common\Persistence\ObjectManager;
 use Wallabag\CoreBundle\Entity\Entry;
+use Wallabag\CoreBundle\Entity\Tag;
 
 class LoadEntryData extends AbstractFixture implements OrderedFixtureInterface
 {
@@ -37,6 +38,14 @@ class LoadEntryData extends AbstractFixture implements OrderedFixtureInterface
         $entry3->setTitle('test title entry3');
         $entry3->setContent('This is my content /o/');
 
+        $tag1 = new Tag();
+        $tag1->setLabel("foo");
+        $tag2 = new Tag();
+        $tag2->setLabel("bar");
+
+        $entry3->addTag($tag1);
+        $entry3->addTag($tag2);
+
         $manager->persist($entry3);
 
         $this->addReference('entry3', $entry3);
diff --git a/src/Wallabag/CoreBundle/DataFixtures/ORM/LoadTagData.php b/src/Wallabag/CoreBundle/DataFixtures/ORM/LoadTagData.php
deleted file mode 100644 (file)
index 4d9846b..0000000
+++ /dev/null
@@ -1,61 +0,0 @@
-<?php
-
-namespace Wallabag\CoreBundle\DataFixtures\ORM;
-
-use Doctrine\Common\DataFixtures\AbstractFixture;
-use Doctrine\Common\DataFixtures\OrderedFixtureInterface;
-use Doctrine\Common\Persistence\ObjectManager;
-use Wallabag\CoreBundle\Entity\Tag;
-use Wallabag\CoreBundle\Entity\TagsEntries;
-
-class LoadTagData extends AbstractFixture implements OrderedFixtureInterface
-{
-    /**
-     * {@inheritDoc}
-     */
-    public function load(ObjectManager $manager)
-    {
-        $tag1 = new Tag();
-        $tag1->setLabel('foo');
-
-        $manager->persist($tag1);
-
-        $this->addReference('tag1', $tag1);
-
-        $tagsEntries1 = new TagsEntries();
-        $tagsEntries1->setEntryId($this->getReference('entry1'));
-        $manager->persist($tagsEntries1);
-
-        $tag2 = new Tag();
-        $tag2->setLabel('bar');
-
-        $manager->persist($tag2);
-
-        $this->addReference('tag2', $tag2);
-
-        $tagsEntries2 = new TagsEntries();
-        $tagsEntries2->setEntryId($this->getReference('entry2'));
-        $manager->persist($tagsEntries2);
-
-        $tag3 = new Tag();
-        $tag3->setLabel('baz');
-
-        $manager->persist($tag3);
-
-        $this->addReference('tag3', $tag3);
-
-        $tagsEntries3 = new TagsEntries();
-        $tagsEntries3->setEntryId($this->getReference('entry2'));
-        $manager->persist($tagsEntries3);
-
-        $manager->flush();
-    }
-
-    /**
-     * {@inheritDoc}
-     */
-    public function getOrder()
-    {
-        return 30;
-    }
-}
index e0d1b839c6a43d0a6100238d9e057b3797d08514..229a67045b0c04fe7737dcd8cefefaa5020fb50d 100644 (file)
@@ -120,11 +120,8 @@ class Entry
     private $user;
 
     /**
-     * @ORM\ManyToMany(targetEntity="Tag", inversedBy="entries", cascade={"persist", "merge"})
-     * @ORM\JoinTable(name="tags_entries",
-     *   joinColumns={@ORM\JoinColumn(name="entry_id", referencedColumnName="id")},
-     *   inverseJoinColumns={@ORM\JoinColumn(name="tag_id", referencedColumnName="id")}
-     * )
+     * @ORM\ManyToMany(targetEntity="Tag", inversedBy="entries", cascade={"persist"})
+     * @ORM\JoinTable(name="entry_tags")
      */
     private $tags;
 
@@ -407,5 +404,6 @@ class Entry
     public function addTag(Tag $tag)
     {
         $this->tags[] = $tag;
+        $tag->addEntry($this);
     }
 }
index 1cdf4df027cc772dcbedf8f8923276ded593a77a..5aed1fa010008727e3550a6763f710d291ec212f 100644 (file)
@@ -6,6 +6,7 @@ use Doctrine\ORM\Mapping as ORM;
 use JMS\Serializer\Annotation\XmlRoot;
 use JMS\Serializer\Annotation\ExclusionPolicy;
 use JMS\Serializer\Annotation\Expose;
+use Doctrine\Common\Collections\ArrayCollection;
 
 /**
  * Tag
@@ -36,10 +37,14 @@ class Tag
     private $label;
 
     /**
-     * @ORM\ManyToMany(targetEntity="Entry", mappedBy="tags", cascade={"persist", "merge"})
+     * @ORM\ManyToMany(targetEntity="Entry", mappedBy="tags", cascade={"persist"})
      */
     private $entries;
 
+    public function __construct()
+    {
+        $this->entries = new ArrayCollection();
+    }
     /**
      * Get id
      *
@@ -72,4 +77,9 @@ class Tag
     {
         return $this->label;
     }
+
+    public function addEntry(Entry $entry)
+    {
+        $this->entries[] = $entry;
+    }
 }
diff --git a/src/Wallabag/CoreBundle/Entity/TagsEntries.php b/src/Wallabag/CoreBundle/Entity/TagsEntries.php
deleted file mode 100644 (file)
index 589f26f..0000000
+++ /dev/null
@@ -1,81 +0,0 @@
-<?php
-
-namespace Wallabag\CoreBundle\Entity;
-
-use Doctrine\ORM\Mapping as ORM;
-
-/**
- * TagsEntries
- *
- * @ORM\Table(name="tags_entries")
- */
-class TagsEntries
-{
-    /**
-     * @var integer
-     *
-     * @ORM\Column(name="id", type="integer")
-     * @ORM\Id
-     * @ORM\GeneratedValue(strategy="AUTO")
-     */
-    private $id;
-
-    /**
-     *
-     * @ORM\ManyToOne(targetEntity="Entry", inversedBy="tags_entries")
-     * @ORM\JoinColumn(name="entry_id", referencedColumnName="id")
-     *
-     */
-    private $entryId;
-
-    /**
-     *
-     * @ORM\ManyToOne(targetEntity="Tag", inversedBy="tags_entries")
-     * @ORM\JoinColumn(name="tag_id", referencedColumnName="id")
-     *
-     */
-    private $tagId;
-
-    /**
-     * Get id
-     *
-     * @return integer
-     */
-    public function getId()
-    {
-        return $this->id;
-    }
-
-    /**
-     * @return mixed
-     */
-    public function getEntryId()
-    {
-        return $this->entryId;
-    }
-
-    /**
-     * @param mixed $entryId
-     */
-    public function setEntryId($entryId)
-    {
-        $this->entryId = $entryId;
-    }
-
-    /**
-     * @return mixed
-     */
-    public function getTagId()
-    {
-        return $this->tagId;
-    }
-
-    /**
-     * @param mixed $tagId
-     */
-    public function setTagId($tagId)
-    {
-        $this->tagId = $tagId;
-    }
-
-}
index 005142fc568707a9b2e807f390dbf2cca8814fb2..f6f60c6fec2cab86ade3867033df0489ed7eff77 100644 (file)
@@ -118,4 +118,15 @@ class EntryRepository extends EntityRepository
             ->getQuery()
             ->getResult();
     }
+
+    public function findOneWithTags()
+    {
+        $qb = $this->createQueryBuilder('e')
+            ->innerJoin('e.tags', 't')
+            ->addSelect('t');
+
+        return $qb
+            ->getQuery()
+            ->getOneOrNullResult();
+    }
 }
index 4164e5161fb49defb23113b875920587a11d2543..d239005567b41b85eb140cf613dd5f814b1d4cb5 100644 (file)
@@ -150,4 +150,30 @@ class WallabagRestControllerTest extends WallabagTestCase
 
         $this->assertEquals(404, $client->getResponse()->getStatusCode());
     }
+
+    public function testGetTagsEntry()
+    {
+        $client = $this->createClient();
+        $client->request('GET', '/api/salts/admin.json');
+        $salt = json_decode($client->getResponse()->getContent());
+        $headers = $this->generateHeaders('admin', 'test', $salt[0]);
+
+        $entry = $client->getContainer()
+            ->get('doctrine.orm.entity_manager')
+            ->getRepository('WallabagCoreBundle:Entry')
+            ->findOneWithTags();
+
+        if (!$entry) {
+            $this->markTestSkipped('No content found in db.');
+        }
+
+        $tags = array();
+        foreach ($entry->getTags() as $tag) {
+            $tags[] = array('id' => $tag->getId(), 'label' => $tag->getLabel());
+        }
+
+        $client->request('GET', '/api/entries/'.$entry->getId().'/tags', array(), array(), $headers);
+
+        $this->assertEquals(json_encode($tags), $client->getResponse()->getContent());
+    }
 }