Server IP : 184.154.167.98 / Your IP : 18.216.212.231 Web Server : Apache System : Linux pink.dnsnetservice.com 4.18.0-553.22.1.lve.1.el8.x86_64 #1 SMP Tue Oct 8 15:52:54 UTC 2024 x86_64 User : puertode ( 1767) PHP Version : 8.2.26 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /home/puertode/public_html/mesa/include/ |
Upload File : |
<?php require_once(INCLUDE_DIR . 'class.staff.php'); class StaffAjaxAPI extends AjaxController { /** * Ajax: GET /staff/<id>/set-password * * Uses a dialog to add a new department * * Returns: * 200 - HTML form for addition * 201 - {id: <id>, name: <name>} * * Throws: * 403 - Not logged in * 403 - Not an administrator * 404 - No such agent exists */ function setPassword($id) { global $ost, $thisstaff; if (!$thisstaff) Http::response(403, 'Agent login required'); if (!$thisstaff->isAdmin()) Http::response(403, 'Access denied'); if ($id && !($staff = Staff::lookup($id))) Http::response(404, 'No such agent'); $form = new PasswordResetForm($_POST); $errors = array(); if (!$_POST && isset($_SESSION['new-agent-passwd'])) $form->data($_SESSION['new-agent-passwd']); if ($_POST && $form->isValid()) { $clean = $form->getClean(); try { // Validate password if (!$clean['welcome_email']) Staff::checkPassword($clean['passwd1'], null); if ($id == 0) { // Stash in the session later when creating the user $_SESSION['new-agent-passwd'] = $clean; Http::response(201, 'Carry on'); } if ($clean['welcome_email']) { $staff->sendResetEmail(); } else { $staff->setPassword($clean['passwd1'], null); if ($clean['change_passwd']) $staff->change_passwd = 1; } if ($staff->save()) Http::response(201, 'Successfully updated'); } catch (BadPassword $ex) { if ($passwd1 = $form->getField('passwd1')) $passwd1->addError($ex->getMessage()); } catch (PasswordUpdateFailed $ex) { $errors['err'] = __('Password update failed:').' '.$ex->getMessage(); } } $title = __("Set Agent Password"); $verb = $id == 0 ? __('Set') : __('Update'); $path = ltrim(Osticket::get_path_info(), '/'); include STAFFINC_DIR . 'templates/quick-add.tmpl.php'; } function changePassword($id) { global $cfg, $ost, $thisstaff; if (!$thisstaff) Http::response(403, 'Agent login required'); if (!$id || $thisstaff->getId() != $id) Http::response(404, 'No such agent'); $form = new PasswordChangeForm($_POST); $errors = array(); if ($_POST && $form->isValid()) { $clean = $form->getClean(); if (($rtoken = $_SESSION['_staff']['reset-token'])) { $_config = new Config('pwreset'); if ($_config->get($rtoken) != $thisstaff->getId()) $errors['err'] = __('Invalid reset token. Logout and try again'); elseif (!($ts = $_config->lastModified($rtoken)) && ($cfg->getPwResetWindow() < (time() - strtotime($ts)))) $errors['err'] = __('Invalid reset token. Logout and try again'); } if (!$errors) { try { $thisstaff->setPassword($clean['passwd1'], @$clean['current']); if ($thisstaff->save()) { if ($rtoken) { $thisstaff->cancelResetTokens(); Http::response(200, $this->encode(array( 'redirect' => 'index.php' ))); } Http::response(201, 'Successfully updated'); } } catch (BadPassword $ex) { if ($passwd1 = $form->getField('passwd1')) $passwd1->addError($ex->getMessage()); } catch (PasswordUpdateFailed $ex) { $errors['err'] = __('Password update failed:').' '.$ex->getMessage(); } } } $title = __("Change Password"); $verb = __('Update'); $path = ltrim(Osticket::get_path_info(), '/'); include STAFFINC_DIR . 'templates/quick-add.tmpl.php'; } function getAgentPerms($id) { global $thisstaff; if (!$thisstaff) Http::response(403, 'Agent login required'); if (!$thisstaff->isAdmin()) Http::response(403, 'Access denied'); if (!($staff = Staff::lookup($id))) Http::response(404, 'No such agent'); return $this->encode($staff->getPermissionInfo()); } function resetPermissions() { global $ost, $thisstaff; if (!$thisstaff) Http::response(403, 'Agent login required'); if (!$thisstaff->isAdmin()) Http::response(403, 'Access denied'); $form = new ResetAgentPermissionsForm($_POST); if (@is_array($_GET['ids'])) { $perms = new RolePermission(null); $selected = Staff::objects()->filter(array('staff_id__in' => $_GET['ids'])); foreach ($selected as $staff) // XXX: This maybe should be intersection rather than union $perms->merge($staff->getPermission()); $form->getField('perms')->setValue($perms->getInfo()); } if ($_POST && $form->isValid()) { $clean = $form->getClean(); Http::response(201, $this->encode(array('perms' => $clean['perms']))); } $title = __("Reset Agent Permissions"); $verb = __("Continue"); $path = ltrim(Osticket::get_path_info(), '/'); include STAFFINC_DIR . 'templates/reset-agent-permissions.tmpl.php'; } function changeDepartment() { global $ost, $thisstaff; if (!$thisstaff) Http::response(403, 'Agent login required'); if (!$thisstaff->isAdmin()) Http::response(403, 'Access denied'); $form = new ChangeDepartmentForm($_POST); // Preselect reasonable dept and role based on the current settings // of the received staff ids if (@is_array($_GET['ids'])) { $dept_id = null; $role_id = null; $selected = Staff::objects()->filter(array('staff_id__in' => $_GET['ids'])); foreach ($selected as $staff) { if (!isset($dept_id)) { $dept_id = $staff->dept_id; $role_id = $staff->role_id; } elseif ($dept_id != $staff->dept_id) $dept_id = 0; elseif ($role_id != $staff->role_id) $role_id = 0; } $form->getField('dept_id')->setValue($dept_id); $form->getField('role_id')->setValue($role_id); } if ($_POST && $form->isValid()) { $clean = $form->getClean(); Http::response(201, $this->encode($clean)); } $title = __("Change Primary Department"); $verb = __("Continue"); $path = ltrim(Osticket::get_path_info(), '/'); include STAFFINC_DIR . 'templates/quick-add.tmpl.php'; } function setAvatar($id) { global $thisstaff; if (!$thisstaff) Http::response(403, 'Agent login required'); if ($id != $thisstaff->getId() && !$thisstaff->isAdmin()) Http::response(403, 'Access denied'); if ($id == $thisstaff->getId()) $staff = $thisstaff; else $staff = Staff::lookup((int) $id); if (!($avatar = $staff->getAvatar())) Http::response(404, 'User does not have an avatar'); if ($code = $avatar->toggle()) return $this->encode(array( 'img' => (string) $avatar, // XXX: This is very inflexible 'code' => $code, )); } function configure2FA($staffId, $id=0) { global $thisstaff; if (!$thisstaff) Http::response(403, 'Agent login required'); if ($staffId != $thisstaff->getId()) Http::response(403, 'Access denied'); if ($id && !($auth= Staff2FABackend::lookup($id))) Http::response(404, 'Unknown 2FA'); $staff = $thisstaff; $info = array(); if ($auth) { // Simple state machine to manage settings and verification $state = @$_POST['state'] ?: 'validate'; switch ($state) { case 'verify': try { $form = $auth->getInputForm($_POST); if ($_POST && $form && $form->isValid() && $auth->validate($form, $staff)) { // Mark the settings as verified if (($config = $staff->get2FAConfig($auth->getId()))) { $config['verified'] = time(); $staff->updateConfig(array( $auth->getId() => JsonDataEncoder::encode($config))); } // We're done here $auth = null; $info['notice'] = __('Setup completed successfully'); } else { $info['error'] = __('Unable to verify the token - try again!'); } } catch (ExpiredOTP $ex) { // giving up cleanly $info['error'] = $ex->getMessage(); $auth = null; } break; case 'validate': default: $config = $staff->get2FAConfig($auth->getId()); $vars = $_POST ?: $config['config'] ?: array('email' => $staff->getEmail()); $form = $auth->getSetupForm($vars); if ($_POST && $form && $form->isValid()) { if ($config['config'] && $config['config']['external2fa']) $external2fa = true; // Save the setting based on setup form $clean = $form->getClean(); if (!$external2fa) { $config = ['config' => $clean, 'verified' => 0]; $staff->updateConfig(array( $auth->getId() => JsonDataEncoder::encode($config))); } // Send verification token to the user if ($token=$auth->send($staff)) { // Transition to verify state $form = $auth->getInputForm($vars); $state = 'verify'; $info['notice'] = __('Token sent to you!'); } else { // Generic error TODO: better wording $info['error'] = __('Error sending Token - double check entry'); } } } } include STAFFINC_DIR . 'templates/2fas.tmpl.php'; } function reset2fA($staffId) { global $thisstaff; if (!$thisstaff) Http::response(403, 'Agent login required'); if (!$thisstaff->isAdmin()) Http::response(403, 'Access denied'); $default_2fa = ConfigItem::getConfigsByNamespace('staff.'.$staffId, 'default_2fa'); if ($default_2fa) $default_2fa->delete(); } }