Server IP : 184.154.167.98 / Your IP : 3.145.196.141 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 : 7.2.34 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /home/puertode/www/mesa/scp/ |
Upload File : |
<?php /********************************************************************* users.php Peter Rotich <peter@osticket.com> Jared Hancock <jared@osticket.com> Copyright (c) 2006-2014 osTicket http://www.osticket.com Released under the GNU General Public License WITHOUT ANY WARRANTY. See LICENSE.TXT for details. vim: expandtab sw=4 ts=4 sts=4: **********************************************************************/ require('staff.inc.php'); if (!$thisstaff->hasPerm(User::PERM_DIRECTORY)) Http::redirect('index.php'); require_once INCLUDE_DIR.'class.note.php'; $user = null; if ($_REQUEST['id'] && !($user=User::lookup($_REQUEST['id']))) $errors['err'] = sprintf(__('%s: Unknown or invalid'), _N('end user', 'end users', 1)); if ($_POST) { switch(strtolower($_REQUEST['do'])) { case 'update': if (!$user) { $errors['err']=sprintf(__('%s: Unknown or invalid'), _N('end user', 'end users', 1)); } elseif (!$thisstaff->hasPerm(User::PERM_EDIT)) { $errors['err'] = __('Action denied. Contact admin for access'); } elseif(($acct = $user->getAccount()) && !$acct->update($_POST, $errors)) { $errors['err']=__('Unable to update user account information'); } elseif($user->updateInfo($_POST, $errors)) { $msg=sprintf(__('Successfully updated %s.'), __('this end user')); $_REQUEST['a'] = null; } elseif(!$errors['err']) { $errors['err']=sprintf('%s %s', sprintf(__('Unable to update %s.'), __('this end user')), __('Correct any errors below and try again.')); } break; case 'create': $form = UserForm::getUserForm()->getForm($_POST); if (($user = User::fromForm($form))) { $msg = Format::htmlchars(sprintf(__('Successfully added %s.'), $user->getName())); $_REQUEST['a'] = null; } elseif (!$errors['err']) { $errors['err']=sprintf('%s %s', sprintf(__('Unable to add %s.'), __('this end user')), __('Correct any errors below and try again.')); } break; case 'confirmlink': if (!$user || !$user->getAccount()) $errors['err'] = sprintf(__('%s: Unknown or invalid'), __('end user account')); elseif ($user->getAccount()->isConfirmed()) $errors['err'] = __('Account is already confirmed'); elseif ($user->getAccount()->sendConfirmEmail()) $msg = sprintf(__('Account activation email sent to %s'),$user->getEmail()); else $errors['err'] = sprintf('%s - %s', __('Unable to send account activation email'), __('Please try again!')); break; case 'pwreset': if (!$user || !$user->getAccount()) $errors['err'] = sprintf(__('%s: Unknown or invalid'), __('end user account')); elseif ($user->getAccount()->sendResetEmail()) $msg = sprintf(__('Account password reset email sent to %s'),$user->getEmail()); else $errors['err'] = sprintf('%s - %s', __('Unable to send account password reset email'), __('Please try again!')); break; case 'mass_process': if (!$_POST['ids'] || !is_array($_POST['ids']) || !count($_POST['ids'])) { $errors['err'] = sprintf(__('You must select at least %s.'), __('one end user')); } else { $users = User::objects()->filter( array('id__in' => $_POST['ids']) ); $count = 0; switch (strtolower($_POST['a'])) { case 'lock': foreach ($users as $U) if (($acct = $U->getAccount()) && $acct->lock()) { $type = array('type' => 'edited', 'key' => 'locked-flag'); Signal::send('object.edited', $acct, $type); $count++; } break; case 'unlock': foreach ($users as $U) if (($acct = $U->getAccount()) && $acct->unlock()) { $type = array('type' => 'edited', 'key' => 'unlocked-flag'); Signal::send('object.edited', $acct, $type); $count++; } break; case 'delete': foreach ($users as $U) { if (@$_POST['deletetickets']) { if (!$U->deleteAllTickets()) // XXX: This message is very unclear $errors['err'] = __('You do not have permission to delete a user with tickets!'); } if ($U->delete()) $count++; } break; case 'reset': foreach ($users as $U) if (($acct = $U->getAccount()) && $acct->sendResetEmail()) { $type = array('type' => 'edited', 'key' => 'pwreset-sent'); Signal::send('object.edited', $acct, $type); $count++; } break; case 'register': foreach ($users as $U) { $type = array('type' => 'edited', 'key' => 'user-registered'); Signal::send('object.edited', $U, $type); if (($acct = $U->getAccount()) && $acct->sendConfirmEmail()) $count++; elseif ($acct = UserAccount::register($U, array('sendemail' => true), $errors )) { $count++; } } break; case 'setorg': if (!($org = Organization::lookup($_POST['org_id']))) $errors['err'] = sprintf('%s - %s', __('Unknown action'), __('Get technical help!')); foreach ($users as $U) { if ($U->setOrganization($org)) { $type = array('type' => 'edited', 'key' => 'user-org'); Signal::send('object.edited', $U, $type); $count++; } } break; default: $errors['err']=sprintf('%s - %s', __('Unknown action'), __('Get technical help!')); } if (!$errors['err'] && !$count) { $errors['err'] = __('Unable to manage any of the selected end users'); } elseif ($_POST['count'] && $count != $_POST['count']) { $warn = __('Not all selected items were updated'); } elseif ($count) { $msg = __('Successfully managed selected end users'); } } break; case 'import-users': $status = User::importFromPost($_FILES['import'] ?: $_POST['pasted']); if (is_numeric($status)) $msg = sprintf(__('Successfully imported %1$d %2$s'), $status, _N('end user', 'end users', $status)); else $errors['err'] = $status; break; default: $errors['err'] = __('Unknown action'); break; } } elseif(!$user && $_REQUEST['a'] == 'export') { require_once(INCLUDE_DIR.'class.export.php'); $ts = date('Ymd'); if (!($query=$_SESSION[':Q:users'])) $errors['err'] = __('Query token not found'); elseif (!Export::saveUsers($query, __("users")."-$ts.csv", 'csv')) $errors['err'] = __('Unable to dump query results.') .' '.__('Internal error occurred'); } $page = 'users.inc.php'; if ($user ) { $page = 'user-view.inc.php'; switch (strtolower($_REQUEST['t'])) { case 'tickets': if (isset($_SERVER['HTTP_X_PJAX'])) { $page='templates/tickets.tmpl.php'; $pjax_container = @$_SERVER['HTTP_X_PJAX_CONTAINER']; require(STAFFINC_DIR.$page); return; } elseif ($_REQUEST['a'] == 'export' && ($query=$_SESSION[':U:tickets'])) { $filename = sprintf('%s-tickets-%s.csv', $user->getName(), date('Ymd')); if (!Export::saveTickets($query, '', $filename, 'csv')) $errors['err'] = __('Unable to dump query results.') .' '.__('Internal error occurred'); } break; } } $nav->setTabActive('users'); require(STAFFINC_DIR.'header.inc.php'); require(STAFFINC_DIR.$page); include(STAFFINC_DIR.'footer.inc.php'); ?>