]> git.immae.eu Git - github/wallabag/wallabag.git/blobdiff - src/Wallabag/ApiBundle/Controller/EntryRestController.php
Added endpoint to handle URL list to add/delete tags
[github/wallabag/wallabag.git] / src / Wallabag / ApiBundle / Controller / EntryRestController.php
index fc46e782efb6cb29c5a6843c455e2d99b65ab3aa..5ccaa4ef885d12937c8005c1a106a300ac4b5d82 100644 (file)
@@ -440,17 +440,17 @@ class EntryRestController extends WallabagRestController
     }
 
     /**
-     * Handles an entries list and add / delete to them some tags.
+     * Handles an entries list delete tags from them.
      *
      * @ApiDoc(
      *       parameters={
-     *          {"name"="list", "dataType"="string", "required"=true, "format"="A JSON array of urls [{'url': 'http://...','tags': 'tag1, tag2','action': 'delete'}, {'url': 'http://...','tags': 'tag1, tag2','action': 'add'}]", "description"="Urls (as an array) to handle."}
+     *          {"name"="list", "dataType"="string", "required"=true, "format"="A JSON array of urls [{'url': 'http://...','tags': 'tag1, tag2'}, {'url': 'http://...','tags': 'tag1, tag2'}]", "description"="Urls (as an array) to handle."}
      *       }
      * )
      *
      * @return JsonResponse
      */
-    public function postEntriesTagsListAction(Request $request)
+    public function deleteEntriesTagsListAction(Request $request)
     {
         $this->validateAuthentication();
 
@@ -467,32 +467,22 @@ class EntryRestController extends WallabagRestController
                 );
 
                 $results[$key]['url'] = $element->url;
-                $results[$key]['action'] = $element->action;
                 $results[$key]['entry'] = $entry instanceof Entry ? $entry->getId() : false;
 
                 $tags = $element->tags;
 
                 if (false !== $entry && !(empty($tags))) {
-                    switch ($element->action) {
-                        case 'delete':
-                            $tags = explode(',', $tags);
-                            foreach ($tags as $label) {
-                                $label = trim($label);
-
-                                $tag = $this->getDoctrine()
-                                    ->getRepository('WallabagCoreBundle:Tag')
-                                    ->findOneByLabel($label);
-
-                                if (false !== $tag) {
-                                    $entry->removeTag($tag);
-                                }
-                            }
-
-                            break;
-                        case 'add':
-                            $this->get('wallabag_core.content_proxy')->assignTagsToEntry($entry, $tags);
-
-                            break;
+                    $tags = explode(',', $tags);
+                    foreach ($tags as $label) {
+                        $label = trim($label);
+
+                        $tag = $this->getDoctrine()
+                            ->getRepository('WallabagCoreBundle:Tag')
+                            ->findOneByLabel($label);
+
+                        if (false !== $tag) {
+                            $entry->removeTag($tag);
+                        }
                     }
 
                     $em = $this->getDoctrine()->getManager();
@@ -506,4 +496,51 @@ class EntryRestController extends WallabagRestController
 
         return (new JsonResponse())->setJson($json);
     }
+
+    /**
+     * Handles an entries list and add tags to them.
+     *
+     * @ApiDoc(
+     *       parameters={
+     *          {"name"="list", "dataType"="string", "required"=true, "format"="A JSON array of urls [{'url': 'http://...','tags': 'tag1, tag2'}, {'url': 'http://...','tags': 'tag1, tag2'}]", "description"="Urls (as an array) to handle."}
+     *       }
+     * )
+     *
+     * @return JsonResponse
+     */
+    public function postEntriesTagsListAction(Request $request)
+    {
+        $this->validateAuthentication();
+
+        $list = json_decode($request->query->get('list', []));
+        $results = [];
+
+        // handle multiple urls
+        if (!empty($list)) {
+            $results = [];
+            foreach ($list as $key => $element) {
+                $entry = $this->get('wallabag_core.entry_repository')->findByUrlAndUserId(
+                    $element->url,
+                    $this->getUser()->getId()
+                );
+
+                $results[$key]['url'] = $element->url;
+                $results[$key]['entry'] = $entry instanceof Entry ? $entry->getId() : false;
+
+                $tags = $element->tags;
+
+                if (false !== $entry && !(empty($tags))) {
+                    $this->get('wallabag_core.content_proxy')->assignTagsToEntry($entry, $tags);
+
+                    $em = $this->getDoctrine()->getManager();
+                    $em->persist($entry);
+                    $em->flush();
+                }
+            }
+        }
+
+        $json = $this->get('serializer')->serialize($results, 'json');
+
+        return (new JsonResponse())->setJson($json);
+    }
 }