session->userdata("logged_in") == FALSE){ redirect("user/login", "location"); } } public function login(){ $this->login_validation(); if($this->form_validation->run() == false){ $data['title'] = 'Login UNLASYS'; $this->load->view('user/v_userlogin.php',$data); }else{ $userid = $this->input->post("user_id"); $userdata = $this->m_login->user_data($userid); if($userdata->num_rows() == null){ $userdata_2 = $this->m_login->user_data_2($userid); foreach ($userdata_2->result() as $row_2){ $uid = $row_2->userid; $uname = $row_2->nmlengkap; $level_id = $row_2->idklppengguna; if($idklppengguna == "2"){ $level_name = "mahasiswa"; }elseif($idklppengguna == "3"){ $level_name = "Tenaga Pendidik"; } $sessdata = array("uid" => $uid, "uname" => $uname, "level_id" => $level_id, "level_name" => $level_name, "logged_in" => TRUE); $this->session->set_userdata($sessdata); } }else{ foreach ($userdata->result() as $row){ $uia = $row->id_akun; $uid = $row->userid; $level_id = $row->id_otoritas; $level_name = $row->nama_otoritas; $this->_last_login($userid); } $sessdata = array("uia" => $uia, "uid" => $uid, "level_id" => $level_id, "level_name" => $level_name, "logged_in" => TRUE); $this->session->set_userdata($sessdata); } redirect("beranda", "location"); } } function login_validation(){ $this->form_validation->set_rules("passwd", "Password", "callback_check_akun"); $this->form_validation->set_message("check_akun", "User ID atau Password salah !"); $this->form_validation->set_error_delimiters("
", "
"); } function check_akun(){ $userid = $this->input->post("user_id"); $passwd = $this->input->post("passwd"); $pass_md5 = md5($passwd); $pass_64 = base64_encode($passwd); if ($this->m_login->valid_password($userid, $pass_md5) == FALSE){ if ($this->m_login->valid_password_64($userid, $pass_64) == FALSE){ return FALSE; }else{ return TRUE; } }else{ return TRUE; } } function _last_login($no){ $datestring = "%Y-%m-%d %h:%i:%s"; $now = time(); $logindata = array("lastlogin" => mdate($datestring,$now)); $this->m_login->last_login($no, $logindata); } public function logout(){ $this->session->sess_destroy(); // hapus cache lama redirect("user/login", "location"); } public function detail(){ // Otoritas // $menu_id = '14'; is_akses($menu_id); $menu["id_menu"] = $menu_id; $id_akun = $this->session->userdata("uia"); $data["title"] = "Detail Akun UNLASYS"; $data["action_form"] = base_url().'user/ubah_password/'.$id_akun; $detail_akun = $this->m_login->detail_akun($id_akun); foreach($detail_akun->result() as $row_akun) { $data["user_id"] = $row_akun->userid; //$data["nm_user"] = $row_akun->nama_user; $data["nm_otoritas"] = $row_akun->nama_otoritas; } $data["ubahpass"] = "isi jika mengubah password"; $data["pass"] = ""; $data["konf_pass"] = ""; $this->load->view('v_header.php',$data); $this->load->view('v_menu.php',$menu); $this->load->view('user/v_detail.php'); $this->load->view('v_footer.php'); } public function ubah_password(){ // Otoritas // $menu_id = '14'; is_akses($menu_id); $menu["id_menu"] = $menu_id; $this->_validation_ubah_akun(); if($this->form_validation->run()==false){ $id_akun = $this->session->userdata("uia"); $data["title"] = "Detail Akun UNLASYS"; $data["action_form"] = base_url().'user/ubah_password/'.$id_akun; $detail_akun = $this->m_login->detail_akun($id_akun); foreach($detail_akun->result() as $row_akun) { $data["user_id"] = $row_akun->userid; $data["nm_otoritas"]= $row_akun->nama_otoritas; } $data["ubahpass"] = "isi jika mengubah password"; $data["pass"] = ""; $data["konf_pass"] = ""; $this->load->view('v_header.php',$data); $this->load->view('v_menu.php',$menu); $this->load->view('user/v_detail.php'); $this->load->view('v_footer.php'); }else{ $id_akun = $this->session->userdata("uia"); $pass_new = $this->input->post('pass'); if(empty($pass_new)){ $detail_akun = $this->m_login->detail_akun($id_akun); foreach($detail_akun->result() as $row_akun) { $post_pass = $row_akun->passwd; } }else{ $post_pass = md5($pass_new); } $data = array('passwd' => $post_pass); $this->m_login->update_akun($id_akun, $data); $this->session->set_flashdata('success', 'Password Akun berhasil diubah'); redirect('user/detail'); } } function _validation_ubah_akun(){ $this->form_validation->set_rules("pass", "Password", "min_length[4]|max_length[20]"); $this->form_validation->set_rules("konf_pass", "Konfirmasi Password", "min_length[4]|max_length[20]|matches[pass]"); $this->form_validation->set_message("max_length", "%s tidak boleh lebih dari %s karakter"); $this->form_validation->set_message("min_length", "%s Minimal %s karakter"); $this->form_validation->set_message("matches", "%s Tidak sama"); $this->form_validation->set_error_delimiters("
", "
"); } }