X-Git-Url: https://dev.renevier.net/gitweb.cgi?a=blobdiff_plain;ds=sidebyside;f=application%2Fcontrollers%2FGeomController.php;h=b01837c8c50c218e20cb452c59ffc6ff3bebe4dc;hb=d2a6eeefc534a97762d715180d67f915ab204ae6;hp=38d5ce7361240ba9c9f395a76c788d67dcc8ecfc;hpb=190fd621df4920c56a422c03663874cddaa67d64;p=syj.git
diff --git a/application/controllers/GeomController.php b/application/controllers/GeomController.php
index 38d5ce7..b01837c 100644
--- a/application/controllers/GeomController.php
+++ b/application/controllers/GeomController.php
@@ -1,5 +1,5 @@
getResponse();
$idx = $request->idx;
+
$pathMapper = new Syj_Model_PathMapper();
$path = new Syj_Model_Path();
$api = $this->_helper->SyjApi;
- if (!$pathMapper->find($idx, $path)) {
- if ($pathMapper->hasexisted($idx)) {
- $api->setCode(410);
+ $ext = "";
+ $parts = explode('.', $idx);
+ if (count($parts) >= 2) {
+ $ext = end($parts);
+ if (in_array($ext, array('kml', 'gpx', 'json'))) {
+ $idx = implode('.', explode('.', $idx, -1));
} else {
- $api->setCode(404);
+ $ext = "";
+ }
+ }
+
+ if (!$pathMapper->find($idx, $path)) {
+ if (!$pathMapper->findByTitle($idx, $path)) {
+ if ($pathMapper->hasexisted($idx)) {
+ $api->setCode(410);
+ } else {
+ $api->setCode(404);
+ }
+ return;
}
- return;
}
- $api->setCheckIfNoneMatch(true)->setBody(json_encode(
- array('owner' => (string)$path->owner->pseudo, 'geom' => (string)$path->geom)
- ));
+ switch ($ext) {
+ case 'kml':
+ $this->kml($path);
+ break;
+ case 'gpx':
+ $this->gpx($path);
+ break;
+ case 'json':
+ default:
+ $this->json($path);
+ return;
+ break;
+ }
+ }
+
+ protected function kml(Syj_Model_Path $path) {
+ $data = '' . PHP_EOL; // <-- vim syntax goes crazy
+ $data .= '';
+ $data .= '';
+ if ($path->creator) {
+ $data .= ''
+ . htmlspecialchars($path->creator->pseudo, ENT_COMPAT, "UTF-8")
+ . '';
+ }
+ $data .= '' . htmlspecialchars($path->displayTitle, ENT_COMPAT, "UTF-8") . '';
+ $data .= $path->geom->toKML();
+ $data .= '';
+ $data .= '';
+
+ $api = $this->_helper->SyjApi;
+ $api->setCheckIfNoneMatch(true)->setContentType('application/vnd.google-earth.kml+xml')->setBody($data);
+ }
+
+ protected function gpx(Syj_Model_Path $path) {
+ $data = '' . PHP_EOL; // <-- vim syntax goes crazy
+ $data .= '';
+ $data .= '';
+ if ($path->creator) {
+ $data .= '' . htmlspecialchars($path->creator->pseudo, ENT_COMPAT, "UTF-8") . '';
+ }
+ $data .= '' . htmlspecialchars($path->displayTitle, ENT_COMPAT, "UTF-8") . '';
+ $data .= $path->geom->toGPX();
+ $data .= '';
+ $data .= '';
+
+ $api = $this->_helper->SyjApi;
+ $api->setCheckIfNoneMatch(true)->setContentType('application/gpx+xml')->setBody($data);
}
+
+ protected function json(Syj_Model_Path $path) {
+ $data = json_decode($path->geom->toGeoJSON());
+ $data->title = (string)$path->displayTitle;
+ if ($path->creator) {
+ $data->creator = (string)$path->creator->pseudo;
+ }
+ $api = $this->_helper->SyjApi;
+ $api->setCheckIfNoneMatch(true)->setBodyJson($data);
+ }
+
}