X-Git-Url: https://dev.renevier.net/?a=blobdiff_plain;f=application%2Fcontrollers%2FIdxController.php;h=9dc4300fbd634c2de2c77ea6e9d776b51d9eae90;hb=ce001229accb2aff799560eec402344f0dbb1762;hp=e606ebc260efd54f53422dd57c73c4fb5e08f1e5;hpb=1de0f433144272946051bb0df886b8c43459beb8;p=syj.git diff --git a/application/controllers/IdxController.php b/application/controllers/IdxController.php index e606ebc..9dc4300 100644 --- a/application/controllers/IdxController.php +++ b/application/controllers/IdxController.php @@ -20,7 +20,7 @@ class IdxController extends Zend_Controller_Action public function indexAction() { $url = $this->getRequest()->getUserParam('url'); - $geomform = new Syj_Form_Geom(array('name' => 'geomform', 'action' => 'path')); + $geomform = new Syj_Form_Geom(array('name' => 'geomform')); $loginform = new Syj_Form_Login(array('name' => 'loginform', 'action' => 'login')); $userform = new Syj_Form_User(array('name' => 'userform', 'action' => 'user')); $newpwdform = new Syj_Form_Newpwd(array('name' => 'newpwdform', 'action' => 'newpwd')); @@ -35,13 +35,14 @@ class IdxController extends Zend_Controller_Action throw new Syj_Exception_NotFound('Not Found', 404); } } + $geomform->setAction('path/' . (string)$path->id . '/update'); $title = $path->displayTitle; $this->view->path = $path; $geomform->geom_title->setValue($path->title); $geomform->geom_data->setValue((string)$path->geom); - $geomform->geom_id->setValue((string)$path->id); $loginform->login_geom_id->setValue((string)$path->id); } else { + $geomform->setAction('path'); $extent = new phptojs\JsObject('gMaxExtent', $this->_helper->syjGeoip($this->getRequest()->getClientIp(true))); $this->view->headScript()->prependScript((string) $extent); $title = "Show your journey"; @@ -54,38 +55,26 @@ class IdxController extends Zend_Controller_Action $this->view->loginform = $loginform; $this->view->userform = $userform; $this->view->newpwdform = $newpwdform; + $this->view->loggedUser = $this->_helper->SyjSession->user(); } protected function _jsLoggedInfo(Syj_Model_Path $path = null) { $loggedinfo = new phptojs\JsObject('gLoggedInfo', array('connections' => 0)); - $sessionStorage = Zend_Auth::getInstance()->getStorage(); - $sessionData = $sessionStorage->read(); - - if ($sessionStorage->isEmpty()) { - $loggedinfo->logged = false; + $user = $this->_helper->SyjSession->user(); + if ($user) { + $loggedinfo->logged = true; } else { - $userMapper = new Syj_Model_UserMapper(); - $obj = new Syj_Model_User(); - if ($userMapper->find($sessionData['user'], $obj)) { - $loggedinfo->logged = true; - } else { - // non existent user - Zend_Session::start(); - Zend_Session::destroy(); - $loggedinfo->logged = false; - } + $loggedinfo->logged = false; } if (isset($path)) { - if ($path->owner->id == $sessionData['user']) { - $loggedinfo->isowner = true; - } else { - $loggedinfo->isowner = false; + $loggedinfo->iscreator = $path->isCreator($user); + if ($path->creator) { + $loggedinfo->creatorname = $this->view->escape((string)$path->creator->pseudo); } - $loggedinfo->ownername = $this->view->escape((string)$path->owner->pseudo); } else { - $loggedinfo->isowner = true; + $loggedinfo->iscreator = true; } $this->view->headScript()->prependScript((string) $loggedinfo); @@ -95,7 +84,7 @@ class IdxController extends Zend_Controller_Action $this->view->jslocales = array( 'saveSuccess' => __("save took place successfully"), 'requestError' => __("server did not understood request. That's probably caused by a bug in SYJ"), - 'UnreferencedError' => __("path did not exist in the server. May be it has been already deleted"), + 'gonePathError' => __("route not referenced on the server. It has probably been deleted."), 'uniquePathError' => __("similar path seems to already exist. Please do not create two exactly identical paths"), 'notReachedError' => __("server could not be reached"), 'serverError' => __("there was a server error"), @@ -103,21 +92,20 @@ class IdxController extends Zend_Controller_Action 'userEmptyWarn' => __("you must enter a login name"), 'loginSuccess' => __("Login correct"), 'loginFailure' => __("Wrong login/password"), - 'loginNeeded' => __("You need to login before retrying to save"), - 'cookiesNeeded' => __("You need to have cookies enabled to login to SYJ"), 'passwordEmptyWarn' => __("you must enter a password"), 'passwordNoMatchWarn' => __("Password do not match"), 'acceptTermsofuseWarn' => __("You must accept terms of use"), 'emailEmptyWarn' => __("you must enter an email"), 'emailInvalidWarn' => __("invalid email"), - 'invalidPseudo' => __("pseudo must only contain letters, digits, dots or underscores"), - 'uniqueUserError' => __("unavailable pseudo"), 'uniqueEmailError' => __("an user is already registered with this email"), 'userSuccess' => __("Account created"), 'newpwdSuccess' => __("A link to reset your password has been emailed to you"), 'canResubmit' => __("Now, you can retry to save"), 'routeBy' => __("route by"), - 'osmAttribution' => __("Map by OpenStreetMap") + 'osmAttribution' => __("Map by OpenStreetMap"), + 'pseudoChecking' => __("checking availibilty"), + 'availablePseudo' => __("available pseudo"), + 'unavailablePseudo' => __("unavailable pseudo"), ); }