SuiteCRM-Core/modules/Users/controller.php
Clemente Raposo 5fa70e2794 Squashed 'public/legacy/' changes from 5a66316965..b065977c61
b065977c61 SuiteCRM 7.12.5 Release
fd07950be0 Fix #8366 - V8 API Filtering W/ OR Operator Chained Conditions
f8504d0a42 Fix #9445 - More than 10 tabs in a views creates a loop
ec3c758b49 Fix #9451 - Missing duplicate merge filter options in Studio
3739e28428 Fix #9468 - Adding Security Suite subpanels to new custom modules
0742615e61 Fix #9427 - Adding missing help popup help strings in Studio
c79a3a6109 Add accessors for the Results, Query fields in SearchResultsController
a507575097 Fix #4075 - No way to add email signature after adding email template
9b8f5b46b2 Fix #9480 - Slow to load imap mailbox with a million email records
8184b82060 Fixed #2857 - No dynamic refreshing in dashboard
ece5919449 Fix #9508 - Legacy search fields are incorrect size
5699ad47ff Fix #9478 - Update GitHub Templates
37d54ca1ab SuiteCRM 7.12.4 Release
5a7f66f1fc Fix #9482 - Update list of modules to normalize
1807751e16 Fix #9482 - Only save update fields on utf encoding repair
08c5a32e07 Fix #9482 - Add partial bean save
a25efff51f Fix #7842 - Do not reset email addresses list upon saving
4e5b509a30 Add ExtensionManager with static method to compile ext files
77b2940fd9 Fix #9061 - Custom Labels can't be overwritten in Studio
2f40449702 Fix #9496 - Cannot save dropdown values
32c6e4a04b Merge next into suite 8
2812bd315a [Legacy] Fix user wizard finish screen re-direction
9dc1a2f017 [Legacy] User Wizard Styling Fixes
0b91cb9a53 [Legacy] Event Delegates Selector Box Styling Fixes
32d7408e93 [Legacy] Add New Task Modal Styling Fixes
e121b602da [Legacy] Workflow Styling Fixes
86ef0fae66 [Legacy] Projects Resource Panel Styling Fixes
56eb694629 [Legacy] map legacy to front-end user action called wizard
4c7ff07fcc [Legacy] Rescheduler Popup Styling Fixes
1b76260971 [Legacy] Project Gantt Chart Delete Button Styling Fixes
09959f1078 [Legacy] Configuration Settings Styling Fixes
711ded6a70 [Legacy] Notes modules styling fixes
a0aa6affc8 [Legacy] Calls Module Styling Fixes
a468cede8b [Legacy] AdminPanel Border Radius Styling Fixes
bfc8a443b7 [Legacy] Bump version to 8.0.1

git-subtree-dir: public/legacy
git-subtree-split: b065977c6116e68cea907dc099205d0b32ac99f4
2022-03-01 14:37:14 +00:00

230 lines
9.2 KiB
PHP
Executable file

<?php
/**
*
* SugarCRM Community Edition is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004-2013 SugarCRM Inc.
*
* SuiteCRM is an extension to SugarCRM Community Edition developed by SalesAgility Ltd.
* Copyright (C) 2011 - 2018 SalesAgility Ltd.
*
* This program is free software; you can redistribute it and/or modify it under
* the terms of the GNU Affero General Public License version 3 as published by the
* Free Software Foundation with the addition of the following permission added
* to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
* IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
* OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
* details.
*
* You should have received a copy of the GNU Affero General Public License along with
* this program; if not, see http://www.gnu.org/licenses or write to the Free
* Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
* 02110-1301 USA.
*
* You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
* SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
*
* The interactive user interfaces in modified source and object code versions
* of this program must display Appropriate Legal Notices, as required under
* Section 5 of the GNU Affero General Public License version 3.
*
* In accordance with Section 7(b) of the GNU Affero General Public License version 3,
* these Appropriate Legal Notices must retain the display of the "Powered by
* SugarCRM" logo and "Supercharged by SuiteCRM" logo. If the display of the logos is not
* reasonably feasible for technical reasons, the Appropriate Legal Notices must
* display the words "Powered by SugarCRM" and "Supercharged by SuiteCRM".
*/
if (!defined('sugarEntry') || !sugarEntry) {
die('Not A Valid Entry Point');
}
require_once __DIR__ . '/../../include/OutboundEmail/OutboundEmail.php';
require_once __DIR__ . '/../../modules/UserPreferences/UserPreference.php';
class UsersController extends SugarController
{
/**
* bug 48170
* Action resetPreferences gets fired when user clicks on 'Reset User Preferences' button
* This action is set in UserViewHelper.php
*/
protected function action_resetPreferences()
{
if ($_REQUEST['record'] == $GLOBALS['current_user']->id || ($GLOBALS['current_user']->isAdminForModule('Users'))) {
$u = BeanFactory::newBean('Users');
$u->retrieve($_REQUEST['record']);
$u->resetPreferences();
if ($u->id == $GLOBALS['current_user']->id) {
SugarApplication::redirect('index.php');
} else {
SugarApplication::redirect("index.php?module=Users&record=" . $_REQUEST['record'] . "&action=DetailView"); //bug 48170]
}
}
}
protected function action_delete()
{
if ($_REQUEST['record'] != $GLOBALS['current_user']->id && (
$GLOBALS['current_user']->isAdminForModule('Users')
)
) {
$u = BeanFactory::newBean('Users');
$u->retrieve($_REQUEST['record']);
$u->status = 'Inactive';
$u->employee_status = 'Terminated';
$u->save();
$u->mark_deleted($u->id);
$GLOBALS['log']->info("User id: {$GLOBALS['current_user']->id} deleted user record: {$_REQUEST['record']}");
$eapm = loadBean('EAPM');
$eapm->delete_user_accounts($_REQUEST['record']);
$GLOBALS['log']->info("Removing user's External Accounts");
SugarApplication::redirect("index.php?module=Users&action=index");
} else {
sugar_die("Unauthorized access to administration.");
}
}
protected function action_wizard()
{
$this->view = 'wizard';
}
protected function action_saveuserwizard()
{
global $current_user, $sugar_config;
// set all of these default parameters since the Users save action will undo the defaults otherwise
$_POST['record'] = $current_user->id;
$_POST['is_admin'] = ($current_user->is_admin ? 'on' : '');
$_POST['use_real_names'] = true;
$_POST['reminder_checked'] = '1';
$_POST['email_reminder_checked'] = '1';
$_POST['reminder_time'] = 1800;
$_POST['email_reminder_time'] = 3600;
$_POST['mailmerge_on'] = 'on';
$_POST['receive_notifications'] = $current_user->receive_notifications;
$_POST['user_theme'] = (string)SugarThemeRegistry::getDefault();
// Will pull in the users details from first page of the wizard
if (!empty($_POST['first_name'])) {
$current_user->first_name = ($_POST['first_name']);
}
if (!empty($_POST['last_name'])) {
$current_user->last_name = ($_POST['last_name']);
}
if (!empty($_POST['email1'])) {
$current_user->email1 = ($_POST['email1']);
}
if (!empty($_POST['phone_work'])) {
$current_user->phone_work = ($_POST['phone_work']);
}
if (!empty($_POST['phone_mobile'])) {
$current_user->phone_mobile = ($_POST['phone_mobile']);
}
if (!empty($_POST['messenger_type'])) {
$current_user->messenger_type = ($_POST['messenger_type']);
}
if (!empty($_POST['messenger_id'])) {
$current_user->messenger_id = ($_POST['messenger_id']);
}
if (!empty($_POST['address_street'])) {
$current_user->address_street = ($_POST['address_street']);
}
if (!empty($_POST['address_city'])) {
$current_user->address_city = ($_POST['address_city']);
}
if (!empty($_POST['address_state'])) {
$current_user->address_state = ($_POST['address_state']);
}
if (!empty($_POST['address_postalcode'])) {
$current_user->address_postalcode = ($_POST['address_postalcode']);
}
if (!empty($_POST['address_country'])) {
$current_user->address_country = ($_POST['address_country']);
}
// Saves User Details ONLY
$current_user->save();
// Will pull in the users Preferences from second page of the wizard
if (!empty($_POST['timezone'])) {
$current_user->setPreference('timezone', $_POST['timezone'],
0, 'global');
}
if (!empty($_POST['dateformat'])) {
$current_user->setPreference('dateformat', $_POST['dateformat'],
0, 'global');
}
if (!empty($_POST['timeformat'])) {
$current_user->setPreference('timeformat', $_POST['timeformat'],
0, 'global');
}
if (!empty($_POST['currency'])) {
$current_user->setPreference('currency', $_POST['currency'],
0, 'global');
}
if (!empty($_POST['default_currency_significant_digits'])) {
$current_user->setPreference('default_currency_significant_digits',
$_POST['default_currency_significant_digits'], 0, 'global');
}
if (!empty($_POST['dec_sep'])) {
$current_user->setPreference('dec_sep', $_POST['dec_sep'],
0, 'global');
}
if (!empty($_POST['num_grp_sep'])) {
$current_user->setPreference('num_grp_sep', $_POST['num_grp_sep'],
0, 'global');
}
if (!empty($_POST['default_locale_name_format'])) {
$current_user->setPreference('default_locale_name_format',
$_POST['default_locale_name_format'], 0, 'global');
}
$next = $_POST['whatnext'] ?? '';
$base = 'index.php?action=index&module=Home';
$nextActions = [
'users' => 'index.php?action=index&module=Users' ,
'finish' => 'index.php?action=index&module=Home',
'settings' => 'index.php?action=index&module=Administration',
'studio' => 'index.php?action=index&module=ModuleBuilder?type=studio',
'import' => 'index.php?module=Import&action=step1&import_module=Administration',
];
$returnUrl = $nextActions[$next] ?? $base;
// redirect to home
SugarApplication::redirect($returnUrl);
}
protected function action_saveftsmodules()
{
$this->view = 'fts';
$GLOBALS['current_user']->setPreference('fts_disabled_modules', $_REQUEST['disabled_modules']);
}
protected function action_editview()
{
$this->view = 'edit';
if (!(is_admin($GLOBALS['current_user']) || $_REQUEST['record'] == $GLOBALS['current_user']->id)) {
SugarApplication::redirect("index.php?module=Home&action=index");
}
}
protected function action_detailview()
{
$this->view = 'detail';
if (!(is_admin($GLOBALS['current_user']) || $_REQUEST['record'] == $GLOBALS['current_user']->id)) {
SugarApplication::redirect("index.php?module=Home&action=index");
}
}
}