2019-05-13 17:55:41 +02:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Update Manager registration process client controller.
|
|
|
|
*
|
|
|
|
* @category Client controller
|
|
|
|
* @package Pandora FMS
|
|
|
|
* @subpackage Update manager
|
|
|
|
* @version 1.0.0
|
|
|
|
* @license See below
|
|
|
|
*
|
|
|
|
* ______ ___ _______ _______ ________
|
2023-06-08 12:42:10 +02:00
|
|
|
* | __ \.-----.--.--.--| |.-----.----.-----. | ___| | | __|
|
|
|
|
* | __/| _ | | _ || _ | _| _ | | ___| |__ |
|
2019-05-13 17:55:41 +02:00
|
|
|
* |___| |___._|__|__|_____||_____|__| |___._| |___| |__|_|__|_______|
|
|
|
|
*
|
|
|
|
* ============================================================================
|
2023-06-08 11:53:13 +02:00
|
|
|
* Copyright (c) 2005-2023 Pandora FMS
|
2023-06-08 13:19:01 +02:00
|
|
|
* Please see https://pandorafms.com/community/ for full contribution list
|
2019-05-13 17:55:41 +02:00
|
|
|
* 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.
|
|
|
|
* ============================================================================
|
|
|
|
*/
|
|
|
|
|
|
|
|
// Begin.
|
|
|
|
global $config;
|
|
|
|
|
2021-06-14 13:56:42 +02:00
|
|
|
require_once $config['homedir'].'/include/functions_register.php';
|
2019-10-24 16:56:13 +02:00
|
|
|
require_once $config['homedir'].'/include/class/WelcomeWindow.class.php';
|
2023-02-14 11:18:39 +01:00
|
|
|
require_once $config['homedir'].'/include/class/TipsWindow.class.php';
|
2019-05-13 17:55:41 +02:00
|
|
|
|
|
|
|
|
2021-06-14 13:56:42 +02:00
|
|
|
if ((bool) is_ajax() === true) {
|
2019-05-13 17:55:41 +02:00
|
|
|
// Parse responses, flow control.
|
|
|
|
$configuration_wizard = get_parameter('save_required_wizard', 0);
|
|
|
|
$change_language = get_parameter('change_language', 0);
|
|
|
|
$cancel_wizard = get_parameter('cancel_wizard', 0);
|
|
|
|
|
2019-05-14 17:15:28 +02:00
|
|
|
// Load wizards.
|
|
|
|
$load_wizards = get_parameter('load_wizards', '');
|
|
|
|
|
2019-05-13 17:55:41 +02:00
|
|
|
$feedback = [];
|
|
|
|
|
2019-05-14 17:15:28 +02:00
|
|
|
// Load wizards.
|
|
|
|
if ($load_wizards != '') {
|
|
|
|
switch ($load_wizards) {
|
|
|
|
case 'initial':
|
|
|
|
return config_wiz_modal(false, false);
|
|
|
|
|
|
|
|
case 'all':
|
|
|
|
config_wiz_modal(false, false);
|
|
|
|
return;
|
|
|
|
|
|
|
|
default:
|
|
|
|
// Ignore.
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-05-13 17:55:41 +02:00
|
|
|
// Configuration wizard process.
|
|
|
|
if ($configuration_wizard) {
|
|
|
|
$feedback = config_wiz_process();
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($change_language) {
|
|
|
|
// Change the language if is change in checkbox.
|
|
|
|
config_update_value('language', $change_language);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($cancel_wizard) {
|
|
|
|
config_update_value('initial_wizard', 1);
|
|
|
|
}
|
|
|
|
|
2021-06-14 13:56:42 +02:00
|
|
|
if (is_array($feedback) === true) {
|
2019-05-13 17:55:41 +02:00
|
|
|
echo json_encode($feedback);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Ajax calls finish here.
|
|
|
|
exit();
|
|
|
|
}
|
|
|
|
|
|
|
|
ui_require_css_file('register');
|
|
|
|
|
|
|
|
$initial = isset($config['initial_wizard']) !== true
|
|
|
|
|| $config['initial_wizard'] != '1';
|
|
|
|
|
2019-05-29 10:01:21 +02:00
|
|
|
if ($initial && users_is_admin()) {
|
2019-05-13 17:55:41 +02:00
|
|
|
// Show all forms in order.
|
|
|
|
// 1- Ask for email, timezone, etc. Fullfill alerts and user mail.
|
|
|
|
config_wiz_modal(
|
|
|
|
false,
|
|
|
|
true,
|
2021-06-14 13:56:42 +02:00
|
|
|
null,
|
2020-11-10 12:10:25 +01:00
|
|
|
true
|
2019-05-13 17:55:41 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2023-05-23 16:54:40 +02:00
|
|
|
if (check_acl($config['id_user'], 0, 'AW')) {
|
|
|
|
$welcome = !$initial;
|
|
|
|
try {
|
|
|
|
$welcome_window = new WelcomeWindow($welcome);
|
|
|
|
if ($welcome_window !== null) {
|
|
|
|
$welcome_window->run();
|
|
|
|
}
|
|
|
|
} catch (Exception $e) {
|
|
|
|
$welcome = false;
|
2019-10-30 16:56:44 +01:00
|
|
|
}
|
2019-10-18 10:30:19 +02:00
|
|
|
}
|
|
|
|
|
2023-02-14 11:18:39 +01:00
|
|
|
try {
|
|
|
|
if (isset($_SESSION['showed_tips_window']) === false) {
|
|
|
|
$tips_window = new TipsWindow();
|
|
|
|
if ($tips_window !== null) {
|
2023-05-23 16:54:40 +02:00
|
|
|
$tips_window->run();
|
2023-02-14 11:18:39 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
} catch (Exception $e) {
|
|
|
|
}
|
|
|
|
|
2020-10-06 17:02:58 +02:00
|
|
|
$double_auth_enabled = (bool) db_get_value('id', 'tuser_double_auth', 'id_user', $config['id_user']);
|
|
|
|
|
2021-02-10 15:00:23 +01:00
|
|
|
if (isset($config['2FA_all_users']) === false) {
|
|
|
|
$config['2FA_all_users'] = null;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!$double_auth_enabled
|
|
|
|
&& $config['2FA_all_users'] != ''
|
2020-10-06 17:02:58 +02:00
|
|
|
&& $config['2Fa_auth'] != '1'
|
|
|
|
&& $config['double_auth_enabled']
|
|
|
|
) {
|
2021-03-11 15:40:23 +01:00
|
|
|
echo '<div id="doble_auth_window" class="invisible"; >';
|
2020-10-06 17:02:58 +02:00
|
|
|
?>
|
|
|
|
<script type="text/javascript">
|
|
|
|
var userID = "<?php echo $config['id_user']; ?>";
|
|
|
|
|
|
|
|
var $loadingSpinner = $("<img src=\"<?php echo $config['homeurl']; ?>/images/spinner.gif\" />");
|
|
|
|
var $dialogContainer = $("div#doble_auth_window");
|
|
|
|
|
|
|
|
$dialogContainer.html($loadingSpinner);
|
|
|
|
|
|
|
|
// Load the info page
|
|
|
|
var request = $.ajax({
|
|
|
|
url: "<?php echo ui_get_full_url('ajax.php', false, false, false); ?>",
|
|
|
|
type: 'POST',
|
|
|
|
dataType: 'html',
|
|
|
|
data: {
|
|
|
|
page: 'include/ajax/double_auth.ajax',
|
|
|
|
id_user: userID,
|
|
|
|
get_double_auth_info_page: 1,
|
|
|
|
containerID: $dialogContainer.prop('id')
|
|
|
|
},
|
|
|
|
complete: function (xhr, textStatus) {
|
|
|
|
|
|
|
|
},
|
|
|
|
success: function (data, textStatus, xhr) {
|
|
|
|
// isNaN = is not a number
|
|
|
|
if (isNaN(data)) {
|
|
|
|
$dialogContainer.html(data);
|
|
|
|
}
|
|
|
|
// data is a number, convert it to integer to do the compare
|
|
|
|
else if (Number(data) === -1) {
|
|
|
|
$dialogContainer.html("<?php echo '<b><div class=\"red\">'.__('Authentication error').'</div></b>'; ?>");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$dialogContainer.html("<?php echo '<b><div class=\"red\">'.__('Error').'</div></b>'; ?>");
|
|
|
|
}
|
|
|
|
},
|
|
|
|
error: function (xhr, textStatus, errorThrown) {
|
|
|
|
$dialogContainer.html("<?php echo '<b><div class=\"red\">'.__('There was an error loading the data').'</div></b>'; ?>");
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
<?php config_update_value('2Fa_auth', ''); ?>
|
2021-02-19 14:30:09 +01:00
|
|
|
$("div#doble_auth_window").dialog({
|
2020-10-06 17:02:58 +02:00
|
|
|
resizable: true,
|
|
|
|
draggable: true,
|
|
|
|
modal: true,
|
2022-09-22 08:59:39 +02:00
|
|
|
title: "<?php echo __('Double authentication activation'); ?>",
|
2020-10-06 17:02:58 +02:00
|
|
|
overlay: {
|
|
|
|
opacity: 0.5,
|
|
|
|
background: "black"
|
|
|
|
},
|
|
|
|
width: 500,
|
2023-03-22 16:42:03 +01:00
|
|
|
height: 'auto',
|
2020-10-06 17:02:58 +02:00
|
|
|
close: function (event, ui) {
|
|
|
|
// Abort the ajax request
|
|
|
|
if (typeof request != 'undefined'){
|
|
|
|
request.abort();
|
|
|
|
}
|
|
|
|
// Remove the contained html
|
|
|
|
$dialogContainer.empty();
|
|
|
|
|
|
|
|
//document.location.reload();
|
|
|
|
}
|
|
|
|
})
|
2021-03-11 14:49:39 +01:00
|
|
|
.show();
|
|
|
|
// Don't allow close the dialog with X button
|
2022-09-20 10:11:27 +02:00
|
|
|
// $('.ui-dialog-titlebar-close').css('display', 'none');
|
2021-03-11 14:49:39 +01:00
|
|
|
|
|
|
|
</script>
|
2020-10-06 17:02:58 +02:00
|
|
|
<?php
|
|
|
|
echo '</div>';
|
|
|
|
}
|
|
|
|
|
2019-05-13 17:55:41 +02:00
|
|
|
?>
|
|
|
|
<script type="text/javascript">
|
|
|
|
|
|
|
|
$(document).ready (function () {
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
</script>
|