Server IP : 192.185.129.71 / Your IP : 18.117.121.71 Web Server : Apache System : Linux bh-ht-3.webhostbox.net 4.19.286-203.ELK.el7.x86_64 #1 SMP Wed Jun 14 04:33:55 CDT 2023 x86_64 User : svymadmin ( 4072) PHP Version : 7.4.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON Directory (0755) : /home4/svymadmin/public_html/vivekaexcel.edu.in/bkp/application/controllers/admin/ |
[ Home ] | [ C0mmand ] | [ Upload File ] |
---|
<?php defined('BASEPATH') or exit('No direct script access allowed'); class Staff extends AdminController { /* List all staff members */ public function index() { if (!has_permission('staff', '', 'view')) { access_denied('staff'); } if ($this->input->is_ajax_request()) { $this->app->get_table_data('staff'); } $data['staff_members'] = $this->staff_model->get('', ['active' => 1]); $data['title'] = _l('staff_members'); $this->load->view('admin/staff/manage', $data); } /* Add new staff member or edit existing */ public function member($id = '') { if (!has_permission('staff', '', 'view')) { access_denied('staff'); } hooks()->do_action('staff_member_edit_view_profile', $id); $this->load->model('departments_model'); if ($this->input->post()) { $data = $this->input->post(); // Don't do XSS clean here. $data['email_signature'] = $this->input->post('email_signature', false); $data['email_signature'] = html_entity_decode($data['email_signature']); if ($data['email_signature'] == strip_tags($data['email_signature'])) { // not contains HTML, add break lines $data['email_signature'] = nl2br_save_html($data['email_signature']); } $data['password'] = $this->input->post('password', false); if ($id == '') { if (!has_permission('staff', '', 'create')) { access_denied('staff'); } $id = $this->staff_model->add($data); if ($id) { handle_staff_profile_image_upload($id); set_alert('success', _l('added_successfully', _l('staff_member'))); redirect(admin_url('staff/member/' . $id)); } } else { if (!has_permission('staff', '', 'edit')) { access_denied('staff'); } handle_staff_profile_image_upload($id); $response = $this->staff_model->update($data, $id); if (is_array($response)) { if (isset($response['cant_remove_main_admin'])) { set_alert('warning', _l('staff_cant_remove_main_admin')); } elseif (isset($response['cant_remove_yourself_from_admin'])) { set_alert('warning', _l('staff_cant_remove_yourself_from_admin')); } } elseif ($response == true) { set_alert('success', _l('updated_successfully', _l('staff_member'))); } redirect(admin_url('staff/member/' . $id)); } } if ($id == '') { $title = _l('add_new', _l('staff_member_lowercase')); } else { $member = $this->staff_model->get($id); if (!$member) { blank_page('Staff Member Not Found', 'danger'); } $data['member'] = $member; $title = $member->firstname . ' ' . $member->lastname; $data['staff_departments'] = $this->departments_model->get_staff_departments($member->staffid); $ts_filter_data = []; if ($this->input->get('filter')) { if ($this->input->get('range') != 'period') { $ts_filter_data[$this->input->get('range')] = true; } else { $ts_filter_data['period-from'] = $this->input->get('period-from'); $ts_filter_data['period-to'] = $this->input->get('period-to'); } } else { $ts_filter_data['this_month'] = true; } $data['logged_time'] = $this->staff_model->get_logged_time_data($id, $ts_filter_data); $data['timesheets'] = $data['logged_time']['timesheets']; } $this->load->model('currencies_model'); $data['base_currency'] = $this->currencies_model->get_base_currency(); $data['roles'] = $this->roles_model->get(); $data['user_notes'] = $this->misc_model->get_notes($id, 'staff'); $data['departments'] = $this->departments_model->get(); $data['title'] = $title; $this->load->view('admin/staff/member', $data); } /* Get role permission for specific role id */ public function role_changed($id) { if (!has_permission('staff', '', 'view')) { ajax_access_denied('staff'); } echo json_encode($this->roles_model->get($id)->permissions); } public function save_dashboard_widgets_order() { hooks()->do_action('before_save_dashboard_widgets_order'); $post_data = $this->input->post(); foreach ($post_data as $container => $widgets) { if ($widgets == 'empty') { $post_data[$container] = []; } } update_staff_meta(get_staff_user_id(), 'dashboard_widgets_order', serialize($post_data)); } public function save_dashboard_widgets_visibility() { hooks()->do_action('before_save_dashboard_widgets_visibility'); $post_data = $this->input->post(); update_staff_meta(get_staff_user_id(), 'dashboard_widgets_visibility', serialize($post_data['widgets'])); } public function reset_dashboard() { update_staff_meta(get_staff_user_id(), 'dashboard_widgets_visibility', null); update_staff_meta(get_staff_user_id(), 'dashboard_widgets_order', null); redirect(admin_url()); } public function save_hidden_table_columns() { hooks()->do_action('before_save_hidden_table_columns'); $data = $this->input->post(); $id = $data['id']; $hidden = isset($data['hidden']) ? $data['hidden'] : []; update_staff_meta(get_staff_user_id(), 'hidden-columns-' . $id, json_encode($hidden)); } public function change_language($lang = '') { hooks()->do_action('before_staff_change_language', $lang); $this->db->where('staffid', get_staff_user_id()); $this->db->update(db_prefix() . 'staff', ['default_language' => $lang]); if (isset($_SERVER['HTTP_REFERER']) && !empty($_SERVER['HTTP_REFERER'])) { redirect($_SERVER['HTTP_REFERER']); } else { redirect(admin_url()); } } public function timesheets() { $data['view_all'] = false; if (staff_can('view-timesheets', 'reports') && $this->input->get('view') == 'all') { $data['staff_members_with_timesheets'] = $this->db->query('SELECT DISTINCT staff_id FROM ' . db_prefix() . 'taskstimers WHERE staff_id !=' . get_staff_user_id())->result_array(); $data['view_all'] = true; } if ($this->input->is_ajax_request()) { $this->app->get_table_data('staff_timesheets', ['view_all' => $data['view_all']]); } if ($data['view_all'] == false) { unset($data['view_all']); } $data['logged_time'] = $this->staff_model->get_logged_time_data(get_staff_user_id()); $data['title'] = ''; $this->load->view('admin/staff/timesheets', $data); } public function delete() { if (!is_admin() && is_admin($this->input->post('id'))) { die('Busted, you can\'t delete administrators'); } if (has_permission('staff', '', 'delete')) { $success = $this->staff_model->delete($this->input->post('id'), $this->input->post('transfer_data_to')); if ($success) { set_alert('success', _l('deleted', _l('staff_member'))); } } redirect(admin_url('staff')); } /* When staff edit his profile */ public function edit_profile() { hooks()->do_action('edit_logged_in_staff_profile'); if ($this->input->post()) { handle_staff_profile_image_upload(); $data = $this->input->post(); // Don't do XSS clean here. $data['email_signature'] = $this->input->post('email_signature', false); $data['email_signature'] = html_entity_decode($data['email_signature']); if ($data['email_signature'] == strip_tags($data['email_signature'])) { // not contains HTML, add break lines $data['email_signature'] = nl2br_save_html($data['email_signature']); } $success = $this->staff_model->update_profile($data, get_staff_user_id()); if ($success) { set_alert('success', _l('staff_profile_updated')); } redirect(admin_url('staff/edit_profile/' . get_staff_user_id())); } $member = $this->staff_model->get(get_staff_user_id()); $this->load->model('departments_model'); $data['member'] = $member; $data['departments'] = $this->departments_model->get(); $data['staff_departments'] = $this->departments_model->get_staff_departments($member->staffid); $data['title'] = $member->firstname . ' ' . $member->lastname; $this->load->view('admin/staff/profile', $data); } /* Remove staff profile image / ajax */ public function remove_staff_profile_image($id = '') { $staff_id = get_staff_user_id(); if (is_numeric($id) && (has_permission('staff', '', 'create') || has_permission('staff', '', 'edit'))) { $staff_id = $id; } hooks()->do_action('before_remove_staff_profile_image'); $member = $this->staff_model->get($staff_id); if (file_exists(get_upload_path_by_type('staff') . $staff_id)) { delete_dir(get_upload_path_by_type('staff') . $staff_id); } $this->db->where('staffid', $staff_id); $this->db->update(db_prefix() . 'staff', [ 'profile_image' => null, ]); if (!is_numeric($id)) { redirect(admin_url('staff/edit_profile/' . $staff_id)); } else { redirect(admin_url('staff/member/' . $staff_id)); } } /* When staff change his password */ public function change_password_profile() { if ($this->input->post()) { $response = $this->staff_model->change_password($this->input->post(null, false), get_staff_user_id()); if (is_array($response) && isset($response[0]['passwordnotmatch'])) { set_alert('danger', _l('staff_old_password_incorrect')); } else { if ($response == true) { set_alert('success', _l('staff_password_changed')); } else { set_alert('warning', _l('staff_problem_changing_password')); } } redirect(admin_url('staff/edit_profile')); } } /* View public profile. If id passed view profile by staff id else current user*/ public function profile($id = '') { if ($id == '') { $id = get_staff_user_id(); } hooks()->do_action('staff_profile_access', $id); $data['logged_time'] = $this->staff_model->get_logged_time_data($id); $data['staff_p'] = $this->staff_model->get($id); if (!$data['staff_p']) { blank_page('Staff Member Not Found', 'danger'); } $this->load->model('departments_model'); $data['staff_departments'] = $this->departments_model->get_staff_departments($data['staff_p']->staffid); $data['departments'] = $this->departments_model->get(); $data['title'] = _l('staff_profile_string') . ' - ' . $data['staff_p']->firstname . ' ' . $data['staff_p']->lastname; // notifications $total_notifications = total_rows(db_prefix() . 'notifications', [ 'touserid' => get_staff_user_id(), ]); $data['total_pages'] = ceil($total_notifications / $this->misc_model->get_notifications_limit()); $this->load->view('admin/staff/myprofile', $data); } /* Change status to staff active or inactive / ajax */ public function change_staff_status($id, $status) { if (has_permission('staff', '', 'edit')) { if ($this->input->is_ajax_request()) { $this->staff_model->change_staff_status($id, $status); } } } /* Logged in staff notifications*/ public function notifications() { $this->load->model('misc_model'); if ($this->input->post()) { $page = $this->input->post('page'); $offset = ($page * $this->misc_model->get_notifications_limit()); $this->db->limit($this->misc_model->get_notifications_limit(), $offset); $this->db->where('touserid', get_staff_user_id()); $this->db->order_by('date', 'desc'); $notifications = $this->db->get(db_prefix() . 'notifications')->result_array(); $i = 0; foreach ($notifications as $notification) { if (($notification['fromcompany'] == null && $notification['fromuserid'] != 0) || ($notification['fromcompany'] == null && $notification['fromclientid'] != 0)) { if ($notification['fromuserid'] != 0) { $notifications[$i]['profile_image'] = '<a href="' . admin_url('staff/profile/' . $notification['fromuserid']) . '">' . staff_profile_image($notification['fromuserid'], [ 'staff-profile-image-small', 'img-circle', 'pull-left', ]) . '</a>'; } else { $notifications[$i]['profile_image'] = '<a href="' . admin_url('clients/client/' . $notification['fromclientid']) . '"> <img class="client-profile-image-small img-circle pull-left" src="' . contact_profile_image_url($notification['fromclientid']) . '"></a>'; } } else { $notifications[$i]['profile_image'] = ''; $notifications[$i]['full_name'] = ''; } $additional_data = ''; if (!empty($notification['additional_data'])) { $additional_data = unserialize($notification['additional_data']); $x = 0; foreach ($additional_data as $data) { if (strpos($data, '<lang>') !== false) { $lang = get_string_between($data, '<lang>', '</lang>'); $temp = _l($lang); if (strpos($temp, 'project_status_') !== false) { $status = get_project_status_by_id(strafter($temp, 'project_status_')); $temp = $status['name']; } $additional_data[$x] = $temp; } $x++; } } $notifications[$i]['description'] = _l($notification['description'], $additional_data); $notifications[$i]['date'] = time_ago($notification['date']); $notifications[$i]['full_date'] = $notification['date']; $i++; } //$notifications as $notification echo json_encode($notifications); die; } } public function update_two_factor() { $fail_reason = _l('set_two_factor_authentication_failed'); if ($this->input->post()) { $this->load->library('form_validation'); $this->form_validation->set_rules('two_factor_auth', _l('two_factor_auth'), 'required'); if ($this->input->post('two_factor_auth') == 'google') { $this->form_validation->set_rules('google_auth_code', _l('google_authentication_code'), 'required'); } if ($this->form_validation->run() !== false) { $two_factor_auth_mode = $this->input->post('two_factor_auth'); $id = get_staff_user_id(); if ($two_factor_auth_mode == 'google') { $this->load->model('Authentication_model'); $secret = $this->input->post('secret'); $success = $this->authentication_model->set_google_two_factor($secret); $fail_reason = _l('set_google_two_factor_authentication_failed'); } elseif ($two_factor_auth_mode == 'email') { $this->db->where('staffid', $id); $success = $this->db->update(db_prefix() . 'staff', ['two_factor_auth_enabled' => 1]); } else { $this->db->where('staffid', $id); $success = $this->db->update(db_prefix() . 'staff', ['two_factor_auth_enabled' => 0]); } if ($success) { set_alert('success', _l('set_two_factor_authentication_successful')); redirect(admin_url('staff/edit_profile/' . get_staff_user_id())); } } } set_alert('danger', $fail_reason); redirect(admin_url('staff/edit_profile/' . get_staff_user_id())); } public function verify_google_two_factor() { if (!$this->input->is_ajax_request()) { show_404(); die; } if ($this->input->post()) { $data = $this->input->post(); $this->load->model('authentication_model'); $is_success = $this->authentication_model->is_google_two_factor_code_valid($data['code'],$data['secret']); $result = []; header('Content-Type: application/json'); if ($is_success) { $result['status'] = 'success'; $result['message'] = _l('google_2fa_code_valid');; echo json_encode($result); die; } $result['status'] = 'failed'; $result['message'] = _l('google_2fa_code_invalid');; echo json_encode($result); die; } } public function save_completed_checklist_visibility() { hooks()->do_action('before_save_completed_checklist_visibility'); $post_data = $this->input->post(); if (is_numeric($post_data['task_id'])) { update_staff_meta(get_staff_user_id(), 'task-hide-completed-items-'. $post_data['task_id'], $post_data['hideCompleted']); } } }