ok

Mini Shell

Direktori : /proc/self/root/home2/selectio/www/bharath/application/controllers/
Upload File :
Current File : //proc/self/root/home2/selectio/www/bharath/application/controllers/Site.php

<?php

if (!defined('BASEPATH'))
    exit('No direct script access allowed');

class Site extends Public_Controller {
    
    public function __construct() {
        parent::__construct();
        $this->check_installation();
        if ($this->config->item('installed') == true) {
            $this->db->reconnect();
        }

        $this->load->model("staff_model");
        $this->load->library('Auth');
        $this->load->library('Enc_lib');
        $this->load->library('customlib');
        $this->load->library('mailer');
        $this->load->config('ci-blog');
        $this->mailer;
    }

    private function check_installation() {
        if ($this->uri->segment(1) !== 'install') {
            $this->load->config('migration');
            if ($this->config->item('installed') == false && $this->config->item('migration_enabled') == false) {
                redirect(base_url() . 'install/start');
            } else {
                if (is_dir(APPPATH . 'controllers/install')) {
                    echo '<h3>Delete the install folder from application/controllers/install</h3>';
                    die;
                }
            }
        }
    }

    function login() {

$app_name=$this->setting_model->get();
$app_name=$app_name[0]['name'];

        if ($this->auth->logged_in()) {
            $this->auth->is_logged_in(true);
        }

        $data = array();
        $data['title'] = 'Login';
        $school = $this->setting_model->get();
        
        $data['name'] = $app_name;

        $notice_content = $this->config->item('ci_front_notice_content');
        $notices = $this->cms_program_model->getByCategory($notice_content, array('start' => 0, 'limit' => 5));
        $data['notice'] = $notices;
        $data['school'] = $school[0];
        $this->form_validation->set_rules('username', $this->lang->line('username'), 'trim|required|xss_clean');
        $this->form_validation->set_rules('password', $this->lang->line('password'), 'trim|required|xss_clean');
        if ($this->form_validation->run() == FALSE) {
           $data['name'] = $app_name;
            $this->load->view('admin/login', $data);
        } else {
            $login_post = array(
                'email' => $this->input->post('username'),
                'password' => $this->input->post('password')
            );
            $setting_result = $this->setting_model->get();
            $result = $this->staff_model->checkLogin($login_post);

            if (!empty($result->language_id)) {
                $lang_array = array('lang_id' => $result->language_id, 'language' => $result->language);
            } else {
                $lang_array = array('lang_id' => $setting_result[0]['lang_id'], 'language' => $setting_result[0]['language']);
            }
            
            if ($result) {
                if ($result->is_active) {
                    if ($result->surname != "") {
                        $logusername = $result->name . " " . $result->surname;
                    } else {
                        $logusername = $result->name;
                    }

                    $setting_result = $this->setting_model->get();
                    $session_data = array(
                        'id' => $result->id,
                        'username' => $logusername,
                        'email' => $result->email,
                        'roles' => $result->roles,
                        'date_format' => $setting_result[0]['date_format'],
                        'currency_symbol' => $setting_result[0]['currency_symbol'],
                        'currency_place' => $setting_result[0]['currency_place'],
                        'start_month' => $setting_result[0]['start_month'],
                        'school_name' => $setting_result[0]['name'],
                        'timezone' => $setting_result[0]['timezone'],
                        'sch_name' => $setting_result[0]['name'],
                        'language' => $lang_array,
                        'is_rtl' => $setting_result[0]['is_rtl'],
                        'theme' => $setting_result[0]['theme'],
                    );
                    $this->session->set_userdata('admin', $session_data);
                    $role = $this->customlib->getStaffRole();
                    $role_name = json_decode($role)->name;
                    $this->customlib->setUserLog($this->input->post('username'), $role_name);

                    if (isset($_SESSION['redirect_to']))
                        redirect($_SESSION['redirect_to']);
                    else
                        redirect('admin/admin/choose');
                        //redirect('admin/admin/dashboard');
                }else {
                    $data['name'] = $app_name;
                    $data['error_message'] = $this->lang->line('your_account_is_disabled_please_contact_to_administrator');

                    $this->load->view('admin/login', $data);
                }
            } else {
                $data['name'] = $app_name;
                $data['error_message'] = $this->lang->line('invalid_username_or_password');
                $this->load->view('admin/login', $data);
            }
        }
    }

    function logout() {
        $admin_session = $this->session->userdata('admin');
        $student_session = $this->session->userdata('student');
        $this->auth->logout();
        if ($admin_session) {
            redirect('https://bharathcollege-egate.in/e-governance');
            //redirect('site/login');
        } else if ($student_session) {
            redirect('https://bharathcollege-egate.in/e-governance');
            //redirect('site/userlogin');
        } else {
            redirect('https://bharathcollege-egate.in/e-governance');
            //redirect('site/userlogin');
        }
    }

    function forgotpassword() {

$app_name=$this->setting_model->get();
$data['name']=$app_name[0]['name'];
        $this->form_validation->set_rules('email', $this->lang->line('email'), 'trim|valid_email|required|xss_clean');

        if ($this->form_validation->run() == FALSE) {
            $this->load->view('admin/forgotpassword',$data);
        } else {
            $email = $this->input->post('email');

            $result = $this->staff_model->getByEmail($email);

            if ($result && $result->email != "") {

                $verification_code = $this->enc_lib->encrypt(uniqid(mt_rand()));
                $update_record = array('id' => $result->id, 'verification_code' => $verification_code);
                $this->staff_model->add($update_record);
                $name = $result->name;

                $resetPassLink = site_url('admin/resetpassword') . "/" . $verification_code;

                $body = $this->forgotPasswordBody($name, $resetPassLink);
                $body_array = json_decode($body);

                if (!empty($this->mail_config)) {
                    $result = $this->mailer->send_mail($result->email, $body_array->subject, $body_array->body);
                }

                $this->session->set_flashdata('message', $this->lang->line('please_check_your_email_to_recover_your_password'));

                redirect('site/login', 'refresh');
            } else {
                $data = array(
                    'error_message' => $this->lang->line('invalid_email')
                );
            }
            $this->load->view('admin/forgotpassword', $data);
        }
    }

    //reset password - final step for forgotten password
    public function admin_resetpassword($verification_code = null) {
        $app_name=$this->setting_model->get();
$data['name']=$app_name[0]['name'];
        if (!$verification_code) {
            show_404();
        }

        $user = $this->staff_model->getByVerificationCode($verification_code);

        if ($user) {
            //if the code is valid then display the password reset form
            $this->form_validation->set_rules('password', $this->lang->line('password'), 'required');
            $this->form_validation->set_rules('confirm_password', $this->lang->line('confirm_password'), 'required|matches[password]');
            if ($this->form_validation->run() == false) {


                $data['verification_code'] = $verification_code;
                //render
                $this->load->view('admin/admin_resetpassword', $data);
            } else {

                // finally change the password
                $password = $this->input->post('password');
                $update_record = array(
                    'id' => $user->id,
                    'password' => $this->enc_lib->passHashEnc($password),
                    'verification_code' => ""
                );

                $change = $this->staff_model->update($update_record);
                if ($change) {
                    //if the password was successfully changed
                    $this->session->set_flashdata('message', $this->lang->line("password_reset_successfully"));
                    redirect('site/login', 'refresh');
                } else {
                    $this->session->set_flashdata('message', $this->lang->line("something_went_wrong"));
                    redirect('admin_resetpassword/' . $verification_code, 'refresh');
                }
            }
        } else {
            //if the code is invalid then send them back to the forgot password page
            $this->session->set_flashdata('message', $this->lang->line('invalid_link'));
            redirect("site/forgotpassword", 'refresh');
        }
    }

    //reset password - final step for forgotten password
    public function resetpassword($role = null, $verification_code = null) {
         $app_name=$this->setting_model->get();
$data['name']=$app_name[0]['name'];
        if (!$role || !$verification_code) {
            show_404();
        }

        $user = $this->user_model->getUserByCodeUsertype($role, $verification_code);

        if ($user) {
            //if the code is valid then display the password reset form
            $this->form_validation->set_rules('password', $this->lang->line('password'), 'required');
            $this->form_validation->set_rules('confirm_password', $this->lang->line('confirm_password'), 'required|matches[password]');
            if ($this->form_validation->run() == false) {

                $data['role'] = $role;
                $data['verification_code'] = $verification_code;
                //render
                $this->load->view('resetpassword', $data);
            } else {

                // finally change the password

                $update_record = array(
                    'id' => $user->user_tbl_id,
                    'password' => $this->input->post('password'),
                    'verification_code' => ""
                );

                $change = $this->user_model->saveNewPass($update_record);
                if ($change) {
                    //if the password was successfully changed
                    $this->session->set_flashdata('message', $this->lang->line('password_reset_successfully'));
                    redirect('site/userlogin', 'refresh');
                } else {
                    $this->session->set_flashdata('message', $this->lang->line("something_went_wrong"));
                    redirect('user/resetpassword/' . $role . '/' . $verification_code, 'refresh');
                }
            }
        } else {
            //if the code is invalid then send them back to the forgot password page
            $this->session->set_flashdata('message', $this->lang->line('invalid_link'));
            redirect("site/ufpassword", 'refresh');
        }
    }

    function ufpassword() {
       
        $app_name=$this->setting_model->get();
        $data['name']=$app_name[0]['name'];
        $this->form_validation->set_rules('username', $this->lang->line('email'), 'trim|required|xss_clean');
        $this->form_validation->set_rules('user[]', $this->lang->line('user_type'), 'trim|required|xss_clean');
        if ($this->form_validation->run() == FALSE) {
            
            $this->load->view('ufpassword',$data);
        } else {
            $email = $this->input->post('username');
            $usertype = $this->input->post('user[]');

            $result = $this->user_model->forgotPassword($usertype[0], $email);

            if ($result && $result->email != "") {

                $verification_code = $this->enc_lib->encrypt(uniqid(mt_rand()));
                $update_record = array('id' => $result->user_tbl_id, 'verification_code' => $verification_code);
                $this->user_model->updateVerCode($update_record);
                if ($usertype[0] == "student") {
                    $name = $result->firstname . " " . $result->lastname;
                } else {
                    $name = $result->guardian_name;
                }
                $resetPassLink = site_url('user/resetpassword') . '/' . $usertype[0] . "/" . $verification_code;

                $body = $this->forgotPasswordBody($name, $resetPassLink);
                $body_array = json_decode($body);

                if (!empty($this->mail_config)) {
                    $result = $this->mailer->send_mail($email, $body_array->subject, $body_array->body);
                }

                $this->session->set_flashdata('message', $this->lang->line("please_check_your_email_to_recover_your_password"));
                redirect('site/userlogin', 'refresh');
            } else {
                $data = array(
                     'name'=> $app_name[0]['name'],
                    'error_message' => $this->lang->line('invalid_email_or_user_type')
                );
            }
           
            $this->load->view('ufpassword', $data);
        }
    } 

    function forgotPasswordBody($name, $resetPassLink) {
        //===============
        $subject = "Password Update Request";
        $body = 'Dear ' . $name . ', 
                <br/>Recently a request was submitted to reset password for your account. If you didn\'t make the request, just ignore this email. Otherwise you can reset your password using this link <a href="' . $resetPassLink . '"><button>Click here to reset your password</button></a>';
        $body .= '<br/><hr/>if you\'re having trouble clicking the password reset button, copy and paste the URL below into your web browser';
        $body .= '<br/>' . $resetPassLink;
        $body .= '<br/><br/>Regards,
                <br/>' . $this->customlib->getSchoolName();

        //======================
        return json_encode(array('subject' => $subject, 'body' => $body));
    }
 // function userlogin() {
 //        if ($this->auth->user_logged_in()) {
 //            $this->auth->user_redirect();
 //        }
 //        $data = array();
 //        $data['title'] = 'Login';
 //        $school = $this->setting_model->get();
 //        $data['name'] = $school[0]['name'];
 //        $notice_content = $this->config->item('ci_front_notice_content');
 //        $notices = $this->cms_program_model->getByCategory($notice_content, array('start' => 0, 'limit' => 5));
 //        $data['notice'] = $notices;
 //        $data['school'] = $school[0];
 //        $this->form_validation->set_rules('username', $this->lang->line('username'), 'trim|required|xss_clean');
 //        $this->form_validation->set_rules('password', $this->lang->line('password'), 'trim|required|xss_clean');
 //        if ($this->form_validation->run() == FALSE) {
 //            $this->load->view('userlogin', $data);
 //        } else {
 //            $login_post = array(
 //                'username' => $this->input->post('username'),
 //                'password' => $this->input->post('password')
 //            );
 //            $login_details = $this->user_model->checkLogin($login_post);

 //            if (isset($login_details) && !empty($login_details)) {
 //                $user = $login_details[0];
 //                if ($user->is_active == "yes") {
 //                    if ($user->role == "student") {
 //                        $result = $this->user_model->read_user_information($user->id);
 //                    } else if ($user->role == "parent") {
 //                        $result = $this->user_model->checkLoginParent($login_post);
 //                    }

 //                    if ($result != false) {
 //                        $setting_result = $this->setting_model->get();
 //                        if ($result[0]->lang_id == 0) {
 //                            $language = array('lang_id' => $setting_result[0]['lang_id'], 'language' => $setting_result[0]['language']);
 //                        } else {
 //                            $language = array('lang_id' => $result[0]->lang_id, 'language' => $result[0]->language);
 //                        }

                       
 //                        if ($result[0]->role == "student") {
 //                            $session_data = array(
 //                                'id' => $result[0]->id,
 //                                'student_id' => $result[0]->user_id,
 //                                'role' => $result[0]->role,
 //                                'username' => $result[0]->firstname . " " . $result[0]->lastname,
 //                                'date_format' => $setting_result[0]['date_format'],
 //                                'currency_symbol' => $setting_result[0]['currency_symbol'],
 //                                'timezone' => $setting_result[0]['timezone'],
 //                                'sch_name' => $setting_result[0]['name'],
 //                                'language' => $language,
 //                                'is_rtl' => $setting_result[0]['is_rtl'],
 //                                'theme' => $setting_result[0]['theme'],
 //                                'image' => $result[0]->image,
 //                            );
 //                            $student_display_session = $this->studentsession_model->searchActiveClassSectionStudent($result[0]->user_id);
 //                            $student_current_class = array('student_session_id'=>$student_display_session->id,'class_id' => $student_display_session->class_id,
 //                                'section_id' => $student_display_session->section_id);
 //                            $this->session->set_userdata('student', $session_data);
 //                            $this->session->set_userdata('current_class', $student_current_class);
 //                            $this->customlib->setUserLog($result[0]->username, $result[0]->role);
 //                            redirect('user/user/dashboard');
 //                        } else if ($result[0]->role == "parent") {
              
 //                            if ($result[0]->guardian_relation == "Father") {
 //                                $image = $result[0]->father_pic;
 //                            } else if ($result[0]->guardian_relation == "Mother") {
 //                                $image = $result[0]->mother_pic;
 //                            } else if ($result[0]->guardian_relation == "Other") {
 //                                $image = $result[0]->guardian_pic;
 //                            }

 //                            $session_data = array(
 //                                'id' => $result[0]->id,
 //                                'student_id' => $result[0]->user_id,
 //                                'role' => $result[0]->role,
 //                                'username' => $result[0]->guardian_name,
 //                                'date_format' => $setting_result[0]['date_format'],
 //                                'timezone' => $setting_result[0]['timezone'],
 //                                'sch_name' => $setting_result[0]['name'],
 //                                'currency_symbol' => $setting_result[0]['currency_symbol'],
 //                                'language' => array('lang_id' => $setting_result[0]['lang_id'], 'language' => $setting_result[0]['language']),
 //                                'is_rtl' => $setting_result[0]['is_rtl'],
 //                                'theme' => $setting_result[0]['theme'],
 //                                'image' => $image,
 //                            );
 //                            $this->session->set_userdata('student', $session_data);
 //                            $s = array();
 //                            $user_id = ($result[0]->id);
 //                            $students_array = $this->student_model->read_siblings_students($user_id);

 //                            $child_student = array();
 //                            foreach ($students_array as $std_key => $std_val) {
 //                                $child = array(
 //                                    'student_id' => $std_val->id,
 //                                    'name' => $std_val->firstname . " " . $std_val->lastname
 //                                );
 //                                $child_student[] = $child;
 //                            }
 //                            $this->session->set_userdata('parent_childs', $child_student);
 //                            $this->customlib->setUserLog($result[0]->username, $result[0]->role);
 //                            redirect('parent/parents/dashboard');
 //                        }
 //                    } else {
 //                        $data['error_message'] = 'Account Suspended';
 //                        $this->load->view('userlogin', $data);
 //                    }
 //                } else {
 //                    $data['error_message'] = $this->lang->line('your_account_is_disabled_please_contact_to_administrator');
 //                    $this->load->view('userlogin', $data);
 //                }
 //            } else {
 //                $data['error_message'] = $this->lang->line('invalid_username_or_password');
 //                $this->load->view('userlogin', $data);
 //            }
 //        }
 //    }

    function userlogin() {
        if ($this->auth->user_logged_in()) {
            $this->auth->user_redirect();
        }
        $data = array();
        $data['title'] = 'Login';
        $school = $this->setting_model->get();
        $data['name'] = $school[0]['name'];
        $notice_content = $this->config->item('ci_front_notice_content');
        $notices = $this->cms_program_model->getByCategory($notice_content, array('start' => 0, 'limit' => 5));
        $data['notice'] = $notices;
        $data['school'] = $school[0];
        $this->form_validation->set_rules('username', $this->lang->line('username'), 'trim|required|xss_clean');
        $this->form_validation->set_rules('password', $this->lang->line('password'), 'trim|required|xss_clean');
        if ($this->form_validation->run() == FALSE) {
            $this->load->view('userlogin', $data);
        } else {
            $login_post = array(
                'username' => $this->input->post('username'),
                'password' => $this->input->post('password')
            );
            $login_details = $this->user_model->checkLogin($login_post);

            if (isset($login_details) && !empty($login_details)) {
                $user = $login_details[0];
                if ($user->is_active == "yes") {
                    if ($user->role == "student") {
                        $result = $this->user_model->read_user_information($user->id);
                    } else if ($user->role == "parent") {
                        $result = $this->user_model->checkLoginParent($login_post);
                    }

                    if ($result != false) {
                        $setting_result = $this->setting_model->get();
                        if ($result[0]->lang_id == 0) {
                            $language = array('lang_id' => $setting_result[0]['lang_id'], 'language' => $setting_result[0]['language']);
                        } else {
                            $language = array('lang_id' => $result[0]->lang_id, 'language' => $result[0]->language);
                        }
                        if($result[0]->role == "parent") {
                             $username=$result[0]->guardian_name;
                            if ($result[0]->guardian_relation == "Father") {
                                $image = $result[0]->father_pic;
                            } else if ($result[0]->guardian_relation == "Mother") {
                                $image = $result[0]->mother_pic;
                            } else if ($result[0]->guardian_relation == "Other") {
                                $image = $result[0]->guardian_pic;
                            }
                        }elseif ($result[0]->role == "student") {
                             $image = $result[0]->image;
                            $username= ($result[0]->lastname != "")? $result[0]->firstname . " " .$result[0]->lastname: $result[0]->firstname;
                        }
                       
                        
                     
                            $session_data = array(
                                'id' => $result[0]->id,
                                'student_id' => $result[0]->user_id,
                                'role' => $result[0]->role,
                                'username' => $username,
                                'date_format' => $setting_result[0]['date_format'],
                                'currency_symbol' => $setting_result[0]['currency_symbol'],
                                'timezone' => $setting_result[0]['timezone'],
                                'sch_name' => $setting_result[0]['name'],
                                'language' => $language,
                                'is_rtl' => $setting_result[0]['is_rtl'],
                                'theme' => $setting_result[0]['theme'],
                                'image' => $result[0]->image,
                            );
                            $this->session->set_userdata('student', $session_data);

                            // $student_display_session = $this->studentsession_model->searchActiveClassSectionStudent($result[0]->user_id);
                            // $student_current_class = array('student_session_id'=>$student_display_session->id,'class_id' => $student_display_session->class_id,
                            //     'section_id' => $student_display_session->section_id);

                            // $this->session->set_userdata('current_class', $student_current_class);

                            $this->customlib->setUserLog($result[0]->username, $result[0]->role);
                            // redirect('user/user/dashboard');
                            redirect('user/user/choose');
                   
                    } else {
                        $data['error_message'] = 'Account Suspended';
                        $this->load->view('userlogin', $data);
                    }
                } else {
                    $data['error_message'] = $this->lang->line('your_account_is_disabled_please_contact_to_administrator');
                    $this->load->view('userlogin', $data);
                }
            } else {
                $data['error_message'] = $this->lang->line('invalid_username_or_password');
                $this->load->view('userlogin', $data);
            }
        }
    }

    public function savemulticlass() {
        
        $student_id = '';
        $this->form_validation->set_rules('student_id', $this->lang->line('student'), 'trim|required|xss_clean');

        if ($this->form_validation->run() == FALSE) {

            $msg = array(
                'student_id' => form_error('student_id')
            );

            $array = array('status' => '0', 'error' => $msg, 'message' => '');
        } else {

            $data = array(
                'student_id' => date('Y-m-d', strtotime($this->input->post('student_id'))),
            );


            $array = array('status' => 'success', 'error' => '', 'message' => $this->lang->line('success_message'));
        }
        echo json_encode($array);
    }

}

?>

Zerion Mini Shell 1.0