Fix PersonController.
authorJérôme Benoit <jerome.benoit@piment-noir.org>
Wed, 27 Jun 2018 19:33:31 +0000 (21:33 +0200)
committerJérôme Benoit <jerome.benoit@piment-noir.org>
Wed, 27 Jun 2018 19:33:31 +0000 (21:33 +0200)
Signed-off-by: Jérôme Benoit <jerome.benoit@piment-noir.org>
config/config.yaml
src/Controller/PersonController.php

index f7f08b19c7abcf66837c760a19368d42d6698b64..3c4eb73c1a66088663c5fd68fb75b6c20a0b4d0b 100644 (file)
@@ -10,12 +10,20 @@ fos_rest:
     view:
         formats: { json: true, xml: false, rss: false }
         view_response_listener: true
+        mime_types:
+            json: ['application/json', 'application/json;version=1.0', 'application/json;version=2.0']
     serializer:
         serialize_null: true
     format_listener:
         rules:
             - { path: '^/', priorities: ['json'], fallback_format: 'json' }
     param_fetcher_listener: force
+    versioning:
+        enabled: true
+        resolvers:
+            media_type: # Accept header
+                enabled: true
+                regex: '/(v|version)=(?P<version>[0-9\.]+)/'
 
 sensio_framework_extra:
     view: { annotations: false }
index 43b907874e1eadfdda520c44ccfa0a70bc627a1c..a47df7c50736291fc9ef14ab4a31540673b04b4d 100644 (file)
@@ -12,6 +12,7 @@ use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
 class PersonController extends FOSRestController
 {
     /**
+     * @Rest\Prefix("/api")
      * @Rest\Post(
      *     path = "/person/inscription",
      *     name = "create_person"
@@ -36,10 +37,10 @@ class PersonController extends FOSRestController
     public function removePersonAction(Request $request)
     {
         $em = $this->getDoctrine()->getManager();
-        $person = $em->getRepository('App:Person')->find($request->get('id'));
+        $person = $em->getRepository('App::Person')->find($request->get('id'));
 
-        if ($person) {
-            $em->remove($place);
+        if (!empty($person)) {
+            $em->remove($person);
             $em->flush();
         }
     }
@@ -56,7 +57,7 @@ class PersonController extends FOSRestController
         $em = $this->getDoctrine()->getManager();
         $person = $em->getRepository('App::Person')->find($request->get('id'));
 
-        if (empty($place)) {
+        if (empty($person)) {
             return new JsonResponse(['message' => 'Person not found'], Response::HTTP_NOT_FOUND);
         }
 
@@ -104,8 +105,15 @@ class PersonController extends FOSRestController
     * )
     * @Rest\View()
     */
-   public function showPerson(Person $person)
+   public function showPerson(Request $request)
    {
+       $em = $this->getDoctrine()->getManager();
+       $person = $em->getRepository('App::Person')->find($request->get('id'));
+
+       if (empty($person)) {
+            return new JsonResponse(['message' => 'Person not found'], Response::HTTP_NOT_FOUND);
+        }
+
        return $person;
    }
 
@@ -117,8 +125,15 @@ class PersonController extends FOSRestController
    * )
    * @Rest\View()
    */
-  public function showPersonByEmail(Person $person)
+  public function showPersonByEmail(Request $request)
   {
+      $em = $this->getDoctrine()->getManager();
+      $person = $em->getRepository('App::Person')->find($request->get('email'));
+
+      if (empty($person)) {
+           return new JsonResponse(['message' => 'Person not found'], Response::HTTP_NOT_FOUND);
+       }
+
       return $person;
   }
 
@@ -128,10 +143,17 @@ class PersonController extends FOSRestController
    *     name = "show_person_friends",
    *     requirements = {"id"="\d+"}
    * )
-   * @Rest\View
+   * @Rest\View()
    */
-  public function showPersonFriends(Person $person)
+  public function showPersonFriends(Request $request)
   {
+      $em = $this->getDoctrine()->getManager();
+      $person = $em->getRepository('App::Person')->find($request->get('id'));
+
+      if (empty($person)) {
+           return new JsonResponse(['message' => 'Person not found'], Response::HTTP_NOT_FOUND);
+       }
+
       return $person->getFriends();
   }
 
@@ -141,10 +163,17 @@ class PersonController extends FOSRestController
   *     name = "show_person_friends_by_email",
   *     requirements = {"email"="\s+"}
   * )
-  * @Rest\View
+  * @Rest\View()
   */
- public function showPersonFriendsByEmail(Person $person)
+ public function showPersonFriendsByEmail(Request $request)
  {
+     $em = $this->getDoctrine()->getManager();
+     $person = $em->getRepository('App::Person')->find($request->get('email'));
+
+     if (empty($person)) {
+          return new JsonResponse(['message' => 'Person not found'], Response::HTTP_NOT_FOUND);
+      }
+
      return $person->getFriends();
  }
 }