2019-02-06 11:36:28 +01:00
|
|
|
<?php
|
2019-04-24 13:53:18 +02:00
|
|
|
/**
|
|
|
|
* Extension to manage a list of gateways and the node address where they should
|
|
|
|
* point to.
|
|
|
|
*
|
|
|
|
* @category Users
|
|
|
|
* @package Pandora FMS
|
|
|
|
* @subpackage Community
|
|
|
|
* @version 1.0.0
|
|
|
|
* @license See below
|
|
|
|
*
|
|
|
|
* ______ ___ _______ _______ ________
|
|
|
|
* | __ \.-----.--.--.--| |.-----.----.-----. | ___| | | __|
|
|
|
|
* | __/| _ | | _ || _ | _| _ | | ___| |__ |
|
|
|
|
* |___| |___._|__|__|_____||_____|__| |___._| |___| |__|_|__|_______|
|
|
|
|
*
|
|
|
|
* ============================================================================
|
2020-11-27 13:52:35 +01:00
|
|
|
* Copyright (c) 2005-2021 Artica Soluciones Tecnologicas
|
2019-04-24 13:53:18 +02:00
|
|
|
* Please see http://pandorafms.org for full contribution list
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation for version 2.
|
|
|
|
* 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 General Public License for more details.
|
|
|
|
* ============================================================================
|
|
|
|
*/
|
2019-02-06 11:36:28 +01:00
|
|
|
|
|
|
|
global $config;
|
|
|
|
|
2019-02-06 12:51:02 +01:00
|
|
|
check_login();
|
2019-02-06 11:36:28 +01:00
|
|
|
|
2019-02-06 12:51:02 +01:00
|
|
|
require_once $config['homedir'].'/include/functions_profile.php';
|
|
|
|
require_once $config['homedir'].'/include/functions_users.php';
|
|
|
|
require_once $config['homedir'].'/include/functions_groups.php';
|
|
|
|
require_once $config['homedir'].'/include/functions_visual_map.php';
|
2019-02-06 11:36:28 +01:00
|
|
|
|
|
|
|
$meta = false;
|
2019-02-06 12:51:02 +01:00
|
|
|
if (enterprise_installed() && defined('METACONSOLE')) {
|
|
|
|
$meta = true;
|
2019-02-06 11:36:28 +01:00
|
|
|
}
|
|
|
|
|
2019-02-06 12:51:02 +01:00
|
|
|
$id = get_parameter_get('id', $config['id_user']);
|
2019-04-24 13:53:18 +02:00
|
|
|
// ID given as parameter.
|
2019-02-06 12:51:02 +01:00
|
|
|
$status = get_parameter('status', -1);
|
2019-04-24 13:53:18 +02:00
|
|
|
// Flag to print action status message.
|
2019-02-06 12:51:02 +01:00
|
|
|
$user_info = get_user_info($id);
|
|
|
|
$id = $user_info['id_user'];
|
2019-04-24 13:53:18 +02:00
|
|
|
// This is done in case there are problems
|
|
|
|
// with uppercase/lowercase (MySQL auth has that problem).
|
2019-02-06 12:51:02 +01:00
|
|
|
if ((!check_acl($config['id_user'], users_get_groups($id), 'UM'))
|
2019-04-24 13:53:18 +02:00
|
|
|
&& ($id != $config['id_user'])
|
2019-02-06 12:51:02 +01:00
|
|
|
) {
|
2019-04-24 13:53:18 +02:00
|
|
|
db_pandora_audit(
|
2022-01-20 10:55:23 +01:00
|
|
|
AUDIT_LOG_ACL_VIOLATION,
|
2019-04-24 13:53:18 +02:00
|
|
|
'Trying to view a user without privileges'
|
|
|
|
);
|
2019-02-06 12:51:02 +01:00
|
|
|
include 'general/noaccess.php';
|
|
|
|
exit;
|
2019-02-06 11:36:28 +01:00
|
|
|
}
|
|
|
|
|
2019-04-24 13:53:18 +02:00
|
|
|
// If current user is editing himself or if the user has UM (User Management)
|
|
|
|
// rights on any groups the user is part of AND the authorization scheme
|
|
|
|
// allows for users/admins to update info.
|
|
|
|
if (($config['id_user'] == $id
|
|
|
|
|| check_acl($config['id_user'], users_get_groups($id), 'UM'))
|
|
|
|
&& $config['user_can_update_info']
|
|
|
|
) {
|
2019-02-06 12:51:02 +01:00
|
|
|
$view_mode = false;
|
|
|
|
} else {
|
|
|
|
$view_mode = true;
|
2019-02-06 11:36:28 +01:00
|
|
|
}
|
|
|
|
|
2019-02-06 12:51:02 +01:00
|
|
|
$urls = [];
|
2019-02-06 11:36:28 +01:00
|
|
|
if (is_metaconsole()) {
|
2019-02-06 12:51:02 +01:00
|
|
|
user_meta_print_header();
|
|
|
|
$urls['main'] = 'index.php?sec=advanced&sec2=advanced/users_setup&tab=user_edit';
|
|
|
|
} else {
|
2023-03-07 17:50:03 +01:00
|
|
|
$urls['main'] = 'index.php?sec=gusuarios&sec2=godmode/users/user_list';
|
2019-02-06 12:51:02 +01:00
|
|
|
$urls['notifications'] = 'index.php?sec=workspace&sec2=operation/users/user_edit_notifications';
|
|
|
|
$buttons = [
|
|
|
|
'main' => [
|
2023-03-07 17:50:03 +01:00
|
|
|
'active' => $_GET['sec2'] === 'godmode/users/user_list&tab=user&pure=0',
|
2019-02-06 12:51:02 +01:00
|
|
|
'text' => "<a href='{$urls['main']}'>".html_print_image(
|
2023-03-07 17:50:03 +01:00
|
|
|
'images/user.svg',
|
2019-02-06 12:51:02 +01:00
|
|
|
true,
|
2021-03-11 15:40:23 +01:00
|
|
|
[
|
|
|
|
'title' => __('User management'),
|
2023-03-07 17:50:03 +01:00
|
|
|
'class' => 'main_menu_icon invert_filter',
|
2021-03-11 15:40:23 +01:00
|
|
|
]
|
2019-02-06 12:51:02 +01:00
|
|
|
).'</a>',
|
|
|
|
],
|
|
|
|
'notifications' => [
|
|
|
|
'active' => $_GET['sec2'] === 'operation/users/user_edit_notifications',
|
|
|
|
'text' => "<a href='{$urls['notifications']}'>".html_print_image(
|
2023-03-07 17:50:03 +01:00
|
|
|
'images/alert@svg.svg',
|
2019-02-06 12:51:02 +01:00
|
|
|
true,
|
2021-03-11 15:40:23 +01:00
|
|
|
[
|
|
|
|
'title' => __('User notifications'),
|
2023-03-07 17:50:03 +01:00
|
|
|
'class' => 'main_menu_icon invert_filter',
|
2021-03-11 15:40:23 +01:00
|
|
|
]
|
2019-02-06 12:51:02 +01:00
|
|
|
).'</a>',
|
|
|
|
],
|
|
|
|
];
|
2019-05-27 19:00:48 +02:00
|
|
|
$tab_name = 'User Management';
|
2019-02-06 12:51:02 +01:00
|
|
|
|
2019-04-24 13:53:18 +02:00
|
|
|
$helpers = '';
|
|
|
|
if ($_GET['sec2'] === 'operation/users/user_edit_notifications') {
|
|
|
|
$helpers = 'user_edit_notifications';
|
2019-05-27 19:00:48 +02:00
|
|
|
$tab_name = 'User Notifications';
|
2019-04-24 13:53:18 +02:00
|
|
|
}
|
|
|
|
|
2021-04-30 14:44:03 +02:00
|
|
|
// Header.
|
|
|
|
ui_print_standard_header(
|
|
|
|
$headerTitle,
|
2021-03-11 15:40:23 +01:00
|
|
|
'images/user.png',
|
2019-02-06 12:51:02 +01:00
|
|
|
false,
|
2019-04-24 13:53:18 +02:00
|
|
|
$helpers,
|
2019-02-06 12:51:02 +01:00
|
|
|
false,
|
2019-05-27 19:00:48 +02:00
|
|
|
$buttons,
|
2021-04-30 14:44:03 +02:00
|
|
|
[
|
|
|
|
[
|
|
|
|
'link' => '',
|
|
|
|
'label' => __('Workspace'),
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'link' => '',
|
|
|
|
'label' => __('Edit user'),
|
|
|
|
],
|
|
|
|
]
|
2019-02-06 12:51:02 +01:00
|
|
|
);
|
2019-02-06 11:36:28 +01:00
|
|
|
}
|