예제 #1
0
 public function loginAction()
 {
     if (Zend_Auth::getInstance()->hasIdentity()) {
     } else {
         $this->_helper->layout->disableLayout();
     }
     $form = new Default_Form_Login();
     $this->view->form = $form;
     $this->_flashMessenger = $this->_helper->getHelper('FlashMessenger');
     $this->view->messages = $this->_flashMessenger->getMessages();
     //Verifica se existem dados de POST
     if ($this->getRequest()->getPost()) {
         $data = $this->getRequest()->getPost();
         //Formulário corretamente preenchido?
         if ($form->isValid($data)) {
             $login = $form->getValue('login');
             $senha = $form->getValue('senha');
             $model_user = new Default_Model_Usuario();
             $ativo = $model_user->buscarPorLoginUsuarios($login);
             if ($ativo['status_usuario'] == 1) {
                 $senhaAlterada = $ativo['senha_alterada'];
                 try {
                     $auth = new Default_Model_Login();
                     $auth->login($login, $senha);
                     if ($senhaAlterada == 0) {
                         return $this->_helper->redirector->goToRoute(array('module' => 'admin', 'controller' => 'index', 'action' => 'index'), null, true);
                     } else {
                         return $this->_helper->redirector->goToRoute(array('module' => 'cadastros', 'controller' => 'usuarios', 'action' => 'alterar-senha-primeiro-acesso'), null, true);
                     }
                 } catch (Exception $e) {
                     echo "<script type='text/javascript'>";
                     echo "alert('Combinação de Usuário + Senha digitada está incorreta!');";
                     echo "</script>";
                 }
             } else {
                 echo "<script type='text/javascript'>";
                 echo "alert('O acesso a este usuário foi negado por o mesmo encontrar-se inativo em nosso sistema.');";
                 echo "</script>";
             }
         } else {
             $form->populate($data);
         }
     }
     ## Log da transação ##
     //        $log = new Acesso_Log;
     //        $log->Log();
 }
예제 #2
0
 public function indexAction()
 {
     // Already logged in
     $viewer = Khcn_Api::_()->getViewer();
     if ($viewer && $viewer->getIdentity()) {
         $this->view->status = false;
         $this->view->error = Zend_Registry::get('Zend_Translate')->_('Bạn đã đăng nhập.');
         $this->_helper->redirector->gotoRoute(array(), 'default', true);
         return;
     }
     // Make form
     $this->view->form = $form = new Default_Form_Login();
     $form->setAction($this->view->url(array('return_url' => null)));
     $form->populate(array('return_url' => $this->_getParam('return_url')));
     // Not a post
     if (!$this->getRequest()->isPost()) {
         $this->view->status = false;
         $this->view->error = Zend_Registry::get('Zend_Translate')->_('No action taken');
         return;
     }
     // Form not valid
     if (!$form->isValid($this->getRequest()->getPost())) {
         $this->view->status = false;
         $this->view->error = Zend_Registry::get('Zend_Translate')->_('Invalid data');
         return;
     }
     // Check login creds
     extract($form->getValues());
     // $Username, $Password, $Remember
     $userTable = Khcn_Api::_()->getItemTable('default_nguoi_dung');
     $userSelect = $userTable->select()->where('ten_dang_nhap = ?', $Username);
     // If post exists
     $user = $userTable->fetchRow($userSelect);
     // Get ip address
     $db = Khcn_Db_Table::getDefaultAdapter();
     // Check if user exists
     if (empty($user)) {
         $this->view->status = false;
         $this->view->error = Zend_Registry::get('Zend_Translate')->_('Tên đăng nhập hoặc mật khẩu không đúng.');
         $form->addError(Zend_Registry::get('Zend_Translate')->_('Tên đăng nhập hoặc mật khẩu không đúng.'));
         return;
     }
     // Check if user is verified and enabled
     if (!$user->enabled) {
         if (!$user->verified) {
             $this->view->status = false;
             $translate = Zend_Registry::get('Zend_Translate');
             $error = $translate->translate('Vui lòng kích hoạt tài khoản thông qua email.');
             $form->getDecorator('errors')->setOption('escape', false);
             $form->addError($error);
             return;
         } else {
             if (!$user->approved) {
                 $this->view->status = false;
                 $translate = Zend_Registry::get('Zend_Translate');
                 $error = $translate->translate('Tài khoản của bạn cần được kích hoạt bởi admin.');
                 $form->getDecorator('errors')->setOption('escape', false);
                 $form->addError($error);
                 return;
             }
         }
         // Should be handled by hooks or payment
         //return;
     }
     // Version 3 Import compatibility
     if (empty($user->mat_khau)) {
         $form->addError('Mật khẩu không hợp lệ. Vui lòng reset lại mật khẩu.');
         return;
     } else {
         $authResult = Khcn_Api::_()->authenticate($Username, $Password);
         $authCode = $authResult->getCode();
         Khcn_Api::_()->setViewer();
         if ($authCode != Zend_Auth_Result::SUCCESS) {
             $this->view->status = false;
             $this->view->error = Zend_Registry::get('Zend_Translate')->_('Tên đăng nhập hoặc mật khẩu không đúng.');
             $form->addError(Zend_Registry::get('Zend_Translate')->_('Tên đăng nhập hoặc mật khẩu không đúng.'));
             return;
         }
     }
     // -- Success! --
     // Remember
     if (!empty($Remember)) {
         $lifetime = 1209600;
         // Two weeks
         Zend_Session::getSaveHandler()->setLifetime($lifetime, true);
         Zend_Session::rememberMe($lifetime);
     }
     // Test activity @todo remove
     $viewer = Khcn_Api::_()->getViewer();
     if ($viewer && $viewer->getIdentity()) {
         $viewer->lan_dang_nhap_cuoi = date("Y-m-d H:i:s");
         $viewer->save();
     }
     // Assign sid to view for json context
     $this->view->status = true;
     $this->view->message = Zend_Registry::get('Zend_Translate')->_('Đăng nhập thành công');
     $this->view->sid = Zend_Session::getId();
     $this->view->sname = Zend_Session::getOptions('name');
     // Do redirection only if normal context
     // Redirect by form
     $uri = $form->getValue('return_url');
     if ($uri) {
         if (substr($uri, 0, 3) == '64-') {
             $uri = base64_decode(substr($uri, 3));
         }
         return $this->_redirect($uri, array('prependBase' => false));
     }
     // Redirect by session
     $session = new Zend_Session_Namespace('Redirect');
     if (isset($session->uri)) {
         $uri = $session->uri;
         $opts = $session->options;
         $session->unsetAll();
         return $this->_redirect($uri, $opts);
     } else {
         if (isset($session->route)) {
             $session->unsetAll();
             return $this->_helper->redirector->gotoRoute($session->params, $session->route, $session->reset);
         }
     }
     // Just redirect to home
     return $this->_helper->redirector->gotoRoute(array(), null, true);
 }