protected function mockLogin($username = '******', $password = '******') { $model = new Application_Model_Pessoa(); $resultadoConsulta = $model->avaliaLogin($username, $password); $config = new Zend_Config_Ini(APPLICATION_PATH . '/configs/application.ini', 'staging'); $idEncontro = $config->encontro->codigo; $idPessoa = $resultadoConsulta['id_pessoa']; $administrador = $resultadoConsulta['administrador']; $apelido = $resultadoConsulta['apelido']; $twitter = $resultadoConsulta['twitter']; $auth = Zend_Auth::getInstance(); $storage = $auth->getStorage(); $storage->write(array("idPessoa" => $idPessoa, "administrador" => $administrador, "apelido" => $apelido, "idEncontro" => $idEncontro, "twitter" => $twitter, "email" => $username)); }
/** * Mapeada como * /login */ public function loginAction() { $isMobile = false; $mobile = new Sige_Mobile_Browser(); if ($mobile->isMobile()) { $this->_helper->layout->setLayout('mobile'); $isMobile = true; $form = new Mobile_Form_Login(); $this->_helper->viewRenderer('mobile-login'); } else { $this->_helper->layout->setLayout('twbs3/front-page'); $form = new Application_Form_Login(); } $this->view->form = $form; $data = $this->getRequest()->getPost(); if ($this->getRequest()->isPost() && $form->isValid($data)) { $data = $form->getValues(); $model = new Application_Model_Pessoa(); $resultadoConsulta = $model->avaliaLogin($data['email'], $data['senha']); if ($resultadoConsulta != NULL) { $idPessoa = $resultadoConsulta['id_pessoa']; $administrador = $resultadoConsulta['administrador']; $apelido = $resultadoConsulta['apelido']; $twitter = $resultadoConsulta['twitter']; $cadastro_validado = $resultadoConsulta['cadastro_validado']; if ($cadastro_validado == false) { $where = $model->getAdapter()->quoteInto('id_pessoa = ?', $idPessoa); $model->update(array('cadastro_validado' => true), $where); } $config = new Zend_Config_Ini(APPLICATION_PATH . '/configs/application.ini', APPLICATION_ENV); $idEncontro = $config->encontro->codigo; $result = $model->buscarUltimoEncontro($idPessoa); $irParaEditar = false; // se ultimo encontro do participante for diferente do atual if ($model->verificaEncontro($idEncontro, $idPessoa) == false) { $result['id_encontro'] = intval($idEncontro); // forçar participante validado : issue #32 $result['validado'] = 't'; // true $result['data_validacao'] = new Zend_Db_Expr('now()'); try { $model->getAdapter()->insert("encontro_participante", $result); $this->_helper->flashMessenger->addMessage(array('success' => _('Welcome back. Your registration was confirmed!<br/>Please update your profile data.'))); $irParaEditar = true; $this->_enviarEmailConfirmacaoInscricao($idEncontro, $idPessoa); } catch (Exception $e) { $irParaEditar = false; $this->_helper->flashMessenger->addMessage(array('danger' => $e->getMessage())); } } else { if (!$result['validado']) { // se participante ainda não está validado no encontro // devemos validar $adapter = $model->getAdapter(); $adapter->fetchAll("UPDATE encontro_participante\n SET validado = 't', data_validacao = now()\n WHERE id_pessoa = {$result['id_pessoa']}\n AND id_encontro = {$idEncontro}"); } } $auth = Zend_Auth::getInstance(); $storage = $auth->getStorage(); $storage->write(array("idPessoa" => $idPessoa, "administrador" => $administrador, "apelido" => $apelido, "idEncontro" => $idEncontro, "twitter" => $twitter, "email" => $data['email'])); if ($isMobile) { return $this->_helper->redirector->goToRoute(array(), 'mobile', true); } else { if ($irParaEditar) { return $this->_helper->redirector->goToRoute(array('controller' => 'participante', 'action' => 'editar'), 'default', true); } else { $session = new Zend_Session_Namespace(); if (isset($session->url)) { $this->_redirect($session->url, array('prependBase' => false)); unset($session->url); } else { return $this->_helper->redirector->goToRoute(array('controller' => 'participante', 'action' => 'index'), 'default', true); } } } } else { $this->_helper->flashMessenger->addMessage(array('danger' => _('E-mail or Password incorrect.'))); } } }
public function alterarSenhaAction() { $this->autenticacao(); $sessao = Zend_Auth::getInstance()->getIdentity(); $idPessoa = $sessao["idPessoa"]; $pessoa = new Application_Model_Pessoa(); $form = new Application_Form_AlterarSenha(); $this->view->form = $form; $data = $this->getRequest()->getPost(); if ($this->getRequest()->isPost() && $form->isValid($data)) { $data = $form->getValues(); $email = $sessao["email"]; $resultadoConsulta = $pessoa->avaliaLogin($email, $data['senhaAntiga']); if ($resultadoConsulta != null) { if ($data['senhaNova'] == $data['senhaNovaRepeticao']) { $pessoa->setNovaSenha($resultadoConsulta['id_pessoa'], $data['senhaNova']); $this->_helper->flashMessenger->addMessage(array('success' => _('Password successfully updated!'))); return $this->_helper->redirector->goToRoute(array('controller' => 'participante'), 'default', true); } else { $this->_helper->flashMessenger->addMessage(array('warning' => _('The passwords must match!'))); } } else { $this->_helper->flashMessenger->addMessage(array('danger' => _('Old password incorrect.'))); } } $this->view->id = $idPessoa; $sql = $pessoa->getAdapter()->quoteInto('id_pessoa = ?', $idPessoa); $this->view->user = $pessoa->fetchRow($sql); }