public function verAction() { $menu = new Sige_Mobile_Menu($this->view, "participante"); $this->view->menu = $menu; $model = new Application_Model_Pessoa(); $id = $this->_getParam('id', ""); if (!empty($id)) { if (is_numeric($id)) { $sql = $model->getAdapter()->quoteInto('id_pessoa = ?', $id); } else { $sql = $model->getAdapter()->quoteInto('twitter = ?', $id); } } else { if (Zend_Auth::getInstance()->hasIdentity()) { $sessao = Zend_Auth::getInstance()->getIdentity(); if (!empty($sessao["twitter"])) { $sql = $model->getAdapter()->quoteInto('twitter = ?', $sessao["twitter"]); $id = $sessao["twitter"]; } else { $sql = $model->getAdapter()->quoteInto('id_pessoa = ?', $sessao["idPessoa"]); $id = $sessao["idPessoa"]; } } else { $this->_helper->flashMessenger->addMessage(array('danger' => 'Participante não encontrado.')); return; } } $this->view->id = $id; $this->view->user = $model->fetchRow($sql); }
/** * Mapeada como: * /u/confirmar/:id * /u/desfazer-confirmar/:id * @return type */ public function presencaAction() { if (!$this->autenticacao(true)) { return; } $id = $this->_getParam('id', 0); $confirmar = $this->_getParam('confirmar', 'f'); $cache = Zend_Registry::get('cache_common'); $ps = $cache->load('prefsis'); $idEncontro = (int) $ps->encontro["id_encontro"]; $model = new Application_Model_Pessoa(); try { if ($confirmar == 't') { $data = 'now()'; $this->view->msg = $this->t->_("Participant confirmed."); } else { $data = 'null'; $this->view->msg = $this->t->_("Participant confirmation undone."); } $select = "UPDATE encontro_participante SET confirmado = ?,\n data_confirmacao = {$data} where id_pessoa = ? AND id_encontro = ?"; $model->getAdapter()->query($select, array($confirmar, $id, $idEncontro)); $this->view->ok = true; } catch (Exception $e) { $this->view->ok = false; $this->view->erro = "Ocorreu um erro inesperado ao marcar interesse em <b>evento</b>.<br/>Detalhes" . $e->getMessage(); } }
public function editarPermissaoAction() { $this->autenticacao(); $this->view->title = $this->t->_('Edit Permission'); $cache = Zend_Registry::get('cache_common'); $ps = $cache->load('prefsis'); $idEncontro = (int) $ps->encontro["id_encontro"]; $model = new Application_Model_Pessoa(); $form = new Admin_Form_Permissao(); $this->view->form = $form; if ($this->getRequest()->isPost()) { $formData = $this->getRequest()->getPost(); if ($form->isValid($formData)) { $cancelar = $this->getRequest()->getPost('cancelar'); if (isset($cancelar)) { return $this->_helper->redirector->goToRoute(array('module' => 'admin', 'controller' => 'config', 'action' => 'permissao-usuarios'), 'default', true); } $id = $this->getRequest()->getParam('id', 0); $admin = (bool) $form->getValue('admin') ? 't' : 'f'; $id_tipo_usuario = $form->getValue('id_tipo_usuario'); $adapter = $model->getAdapter(); try { $adapter->beginTransaction(); $model->update(array('administrador' => $admin), 'id_pessoa = ' . $id); $adapter->update("encontro_participante", array('id_tipo_usuario' => $id_tipo_usuario), "id_encontro = {$idEncontro} AND id_pessoa = {$id}"); $adapter->commit(); return $this->_helper->redirector->goToRoute(array('module' => 'admin', 'controller' => 'config', 'action' => 'permissao-usuarios'), 'default', true); } catch (Exception $e) { $this->_helper->flashMessenger->addMessage(array('danger' => 'Ocorreu um erro inesperado.<br/>Detalhes: ' . $e->getMessage())); $adapter->rollBack(); } } else { $form->populate($formData); } } else { $id = $this->_getParam('id', 0); if ($id > 0) { $rs = $model->buscarPermissaoUsuarios($idEncontro, $id, "id_pessoa"); $data = $rs[0]; $form->populate(array('admin' => $data['administrador'], 'id_tipo_usuario' => $data['id_tipo_usuario'])); $this->view->usuario = $data['nome']; } } }
/** * 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 certificadosAction() { $this->autenticacao(); $sessao = Zend_Auth::getInstance()->getIdentity(); $id_pessoa = $sessao["idPessoa"]; $this->view->menu->setAtivo('certificados'); $model = new Application_Model_Participante(); $this->view->certsParticipanteEncontro = $model->listarCertificadosParticipanteEncontro($id_pessoa); $this->view->certsParticipanteEvento = $model->listarCertificadosParticipanteEvento($id_pessoa); // $this->view->certsPalestrante = array_merge($model->listarCertificadosPalestrante($id_pessoa), $model->listarCertificadosPalestrantesOutros($id_pessoa), $model->listarCertificadosPalestrantesArtigos($id_pessoa)); $this->view->certsPalestrante = array_merge($model->listarCertificadosPalestrante($id_pessoa), $model->listarCertificadosPalestrantesOutros($id_pessoa)); $this->view->id = $id_pessoa; $pessoa = new Application_Model_Pessoa(); $sql = $pessoa->getAdapter()->quoteInto('id_pessoa = ?', $id_pessoa); $this->view->user = $pessoa->fetchRow($sql); }