--- /dev/null
+<?php
+
+namespace Wallabag\AnnotationBundle\Controller;
+
+use FOS\RestBundle\Controller\FOSRestController;
+use Nelmio\ApiDocBundle\Annotation\ApiDoc;
+use Symfony\Component\HttpFoundation\Request;
+use Symfony\Component\HttpFoundation\Response;
+use Sensio\Bundle\FrameworkExtraBundle\Configuration\ParamConverter;
+use Wallabag\AnnotationBundle\Entity\Annotation;
+use Wallabag\CoreBundle\Entity\Entry;
+
+class WallabagAnnotationController extends FOSRestController
+{
+ /**
+ * Retrieve annotations for an entry.
+ *
+ * @ApiDoc(
+ * requirements={
+ * {"name"="entry", "dataType"="integer", "requirement"="\w+", "description"="The entry ID"}
+ * }
+ * )
+ *
+ * @return Response
+ */
+ public function getAnnotationsAction(Entry $entry)
+ {
+ $annotationRows = $this
+ ->getDoctrine()
+ ->getRepository('WallabagAnnotationBundle:Annotation')
+ ->findAnnotationsByPageId($entry->getId(), $this->getUser()->getId());
+ $total = count($annotationRows);
+ $annotations = array('total' => $total, 'rows' => $annotationRows);
+
+ $json = $this->get('serializer')->serialize($annotations, 'json');
+
+ return $this->renderJsonResponse($json);
+ }
+
+ /**
+ * Creates a new annotation.
+ *
+ * @param Entry $entry
+ *
+ * @ApiDoc(
+ * requirements={
+ * {"name"="ranges", "dataType"="array", "requirement"="\w+", "description"="The range array for the annotation"},
+ * {"name"="quote", "dataType"="string", "required"=false, "description"="Optional, quote for the annotation"},
+ * {"name"="text", "dataType"="string", "required"=true, "description"=""},
+ * }
+ * )
+ *
+ * @return Response
+ */
+ public function postAnnotationAction(Request $request, Entry $entry)
+ {
+ $data = json_decode($request->getContent(), true);
+
+ $em = $this->getDoctrine()->getManager();
+
+ $annotation = new Annotation($this->getUser());
+
+ $annotation->setText($data['text']);
+ if (array_key_exists('quote', $data)) {
+ $annotation->setQuote($data['quote']);
+ }
+ if (array_key_exists('ranges', $data)) {
+ $annotation->setRanges($data['ranges']);
+ }
+
+ $annotation->setEntry($entry);
+
+ $em->persist($annotation);
+ $em->flush();
+
+ $json = $this->get('serializer')->serialize($annotation, 'json');
+
+ return $this->renderJsonResponse($json);
+ }
+
+ /**
+ * Updates an annotation.
+ *
+ * @ApiDoc(
+ * requirements={
+ * {"name"="annotation", "dataType"="string", "requirement"="\w+", "description"="The annotation ID"}
+ * }
+ * )
+ *
+ * @ParamConverter("annotation", class="WallabagAnnotationBundle:Annotation")
+ *
+ * @return Response
+ */
+ public function putAnnotationAction(Annotation $annotation, Request $request)
+ {
+ $data = json_decode($request->getContent(), true);
+
+ if (!is_null($data['text'])) {
+ $annotation->setText($data['text']);
+ }
+
+ $em = $this->getDoctrine()->getManager();
+ $em->flush();
+
+ $json = $this->get('serializer')->serialize($annotation, 'json');
+
+ return $this->renderJsonResponse($json);
+ }
+
+ /**
+ * Removes an annotation.
+ *
+ * @ApiDoc(
+ * requirements={
+ * {"name"="annotation", "dataType"="string", "requirement"="\w+", "description"="The annotation ID"}
+ * }
+ * )
+ *
+ * @ParamConverter("annotation", class="WallabagAnnotationBundle:Annotation")
+ *
+ * @return Response
+ */
+ public function deleteAnnotationAction(Annotation $annotation)
+ {
+ $em = $this->getDoctrine()->getManager();
+ $em->remove($annotation);
+ $em->flush();
+
+ $json = $this->get('serializer')->serialize($annotation, 'json');
+
+ return $this->renderJsonResponse($json);
+ }
+
+ /**
+ * Send a JSON Response.
+ * We don't use the Symfony JsonRespone, because it takes an array as parameter instead of a JSON string.
+ *
+ * @param string $json
+ *
+ * @return Response
+ */
+ private function renderJsonResponse($json, $code = 200)
+ {
+ return new Response($json, $code, array('application/json'));
+ }
+}