view->headTitle()->append('Connexion'); $form = new Form_Login(); $this->view->form = $form; $request = $this->getRequest(); //print_r($request->getParams());exit; if ($request->isPost()) { $formData = $request->getPost(); if ($form->isValid($formData)) { $login = $form->getValue('login'); $pass = $form->getValue('pass'); $auth = Zend_Auth::getInstance(); $authAdapter = new WebAuthAdapter($login, md5($login.'|'.$pass)); $result = $auth->authenticate($authAdapter); if (!$result->isValid()){ $this->view->message = ''; Zend_Registry::get('firebug')->info($result); foreach ($result->getMessages() as $message) { $this->view->message.= $message."
"; } } else { $timeout = $auth->getIdentity()->timeout; //Ecrit un cookie persistant valide pendant le temps definit Zend_Session::rememberMe($timeout); $storage = new Zend_Auth_Storage_Session(); $sessionNamespace = new Zend_Session_Namespace($storage->getNamespace()); $sessionNamespace->setExpirationSeconds($timeout); $auth->setStorage($storage); $url = ''; if (Zend_Session::namespaceIsset('login')){ $session = new Zend_Session_Namespace('login'); if (isset($session->url)) { $url = $session->url; } } if (!empty($url) && $url!='/user/login' && $url!='/localauth' && $url!='/favicon.ico'){ $this->_redirect($url); } $this->_redirect('/'); } } } $this->_helper->layout()->disableLayout(); $this->render('login'); } public function logoutAction() { //Suppression des critères de comptage en session require_once 'Scores/SessionCiblage.php'; $session = new SessionCiblage(); $session->clearCiblage(); //Suppression de l'identité Zend_Auth::getInstance()->clearIdentity(); $this->_helper->layout()->disableLayout(); $url = 'http://www.scores-decisions.com/'; $refresh = 5; if (APPLICATION_ENV != 'production'){ $url = 'http://'.$_SERVER['SERVER_NAME'].$this->view->url(array( 'controller' => 'user', 'action' => 'login', )); } $this->view->assign('url', $url); $this->view->headMeta()->appendHttpEquiv('refresh', '5; url='.$url); $this->render('logout'); } }