{
//TODO: Check that the authenticated user is allowed to see the localisation
$em = $this->getDoctrine()->getManager();
- $localisation = $em->getRepository('App:Localisation')->findOneBy(['person' => $request->get('id')]);
+
+ $query = $em->createQuery("SELECT l1 FROM App\Entity\Localisation l1 WHERE l1.person = :person and l1.timestamp = (SELECT MAX(l2.timestamp) FROM App\Entity\Localisation l2 WHERE l2.person = l1.person)");
+ $query->setParameter('person', $request->get('id'));
+ $localisation = $query->getResult();
if (empty($localisation)) {
return $this->PersonLocalisationNotFound();
return $persons;
}
+ /**
+ * @Rest\Put(
+ * path = "/api/person/{id}/online",
+ * name = "set_person_online"
+ * )
+ * @Rest\View(StatusCode = Response::HTTP_CREATED)
+ */
+ public function onlinePersonAction(Request $request)
+ {
+ //TODO: check that the authenticated user have the same id
+ $em = $this->getDoctrine()->getManager();
+ $person = $em->getRepository('App:Person')->find($request->get('id'));
+
+ if (empty($person)) {
+ return $this->PersonNotFound();
+ }
+
+ $person->setOnline(true);
+
+ $em->merge($person);
+ $em->flush();
+ }
+
+ /**
+ * @Rest\Put(
+ * path = "/api/person/{id}/offline",
+ * name = "set_person_offline"
+ * )
+ * @Rest\View(StatusCode = Response::HTTP_CREATED)
+ */
+ public function offlinePersonAction(Request $request)
+ {
+ //TODO: check that the authenticated user have the same id
+ $em = $this->getDoctrine()->getManager();
+ $person = $em->getRepository('App:Person')->find($request->get('id'));
+
+ if (empty($person)) {
+ return $this->PersonNotFound();
+ }
+
+ $person->setOnline(false);
+
+ $em->merge($person);
+ $em->flush();
+ }
+
private function PersonNotFound() {
return View::create(['message' => 'Person not found'], Response::HTTP_NOT_FOUND);
}