X-Git-Url: https://dev.renevier.net/gitweb.cgi?a=blobdiff_plain;ds=inline;f=application%2Fcontrollers%2FGeomController.php;h=b01837c8c50c218e20cb452c59ffc6ff3bebe4dc;hb=a0c085f9492929c7b2bd6ada5cd1186d3133a44e;hp=f97d016c554ee0f950723d97b8c920c7395cd01e;hpb=d501fa8a29291499c668bed9ddfcb4fc328b2e25;p=syj.git
diff --git a/application/controllers/GeomController.php b/application/controllers/GeomController.php
index f97d016..b01837c 100644
--- a/application/controllers/GeomController.php
+++ b/application/controllers/GeomController.php
@@ -1,5 +1,5 @@
find($idx, $path)) {
- if ($pathMapper->hasexisted($idx)) {
- $api->setCode(410);
- } else {
- $api->setCode(404);
+ if (!$pathMapper->findByTitle($idx, $path)) {
+ if ($pathMapper->hasexisted($idx)) {
+ $api->setCode(410);
+ } else {
+ $api->setCode(404);
+ }
+ return;
}
- return;
}
switch ($ext) {
@@ -56,9 +58,11 @@ class GeomController extends Zend_Controller_Action
$data .= '';
$data .= '';
if ($path->creator) {
- $data .= '' . htmlspecialchars($path->creator->pseudo) . '';
+ $data .= ''
+ . htmlspecialchars($path->creator->pseudo, ENT_COMPAT, "UTF-8")
+ . '';
}
- $data .= '' . htmlspecialchars($path->displayTitle) . '';
+ $data .= '' . htmlspecialchars($path->displayTitle, ENT_COMPAT, "UTF-8") . '';
$data .= $path->geom->toKML();
$data .= '';
$data .= '';
@@ -67,11 +71,27 @@ class GeomController extends Zend_Controller_Action
$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 = array('geom' => (string)$path->geom,
- 'title' => (string)$path->displayTitle);
+ $data = json_decode($path->geom->toGeoJSON());
+ $data->title = (string)$path->displayTitle;
if ($path->creator) {
- $data['creator'] = (string)$path->creator->pseudo;
+ $data->creator = (string)$path->creator->pseudo;
}
$api = $this->_helper->SyjApi;
$api->setCheckIfNoneMatch(true)->setBodyJson($data);