]> git.immae.eu Git - github/wallabag/wallabag.git/blobdiff - src/Wallabag/ApiBundle/Controller/EntryRestController.php
Splitted the endpoint in two
[github/wallabag/wallabag.git] / src / Wallabag / ApiBundle / Controller / EntryRestController.php
index 3833ce3c8af129c2b17bcec8e18234d54edb0e4d..0c98c242ada0f3aa7077978d7670537ba39535d3 100644 (file)
@@ -173,68 +173,96 @@ class EntryRestController extends WallabagRestController
     }
 
     /**
-     * Handles an entries list and create or remove URL.
+     * Handles an entries list and delete URL.
      *
      * @ApiDoc(
      *       parameters={
-     *          {"name"="list", "dataType"="string", "required"=true, "format"="A JSON array of urls [{'url': 'http://...', 'action': 'delete'}, {'url': 'http://...', 'action': 'add'}]", "description"="Urls (as an array) to handle."}
+     *          {"name"="urls", "dataType"="string", "required"=true, "format"="A JSON array of urls [{'url': 'http://...'}, {'url': 'http://...'}]", "description"="Urls (as an array) to delete."}
      *       }
      * )
      *
      * @return JsonResponse
      */
-    public function postEntriesListAction(Request $request)
+    public function deleteEntriesListAction(Request $request)
     {
         $this->validateAuthentication();
 
-        $list = json_decode($request->query->get('list', []));
+        $urls = json_decode($request->query->get('urls', []));
         $results = [];
 
         // handle multiple urls
-        if (!empty($list)) {
+        if (!empty($urls)) {
             $results = [];
-            foreach ($list as $key => $element) {
+            foreach ($urls as $key => $url) {
                 $entry = $this->get('wallabag_core.entry_repository')->findByUrlAndUserId(
-                    $element->url,
+                    $url,
                     $this->getUser()->getId()
                 );
 
-                $results[$key]['url'] = $element->url;
-                $results[$key]['action'] = $element->action;
+                $results[$key]['url'] = $url;
 
-                switch ($element->action) {
-                    case 'delete':
-                        if (false !== $entry) {
-                            $em = $this->getDoctrine()->getManager();
-                            $em->remove($entry);
-                            $em->flush();
+                if (false !== $entry) {
+                    $em = $this->getDoctrine()->getManager();
+                    $em->remove($entry);
+                    $em->flush();
 
-                            // entry deleted, dispatch event about it!
-                            $this->get('event_dispatcher')->dispatch(EntryDeletedEvent::NAME, new EntryDeletedEvent($entry));
-                        }
+                    // entry deleted, dispatch event about it!
+                    $this->get('event_dispatcher')->dispatch(EntryDeletedEvent::NAME, new EntryDeletedEvent($entry));
+                }
 
-                        $results[$key]['entry'] = $entry instanceof Entry ? true : false;
+                $results[$key]['entry'] = $entry instanceof Entry ? true : false;
+            }
+        }
 
-                        break;
-                    case 'add':
-                        if (false === $entry) {
-                            $entry = $this->get('wallabag_core.content_proxy')->updateEntry(
-                                new Entry($this->getUser()),
-                                $element->url
-                            );
-                        }
+        $json = $this->get('serializer')->serialize($results, 'json');
+
+        return (new JsonResponse())->setJson($json);
+    }
+
+    /**
+     * Handles an entries list and create URL.
+     *
+     * @ApiDoc(
+     *       parameters={
+     *          {"name"="urls", "dataType"="string", "required"=true, "format"="A JSON array of urls [{'url': 'http://...'}, {'url': 'http://...'}]", "description"="Urls (as an array) to create."}
+     *       }
+     * )
+     *
+     * @return JsonResponse
+     */
+    public function postEntriesListAction(Request $request)
+    {
+        $this->validateAuthentication();
 
-                        $em = $this->getDoctrine()->getManager();
-                        $em->persist($entry);
-                        $em->flush();
+        $urls = json_decode($request->query->get('urls', []));
+        $results = [];
 
-                        $results[$key]['entry'] = $entry instanceof Entry ? $entry->getId() : false;
+        // handle multiple urls
+        if (!empty($urls)) {
+            $results = [];
+            foreach ($urls as $key => $url) {
+                $entry = $this->get('wallabag_core.entry_repository')->findByUrlAndUserId(
+                    $url,
+                    $this->getUser()->getId()
+                );
 
-                        // entry saved, dispatch event about it!
-                        $this->get('event_dispatcher')->dispatch(EntrySavedEvent::NAME, new EntrySavedEvent($entry));
+                $results[$key]['url'] = $url;
 
-                        break;
+                if (false === $entry) {
+                    $entry = $this->get('wallabag_core.content_proxy')->updateEntry(
+                        new Entry($this->getUser()),
+                        $url
+                    );
                 }
+
+                $em = $this->getDoctrine()->getManager();
+                $em->persist($entry);
+                $em->flush();
+
+                $results[$key]['entry'] = $entry instanceof Entry ? $entry->getId() : false;
+
+                // entry saved, dispatch event about it!
+                $this->get('event_dispatcher')->dispatch(EntrySavedEvent::NAME, new EntrySavedEvent($entry));
             }
         }