X-Git-Url: https://dev.renevier.net/gitweb.cgi?a=blobdiff_plain;ds=inline;f=application%2Fcontrollers%2FGeomController.php;h=3f14df907137d7cbab2ec8a83f695ba3d140b653;hb=bfe63b61894a100bd3d83ac86593a8d767b94920;hp=38d5ce7361240ba9c9f395a76c788d67dcc8ecfc;hpb=190fd621df4920c56a422c03663874cddaa67d64;p=syj.git
diff --git a/application/controllers/GeomController.php b/application/controllers/GeomController.php
index 38d5ce7..3f14df9 100644
--- a/application/controllers/GeomController.php
+++ b/application/controllers/GeomController.php
@@ -10,11 +10,23 @@ class GeomController extends Zend_Controller_Action
$response = $this->getResponse();
$idx = $request->idx;
+
$pathMapper = new Syj_Model_PathMapper();
$path = new Syj_Model_Path();
$api = $this->_helper->SyjApi;
+ $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 {
+ $ext = "";
+ }
+ }
+
if (!$pathMapper->find($idx, $path)) {
if ($pathMapper->hasexisted($idx)) {
$api->setCode(410);
@@ -24,8 +36,61 @@ class GeomController extends Zend_Controller_Action
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) . '';
+ }
+ $data .= '' . htmlspecialchars($path->displayTitle) . '';
+ $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) . '';
+ }
+ $data .= '' . htmlspecialchars($path->displayTitle) . '';
+ $data .= $path->geom->toGPX();
+ $data .= '';
+ $data .= '';
+
+ $api = $this->_helper->SyjApi;
+ $api->setCheckIfNoneMatch(true)->setContentType('application/octet-stream')->setBody($data);
+ }
+
+ protected function json(Syj_Model_Path $path) {
+ $data = array('geom' => (string)$path->geom,
+ 'title' => (string)$path->displayTitle);
+ if ($path->creator) {
+ $data['creator'] = (string)$path->creator->pseudo;
+ }
+ $api = $this->_helper->SyjApi;
+ $api->setCheckIfNoneMatch(true)->setBodyJson($data);
+ }
+
}