2006-03-27 05:37:27 +02:00
< ? php
2019-02-19 14:55:44 +01:00
/**
2021-05-18 10:57:21 +02:00
* User edit .
2019-02-19 14:55:44 +01:00
*
2021-05-18 10:57:21 +02:00
* @ category Users
2019-02-19 14:55:44 +01:00
* @ package Pandora FMS
* @ subpackage Community
* @ version 1.0 . 0
* @ license See below
*
* ______ ___ _______ _______ ________
2023-06-08 12:42:10 +02:00
* | __ \ .-----.--.--.--| |.-----.----.-----. | ___ | | | __ |
* | __ /| _ | | _ || _ | _ | _ | | ___ | | __ |
2019-02-19 14:55:44 +01: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-02-19 14:55:44 +01: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 .
* ============================================================================
*/
2009-06-08 20:18:20 +02:00
2010-03-02 20:25:51 +01:00
global $config ;
2006-07-11 16:48:04 +02:00
2021-04-30 14:44:03 +02:00
$headerTitle = __ ( 'User detail editor' );
2019-03-12 08:56:45 +01:00
// Load the header.
2019-02-18 15:14:24 +01:00
require $config [ 'homedir' ] . '/operation/users/user_edit_header.php' ;
2023-01-24 10:12:37 +01:00
use PandoraFMS\Dashboard\Manager ;
2013-05-20 10:42:02 +02:00
2021-03-31 13:27:58 +02:00
if ( is_metaconsole () === false ) {
2019-04-09 18:18:10 +02:00
include 'include/javascript/timezonepicker/includes/parser.inc' ;
// Read in options for map builder.
$bases = [
'gray' => 'Gray' ,
'blue-marble' => 'Blue marble' ,
'night-electric' => 'Night Electric' ,
'living' => 'Living Earth' ,
];
2019-04-12 10:10:04 +02:00
$local_file = 'include/javascript/timezonepicker/images/gray-400.png' ;
2019-04-09 18:18:10 +02:00
// Dimensions must always be exact since the imagemap does not scale.
$array_size = getimagesize ( $local_file );
$map_width = $array_size [ 0 ];
$map_height = $array_size [ 1 ];
$timezones = timezone_picker_parse_files (
$map_width ,
$map_height ,
'include/javascript/timezonepicker/tz_world.txt' ,
'include/javascript/timezonepicker/tz_islands.txt'
);
}
2019-03-12 08:56:45 +01:00
// Update user info.
2019-01-30 16:18:44 +01:00
if ( isset ( $_GET [ 'modified' ]) && ! $view_mode ) {
if ( html_print_csrf_error ()) {
return ;
}
$upd_info = [];
$upd_info [ 'fullname' ] = get_parameter_post ( 'fullname' , $user_info [ 'fullname' ]);
$upd_info [ 'firstname' ] = get_parameter_post ( 'firstname' , $user_info [ 'firstname' ]);
$upd_info [ 'lastname' ] = get_parameter_post ( 'lastname' , $user_info [ 'lastname' ]);
$password_new = get_parameter_post ( 'password_new' , '' );
$password_confirm = get_parameter_post ( 'password_conf' , '' );
2020-12-02 16:29:45 +01:00
$current_password = get_parameter_post ( 'current_password' , '' );
2019-01-30 16:18:44 +01:00
$upd_info [ 'email' ] = get_parameter_post ( 'email' , '' );
$upd_info [ 'phone' ] = get_parameter_post ( 'phone' , '' );
$upd_info [ 'comments' ] = get_parameter_post ( 'comments' , '' );
2022-09-12 12:41:09 +02:00
$upd_info [ 'allowed_ip_active' ] = (( int ) get_parameter_switch ( 'allowed_ip_active' , - 1 ) === 0 );
$upd_info [ 'allowed_ip_list' ] = io_safe_input ( strip_tags ( io_safe_output (( string ) get_parameter ( 'allowed_ip_list' ))));
$upd_info [ 'comments' ] = get_parameter_post ( 'comments' , '' );
2019-01-30 16:18:44 +01:00
$upd_info [ 'language' ] = get_parameter_post ( 'language' , $user_info [ 'language' ]);
$upd_info [ 'timezone' ] = get_parameter_post ( 'timezone' , '' );
$upd_info [ 'id_skin' ] = get_parameter ( 'skin' , $user_info [ 'id_skin' ]);
2019-02-19 14:55:44 +01:00
$upd_info [ 'default_event_filter' ] = get_parameter ( 'event_filter' , null );
2019-01-30 16:18:44 +01:00
$upd_info [ 'block_size' ] = get_parameter ( 'block_size' , $config [ 'block_size' ]);
2023-02-03 14:10:26 +01:00
2022-06-28 17:24:49 +02:00
// API Token information.
$apiTokenRenewed = ( bool ) get_parameter ( 'renewAPIToken' );
$upd_info [ 'api_token' ] = ( $apiTokenRenewed === true ) ? api_token_generate () : users_get_API_token ( $config [ 'id_user' ]);
2021-06-14 13:56:42 +02:00
2023-02-03 14:10:26 +01:00
2019-01-30 16:18:44 +01:00
$default_block_size = get_parameter ( 'default_block_size' , 0 );
2022-06-28 17:24:49 +02:00
if ( $default_block_size > 0 ) {
2019-01-30 16:18:44 +01:00
$upd_info [ 'block_size' ] = 0 ;
}
$upd_info [ 'section' ] = get_parameter ( 'section' , $user_info [ 'section' ]);
$upd_info [ 'data_section' ] = get_parameter ( 'data_section' , '' );
$dashboard = get_parameter ( 'dashboard' , '' );
$visual_console = get_parameter ( 'visual_console' , '' );
2023-02-03 14:10:26 +01:00
2019-02-19 14:55:44 +01:00
// Save autorefresh list.
2019-01-30 16:18:44 +01:00
$autorefresh_list = get_parameter_post ( 'autorefresh_list' );
if (( $autorefresh_list [ 0 ] === '' ) || ( $autorefresh_list [ 0 ] === '0' )) {
$upd_info [ 'autorefresh_white_list' ] = '' ;
} else {
$upd_info [ 'autorefresh_white_list' ] = json_encode ( $autorefresh_list );
}
2023-02-03 14:10:26 +01:00
2019-01-30 16:18:44 +01:00
$upd_info [ 'time_autorefresh' ] = ( int ) get_parameter ( 'time_autorefresh' , 0 );
2019-05-28 13:14:42 +02:00
$upd_info [ 'ehorus_user_level_user' ] = get_parameter ( 'ehorus_user_level_user' );
$upd_info [ 'ehorus_user_level_pass' ] = get_parameter ( 'ehorus_user_level_pass' );
2019-05-28 17:19:13 +02:00
$upd_info [ 'ehorus_user_level_enabled' ] = get_parameter ( 'ehorus_user_level_enabled' , 0 );
2019-01-30 16:18:44 +01:00
$is_admin = db_get_value ( 'is_admin' , 'tusuario' , 'id_user' , $id );
$section = io_safe_output ( $upd_info [ 'section' ]);
2022-09-12 12:41:09 +02:00
if (( $section === 'Event list' ) || ( $section === 'Group view' )
|| ( $section === 'Alert detail' ) || ( $section === 'Tactical view' )
|| ( $section === 'Default' )
2019-02-19 14:55:44 +01:00
) {
2019-01-30 16:18:44 +01:00
$upd_info [ 'data_section' ] = '' ;
2022-09-12 12:41:09 +02:00
} else if ( $section === 'Dashboard' ) {
2019-01-30 16:18:44 +01:00
$upd_info [ 'data_section' ] = $dashboard ;
2022-09-12 12:41:09 +02:00
} else if ( $section === 'Visual console' ) {
2019-01-30 16:18:44 +01:00
$upd_info [ 'data_section' ] = $visual_console ;
}
2021-05-18 10:57:21 +02:00
if ( empty ( $password_new ) === false ) {
2020-12-02 16:29:45 +01:00
$correct_password = false ;
$user_credentials_check = process_user_login ( $config [ 'id_user' ], $current_password , true );
if ( $user_credentials_check !== false ) {
$correct_password = true ;
}
2019-01-30 16:18:44 +01:00
if ( $config [ 'user_can_update_password' ] && $password_confirm == $password_new ) {
2020-12-02 16:29:45 +01:00
if ( $correct_password === true ) {
if (( ! $is_admin || $config [ 'enable_pass_policy_admin' ])
&& $config [ 'enable_pass_policy' ]
) {
$pass_ok = login_validate_pass ( $password_new , $id , true );
if ( $pass_ok != 1 ) {
ui_print_error_message ( $pass_ok );
} else {
$return = update_user_password ( $id , $password_new );
if ( $return ) {
$return2 = save_pass_history ( $id , $password_new );
}
}
2019-01-30 16:18:44 +01:00
} else {
$return = update_user_password ( $id , $password_new );
}
} else {
2020-12-02 16:29:45 +01:00
if ( $current_password === '' ) {
$error_msg = __ ( 'Current password of user is required to perform password change' );
} else {
$error_msg = __ ( 'Current password of user is not correct' );
}
2019-01-30 16:18:44 +01:00
}
} else if ( $password_new !== 'NON-INIT' ) {
$error_msg = __ ( 'Passwords didn\'t match or other problem encountered while updating passwords' );
}
2022-06-28 17:24:49 +02:00
} else if ( empty ( $password_new ) === true && empty ( $password_confirm ) === true ) {
2019-01-30 16:18:44 +01:00
$return = true ;
2022-06-28 17:24:49 +02:00
} else if ( empty ( $password_new ) === true || empty ( $password_confirm ) === true ) {
2019-01-30 16:18:44 +01:00
$return = false ;
}
2019-02-19 14:55:44 +01:00
// No need to display "error" here, because when no update is needed
// (no changes in data) SQL function returns 0 (FALSE), but is not an error,
// just no change. Previous error message could be confussing to the user.
2022-06-28 17:24:49 +02:00
if ( $return !== false ) {
2022-09-12 12:41:09 +02:00
if ( empty ( $password_new ) === false && empty ( $password_confirm ) === false ) {
2019-01-30 16:18:44 +01:00
$success_msg = __ ( 'Password successfully updated' );
}
2019-02-19 14:55:44 +01:00
// If info is valid then proceed with update.
2022-09-12 12:41:09 +02:00
if (( filter_var ( $upd_info [ 'email' ], FILTER_VALIDATE_EMAIL ) || empty ( $upd_info [ 'email' ]) === true )
&& ( preg_match ( '/^[0-9- ]+$/D' , $upd_info [ 'phone' ]) || empty ( $upd_info [ 'phone' ]) === true )
2019-02-19 14:55:44 +01:00
) {
2019-01-30 16:18:44 +01:00
$return_update_user = update_user ( $id , $upd_info );
if ( $return_update_user === false ) {
$error_msg = __ ( 'Error updating user info' );
} else if ( $return_update_user == true ) {
2022-06-28 17:24:49 +02:00
if ( $apiTokenRenewed === true ) {
$success_msg = __ ( 'You have generated a new API Token.' );
} else {
$success_msg = __ ( 'User info successfully updated' );
}
2019-01-30 16:18:44 +01:00
} else {
2022-09-12 12:41:09 +02:00
if ( empty ( $password_new ) === false && empty ( $password_confirm ) === false ) {
2019-01-30 16:18:44 +01:00
$success_msg = __ ( 'Password successfully updated' );
2022-01-03 16:10:36 +01:00
} else if ( $upd_info [ 'id_skin' ] !== $user_info [ 'id_skin' ]) {
$success_msg = __ ( 'Skin successfully updated' );
2019-01-30 16:18:44 +01:00
} else {
$return = false ;
$error_msg = __ ( 'No changes have been made' );
}
}
2019-02-19 14:55:44 +01:00
ui_print_result_message (
$return ,
$success_msg ,
$error_msg ,
$user_auth_error
);
2019-01-30 16:18:44 +01:00
} else if ( ! filter_var ( $upd_info [ 'email' ], FILTER_VALIDATE_EMAIL )) {
ui_print_error_message ( __ ( 'Please enter a valid email' ));
} else if ( ! preg_match ( '/^[0-9- ]+$/D' , $upd_info [ 'phone' ])) {
ui_print_error_message ( __ ( 'Please enter a valid phone number' ));
}
$user_info = $upd_info ;
} else {
if ( ! $error_msg ) {
2022-10-04 16:54:34 +02:00
$error_msg = __ ( 'Error updating passwords: ' ) . ( $config [ 'auth_error' ] ? ? '' );
2019-01-30 16:18:44 +01:00
}
$user_auth_error = $config [ 'auth_error' ];
2019-02-19 14:55:44 +01:00
ui_print_result_message (
$return ,
$success_msg ,
$error_msg ,
$user_auth_error
);
2019-01-30 16:18:44 +01:00
}
}
2019-02-19 14:55:44 +01:00
// Prints action status for current message.
2022-06-28 17:24:49 +02:00
if (( int ) $status !== - 1 ) {
2019-01-30 16:18:44 +01:00
ui_print_result_message (
$status ,
__ ( 'User info successfully updated' ),
__ ( 'Error updating user info' )
);
2011-08-31 09:21:18 +02:00
}
2019-01-30 16:18:44 +01:00
2021-05-18 10:57:21 +02:00
if ( is_metaconsole () === true ) {
2019-03-20 16:45:24 +01:00
echo '<div class="user_form_title">' . __ ( 'Edit my User' ) . '</div>' ;
2015-03-06 12:28:05 +01:00
}
2019-01-30 16:18:44 +01:00
2021-05-18 10:57:21 +02:00
$is_management_allowed = true ;
2021-08-23 12:29:17 +02:00
if ( is_metaconsole () === false && is_management_allowed () === false ) {
2021-05-18 10:57:21 +02:00
$is_management_allowed = false ;
2021-09-23 11:16:48 +02:00
if ( is_metaconsole () === false ) {
$url = '<a target="_blank" href="' . ui_get_meta_url (
'index.php?sec=advanced&sec2=advanced/users_setup&tab=user&pure=' . ( int ) $config [ 'pure' ]
) . '">' . __ ( 'metaconsole' ) . '</a>' ;
} else {
$url = __ ( 'any node' );
}
2021-05-18 10:57:21 +02:00
ui_print_warning_message (
2021-06-24 19:48:07 +02:00
__ (
'This node is configured with centralized mode. All users information is read only. Go to %s to manage it.' ,
2021-09-23 11:16:48 +02:00
$url
2021-06-24 19:48:07 +02:00
)
2021-05-18 10:57:21 +02:00
);
}
2019-03-12 08:56:45 +01:00
2019-03-20 13:26:15 +01:00
$user_id = '<div class="label_select_simple"><p class="edit_user_labels">' . __ ( 'User ID' ) . ': </p>' ;
2019-03-12 08:56:45 +01:00
$user_id .= '<span>' . $id . '</span></div>' ;
2019-03-20 13:26:15 +01:00
2023-02-03 14:10:26 +01:00
2022-06-28 17:24:49 +02:00
$user_id .= '<div class="label_select_simple"><p class="edit_user_labels">' . __ ( 'API Token' ) . '</p>' ;
2022-12-30 16:11:49 +01:00
if ( is_management_allowed ()) {
$user_id .= html_print_anchor (
[
'onClick' => sprintf (
'javascript:renewAPIToken(\'%s\', \'%s\', \'%s\')' ,
__ ( 'Warning' ),
__ ( 'The API token will be renewed. After this action, the last token you were using will not work. Are you sure?' ),
'user_profile_form' ,
),
'content' => html_print_image (
'images/icono-refrescar.png' ,
true ,
[
'class' => 'renew_api_token_image clickable' ,
'title' => __ ( 'Renew API Token' ),
]
),
'class' => 'renew_api_token_link' ,
],
true
);
}
2022-06-28 17:24:49 +02:00
2022-12-29 17:20:34 +01:00
// Check php conf for header auth.
$lines = file ( '/etc/httpd/conf.d/php.conf' );
$http_authorization = false ;
foreach ( $lines as $l ) {
if ( preg_match ( '/SetEnvIfNoCase \^Authorization\$ \"\(\.\+\)\" HTTP_AUTHORIZATION=\$1/' , $l )) {
$http_authorization = true ;
}
}
2022-06-28 17:24:49 +02:00
$user_id .= html_print_anchor (
[
'onClick' => sprintf (
'javascript:showAPIToken(\'%s\', \'%s\')' ,
__ ( 'API Token' ),
base64_encode ( __ ( 'Your API Token is:' ) . '<br><span class="font_12pt bolder">' . users_get_API_token ( $config [ 'id_user' ]) . '</span><br>' . __ ( 'Please, avoid share this string with others.' )),
),
'content' => html_print_image (
2023-03-09 23:31:40 +01:00
'images/see-details@svg.svg' ,
2022-06-28 17:24:49 +02:00
true ,
2022-06-29 09:14:21 +02:00
[
2023-03-09 23:31:40 +01:00
'class' => 'main_menu_icon renew_api_token_image clickable' ,
2022-06-29 09:14:21 +02:00
'title' => __ ( 'Show API Token' ),
]
2022-06-28 17:24:49 +02:00
),
'class' => 'renew_api_token_link' ,
],
true
2022-06-17 12:13:23 +02:00
);
2022-12-29 17:20:34 +01:00
if ( $http_authorization === false ) {
$user_id .= ui_print_help_tip (
__ ( 'Directive HTTP_AUTHORIZATION=$1 is not set. Please, add it to /etc/httpd/conf.d/php.conf' ),
true ,
'images/warn.png' ,
false ,
'' ,
true
);
}
2023-02-03 14:10:26 +01:00
2022-12-29 17:20:34 +01:00
$user_id .= '</div>' ;
2019-03-20 13:26:15 +01:00
$full_name = ' <div class="label_select_simple">' . html_print_input_text_extended (
2019-02-19 14:55:44 +01:00
'fullname' ,
$user_info [ 'fullname' ],
'fullname' ,
'' ,
20 ,
100 ,
$view_mode ,
'' ,
2019-03-12 08:56:45 +01:00
[
'class' => 'input' ,
'placeholder' => __ ( 'Full (display) name' ),
],
2019-02-19 14:55:44 +01:00
true
2019-03-12 08:56:45 +01:00
) . '</div>' ;
2019-02-19 14:55:44 +01:00
2009-11-27 Sancho lerena <slerena@artica.es>
* operation/menu.php: User section has no ACL check, always can be seen.
* index.php: Added suppor for user-defined custom language (this code was
on my disk for 3 months, pending to be commited!).
* include/functions_db.php,
* include/functions_agents.php,
* godmode/alerts/alert_list.php,
* godmode/agentes/modificar_agente.php,
* godmode/agentes/configurar_agente.php: Added audit calls to several
management operations who don't have or have insufficient audit info.
* godmode/users/configure_user.php: Fixed several annoyings bugs. Added
custom language support, and added more audit info on management operations.
* godmode/users/user_list.php: More audit info.
* include/config_process.php: Add new debug option to render error log to
/pandora_console.log. Also set timezone if not defined (this makes warnings
on several PHP 5.x setups). Added user custom language support.
* include/functions_events.php: More audit info. Fixed problems with HTML
encoding render.
* functions_io.php: Some cleaning.
* include/functions_messages.php: Fixed problems with HTML
encoding render.
* functions_ui.php: Fixed problems with HTML encoding render in
print_string_substr() function.
* auth/mysql.php: is_user_admin() functions seems to be broken ¿?¿!. Fixed.
* styles/pandora.css: removed green colored left border in default style.
* message.php, incident*: Fixed problems with HTML encoding render.
* user.php: Better ACL check before let user to view/edit another user.
* user_edit: Removed some un-used form fields, some arrangements in layout,
and FIXED forever problems with password change (new code written).
* users/user_statistics.php: Now user can see its own audit records.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@2139 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-11-27 21:02:12 +01:00
// Show "Picture" (in future versions, why not, allow users to upload it's own avatar here.
2022-06-28 17:24:49 +02:00
if ( is_user_admin ( $id ) === true ) {
2019-03-12 08:56:45 +01:00
$avatar = html_print_image ( 'images/people_1.png' , true , [ 'class' => 'user_avatar' ]);
2019-01-30 16:18:44 +01:00
} else {
2019-03-12 08:56:45 +01:00
$avatar = html_print_image ( 'images/people_2.png' , true , [ 'class' => 'user_avatar' ]);
2013-04-10 09:57:54 +02:00
}
2013-05-23 17:42:32 +02:00
2022-01-12 14:22:16 +01:00
if ( isset ( $table ) === true ) {
if ( $view_mode === false ) {
$table -> rowspan = [ 0 => [ 2 => 3 ]];
} else {
$table -> rowspan = [ 0 => [ 2 => 2 ]];
}
2009-11-27 Sancho lerena <slerena@artica.es>
* operation/menu.php: User section has no ACL check, always can be seen.
* index.php: Added suppor for user-defined custom language (this code was
on my disk for 3 months, pending to be commited!).
* include/functions_db.php,
* include/functions_agents.php,
* godmode/alerts/alert_list.php,
* godmode/agentes/modificar_agente.php,
* godmode/agentes/configurar_agente.php: Added audit calls to several
management operations who don't have or have insufficient audit info.
* godmode/users/configure_user.php: Fixed several annoyings bugs. Added
custom language support, and added more audit info on management operations.
* godmode/users/user_list.php: More audit info.
* include/config_process.php: Add new debug option to render error log to
/pandora_console.log. Also set timezone if not defined (this makes warnings
on several PHP 5.x setups). Added user custom language support.
* include/functions_events.php: More audit info. Fixed problems with HTML
encoding render.
* functions_io.php: Some cleaning.
* include/functions_messages.php: Fixed problems with HTML
encoding render.
* functions_ui.php: Fixed problems with HTML encoding render in
print_string_substr() function.
* auth/mysql.php: is_user_admin() functions seems to be broken ¿?¿!. Fixed.
* styles/pandora.css: removed green colored left border in default style.
* message.php, incident*: Fixed problems with HTML encoding render.
* user.php: Better ACL check before let user to view/edit another user.
* user_edit: Removed some un-used form fields, some arrangements in layout,
and FIXED forever problems with password change (new code written).
* users/user_statistics.php: Now user can see its own audit records.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@2139 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-11-27 21:02:12 +01:00
}
2019-01-30 16:18:44 +01:00
2019-03-20 13:26:15 +01:00
$email = '<div class="label_select_simple">' . html_print_input_text_extended ( 'email' , $user_info [ 'email' ], 'email' , '' , '25' , '100' , $view_mode , '' , [ 'class' => 'input' , 'placeholder' => __ ( 'E-mail' )], true ) . '</div>' ;
2019-03-12 08:56:45 +01:00
2019-03-20 13:26:15 +01:00
$phone = '<div class="label_select_simple">' . html_print_input_text_extended ( 'phone' , $user_info [ 'phone' ], 'phone' , '' , '20' , '30' , $view_mode , '' , [ 'class' => 'input' , 'placeholder' => __ ( 'Phone number' )], true ) . '</div>' ;
2013-04-10 09:57:54 +02:00
2009-01-22 18:44:33 +01:00
if ( $view_mode === false ) {
2019-01-30 16:18:44 +01:00
if ( $config [ 'user_can_update_password' ]) {
2019-03-20 13:26:15 +01:00
$new_pass = '<div class="label_select_simple"><span>' . html_print_input_text_extended ( 'password_new' , '' , 'password_new' , '' , '25' , '45' , $view_mode , '' , [ 'class' => 'input' , 'placeholder' => __ ( 'New Password' )], true , true ) . '</span></div>' ;
$new_pass_confirm = '<div class="label_select_simple"><span>' . html_print_input_text_extended ( 'password_conf' , '' , 'password_conf' , '' , '20' , '45' , $view_mode , '' , [ 'class' => 'input' , 'placeholder' => __ ( 'Password confirmation' )], true , true ) . '</span></div>' ;
2020-12-02 16:29:45 +01:00
$current_pass = '<div class="label_select_simple"><span>' . html_print_input_text_extended ( 'current_password' , '' , 'current_password' , '' , '20' , '45' , $view_mode , '' , [ 'class' => 'input' , 'placeholder' => __ ( 'Current password' )], true , true ) . '</span></div>' ;
2019-01-30 16:18:44 +01:00
} else {
2019-03-12 08:56:45 +01:00
$new_pass = '<i>' . __ ( 'You cannot change your password under the current authentication scheme' ) . '</i>' ;
$new_pass_confirm = '' ;
2020-12-02 16:29:45 +01:00
$current_pass = '' ;
2019-01-30 16:18:44 +01:00
}
}
2019-03-20 13:26:15 +01:00
$size_pagination = '<div class="label_select_simple"><p class="edit_user_labels">' . __ ( 'Block size for pagination' ) . '</p>' ;
2019-01-30 16:18:44 +01:00
if ( $user_info [ 'block_size' ] == 0 ) {
$block_size = $config [ 'global_block_size' ];
} else {
$block_size = $user_info [ 'block_size' ];
2008-08-11 Esteban Sanchez <estebans@artica.es>
* include/functions_db.php: Added __ as an alias of lang_string().
* include/functions_reporting_pdf.php,
include/functions_reporting.php, include/functions.php,
include/functions_visual_map.php, index.php,
operation/incidents/incident.php,
operation/incidents/incident_detail.php,
operation/incidents/incident_note.php,
operation/incidents/incident_search.php,
operation/incidents/incident_statistics.php,
operation/snmpconsole/snmp_alert.php,
operation/snmpconsole/snmp_view.php, operation/users/user.php,
operation/users/user_edit.php, operation/users/user_statistics.php,
operation/events/event_statistics.php, operation/events/events.php,
operation/visual_console/render_view.php,
operation/visual_console/index.php, operation/extensions.php,
operation/agentes/estado_alertas.php,
operation/agentes/status_monitor.php,
operation/agentes/estado_grupo.php, operation/agentes/export_csv.php,
operation/agentes/datos_agente.php,
operation/agentes/estado_ultimopaquete.php,
operation/agentes/estado_generalagente.php,
operation/agentes/estado_agente.php, operation/agentes/bulbs.php,
operation/agentes/status_events.php, operation/agentes/sla_view.php,
operation/agentes/exportdata.php,
operation/agentes/estado_monitores.php,
operation/agentes/ver_agente.php, operation/agentes/estadisticas.php,
operation/agentes/tactical.php, operation/agentes/networkmap.php,
operation/messages/message.php,
operation/reporting/reporting_viewer.php,
operation/reporting/graph_viewer.php,
operation/reporting/custom_reporting.php,
operation/servers/view_server.php,
operation/servers/view_server_detail.php, operation/menu.php,
reporting/fgraph.php, reporting/stat_win.php, ajax.php,
general/logoff.php, general/pandora_help.php, general/footer.php,
general/noaccess.php, general/logon_failed.php,
general/links_menu.php, general/login_page.php, general/logon_ok.php,
general/header.php, general/main_menu.php,
godmode/groups/configure_group.php, godmode/groups/group_list.php,
godmode/setup/news.php, godmode/setup/links.php,
godmode/setup/setup.php, godmode/users/user_list.php,
godmode/users/configure_user.php, godmode/profiles/profile_list.php,
godmode/admin_access_logs.php, godmode/db/db_info_data.php,
godmode/db/db_main.php, godmode/db/db_audit.php,
godmode/db/db_sanity.php, godmode/db/db_refine.php,
godmode/db/db_info.php, godmode/db/db_event.php,
godmode/db/db_purge.php, godmode/extensions.php,
godmode/agentes/agent_template.php,
godmode/agentes/module_manager_editor_network.php,
godmode/agentes/module_manager_editor_wmi.php,
godmode/agentes/alert_manager.php,
godmode/agentes/module_manager_editor_plugin.php,
godmode/agentes/module_manager_editor_prediction.php,
godmode/agentes/alert_manager_editor.php,
godmode/agentes/manage_config.php,
godmode/agentes/module_manager_editor_data.php,
godmode/agentes/module_manager.php,
godmode/agentes/modificar_agente.php,
godmode/agentes/configurar_agente.php,
godmode/agentes/agent_disk_conf_editor.php,
godmode/agentes/planned_downtime.php,
godmode/agentes/manage_config_remote.php,
godmode/agentes/agent_manager.php,
godmode/modules/manage_network_components_form.php,
godmode/modules/manage_nc_groups_form.php,
godmode/modules/manage_network_templates.php,
godmode/modules/module_list.php,
godmode/modules/manage_network_templates_form.php,
godmode/modules/manage_network_components_form_network.php,
godmode/modules/manage_network_components_form_wmi.php,
godmode/modules/manage_network_components.php,
godmode/modules/manage_nc_groups.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/map_builder.php,
godmode/reporting/graph_builder.php, godmode/servers/plugin.php,
godmode/servers/manage_recontask.php,
godmode/servers/modificar_server.php,
godmode/servers/manage_recontask_form.php,
godmode/alerts/modify_alert.php, godmode/alerts/configure_alert.php,
godmode/menu.php: Replaced $id_user with $config['id_user']. Use __a
instead of $lang_label to future use of gettext. Style
corrections.
* godmode/agentes/planned_downtime.php: Rewritten to use Pandora
functions and adopt the UI style. Replaced lang_string with __().
* pandoradb.sql: Fields in tplanned_downtime renamed to fit
guidelines.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1005 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2008-08-11 12:59:07 +02:00
}
2009-01-22 18:44:33 +01:00
2019-03-20 13:26:15 +01:00
$size_pagination .= html_print_input_text ( 'block_size' , $block_size , '' , 5 , 5 , true );
$size_pagination .= html_print_checkbox_switch ( 'default_block_size' , 1 , $user_info [ 'block_size' ] == 0 , true );
$size_pagination .= '<span>' . __ ( 'Default' ) . ' (' . $config [ 'global_block_size' ] . ')</span>' . ui_print_help_tip ( __ ( 'If checkbox is clicked then block size global configuration is used' ), true ) . '</div>' ;
2013-05-23 17:42:32 +02:00
2019-01-30 16:18:44 +01:00
$values = [
- 1 => __ ( 'Default' ),
1 => __ ( 'Yes' ),
0 => __ ( 'No' ),
];
2013-05-23 17:42:32 +02:00
2019-03-20 13:26:15 +01:00
$language = '<div class="label_select"><p class="edit_user_labels">' . __ ( 'Language' ) . ': </p>' ;
$language .= html_print_select_from_sql (
2019-01-30 16:18:44 +01:00
'SELECT id_language, name FROM tlanguage' ,
'language' ,
$user_info [ 'language' ],
'' ,
__ ( 'Default' ),
'default' ,
true ,
'' ,
'' ,
'' ,
'' ,
'' ,
10
2019-03-12 08:56:45 +01:00
) . '</div>' ;
2013-06-25 13:20:13 +02:00
2019-01-30 16:18:44 +01:00
$own_info = get_user_info ( $config [ 'id_user' ]);
if ( $own_info [ 'is_admin' ] || check_acl ( $config [ 'id_user' ], 0 , 'PM' )) {
$display_all_group = true ;
} else {
$display_all_group = false ;
}
2013-04-11 17:41:51 +02:00
$usr_groups = ( users_get_groups ( $config [ 'id_user' ], 'AR' , $display_all_group ));
$id_usr = $config [ 'id_user' ];
2022-01-17 11:32:51 +01:00
$skin = '' ;
2023-04-28 09:51:30 +02:00
2019-09-04 16:05:10 +02:00
$home_screen = '<div class="label_select"><p class="edit_user_labels">' . __ ( 'Home screen' ) . ui_print_help_tip ( __ ( 'User can customize the home page. By default, will display \'Agent Detail\'. Example: Select \'Other\' and type index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente=1 to show agent detail view' ), true ) . '</p>' ;
2019-01-30 16:18:44 +01:00
$values = [
'Default' => __ ( 'Default' ),
'Visual console' => __ ( 'Visual console' ),
'Event list' => __ ( 'Event list' ),
'Group view' => __ ( 'Group view' ),
'Tactical view' => __ ( 'Tactical view' ),
'Alert detail' => __ ( 'Alert detail' ),
'Other' => __ ( 'Other' ),
2020-03-26 12:29:38 +01:00
'Dashboard' => __ ( 'Dashboard' ),
2019-01-30 16:18:44 +01:00
];
2023-05-22 12:08:27 +02:00
if ( is_metaconsole () === true ) {
$home_screen .= html_print_select ( $values , 'metaconsole_section' , io_safe_output ( $user_info [ 'section' ]), 'show_data_section();' , '' , - 1 , true , false , false ) . '</div>' ;
} else {
$home_screen .= html_print_select ( $values , 'section' , io_safe_output ( $user_info [ 'section' ]), 'show_data_section();' , '' , - 1 , true , false , false ) . '</div>' ;
}
2019-01-30 16:18:44 +01:00
2023-01-24 10:12:37 +01:00
$dashboards = Manager :: getDashboards (
- 1 ,
- 1 ,
false ,
false ,
$config [ 'id_user' ]
);
2019-01-30 16:18:44 +01:00
2020-03-26 12:29:38 +01:00
$dashboards_aux = [];
if ( $dashboards === false ) {
$dashboards = [ 'None' => 'None' ];
} else {
foreach ( $dashboards as $key => $dashboard ) {
$dashboards_aux [ $dashboard [ 'id' ]] = $dashboard [ 'name' ];
2019-01-30 16:18:44 +01:00
}
}
2021-04-13 15:37:44 +02:00
$home_screen .= '<div id="show_db" style="display: none; width: 100%;">' ;
2021-04-13 13:23:22 +02:00
$home_screen .= html_print_select ( $dashboards_aux , 'dashboard' , $user_info [ 'data_section' ], '' , '' , '' , true , false , false , '' );
$home_screen .= '</div>' ;
2020-03-26 12:29:38 +01:00
2019-01-30 16:18:44 +01:00
$layouts = visual_map_get_user_layouts ( $config [ 'id_user' ], true );
$layouts_aux = [];
if ( $layouts === false ) {
$layouts_aux = [ 'None' => 'None' ];
} else {
foreach ( $layouts as $layout ) {
$layouts_aux [ $layout ] = $layout ;
}
}
2021-04-13 16:29:28 +02:00
$home_screen .= '<div id="show_vc" style="display: none; width: 100%;">' ;
2019-03-12 08:56:45 +01:00
$home_screen .= html_print_select ( $layouts_aux , 'visual_console' , $user_info [ 'data_section' ], '' , '' , '' , true );
2021-04-13 13:23:22 +02:00
$home_screen .= '</div>' ;
2019-03-12 08:56:45 +01:00
$home_screen .= html_print_input_text ( 'data_section' , $user_info [ 'data_section' ], '' , 60 , 255 , true , false );
2019-01-30 16:18:44 +01:00
2019-02-19 14:55:44 +01:00
// User only can change skins if has more than one group.
2019-01-30 16:18:44 +01:00
if ( function_exists ( 'skins_print_select' )) {
if ( count ( $usr_groups ) > 1 ) {
2022-12-22 11:01:21 +01:00
$skin = '<div class="label_select"><p class="edit_user_labels">' . __ ( 'Theme' ) . ': </p>' ;
2019-03-20 13:26:15 +01:00
$skin .= skins_print_select ( $id_usr , 'skin' , $user_info [ 'id_skin' ], '' , __ ( 'None' ), 0 , true ) . '</div>' ;
2019-01-30 16:18:44 +01:00
}
}
2018-04-30 15:34:46 +02:00
2013-04-10 09:57:54 +02:00
2023-04-28 09:51:30 +02:00
$timezone = '<div class="label_select"><p class="edit_user_labels">' . __ ( 'Timezone' ) . ui_print_help_tip ( __ ( 'The timezone must be that of the associated server.' ), true ) . '</p>' ;
$timezone .= html_print_timezone_select ( 'timezone' , $user_info [ 'timezone' ]) . '</div>' ;
2019-03-20 13:26:15 +01:00
2023-04-28 09:51:30 +02:00
// Double auth.
$double_auth_enabled = ( bool ) db_get_value ( 'id' , 'tuser_double_auth' , 'id_user' , $config [ 'id_user' ]);
2020-10-05 12:29:51 +02:00
2023-04-28 09:51:30 +02:00
if (( bool ) $config [ 'double_auth_enabled' ] === true ) {
$double_authentication = '<div class="label_select_simple"><p class="edit_user_labels">' . __ ( 'Double authentication' ) . '</p>' ;
if (( $config [ '2FA_all_users' ] == '' && ! $double_auth_enabled )
|| ( $config [ '2FA_all_users' ] != '' && ! $double_auth_enabled )
|| ( $config [ 'double_auth_enabled' ] == '' && $double_auth_enabled )
|| check_acl ( $config [ 'id_user' ], 0 , 'PM' )
) {
$double_authentication .= html_print_checkbox_switch ( 'double_auth' , 1 , $double_auth_enabled , true );
}
2019-01-30 16:18:44 +01:00
2023-04-28 09:51:30 +02:00
// Dialog.
$double_authentication .= '<div id="dialog-double_auth"class="invisible"><div id="dialog-double_auth-container"></div></div>' ;
}
2016-05-25 12:43:49 +02:00
2023-04-28 09:51:30 +02:00
if ( $double_auth_enabled && $config [ 'double_auth_enabled' ]) {
$double_authentication .= html_print_button (
__ ( 'Show information' ),
'show_info' ,
false ,
'show_double_auth_info();' ,
[ 'icon' => 'camera' ],
'' ,
true
);
}
2019-01-30 16:18:44 +01:00
2023-04-28 09:51:30 +02:00
if ( isset ( $double_authentication ) === true ) {
$double_authentication .= '</div>' ;
2021-07-06 10:14:59 +02:00
}
2019-01-30 16:18:44 +01:00
2023-05-22 12:08:27 +02:00
if ( is_metaconsole () === true && empty ( $user_info [ 'metaconsole_default_event_filter' ]) !== true ) {
$user_info [ 'default_event_filter' ] = $user_info [ 'metaconsole_default_event_filter' ];
}
2023-04-28 09:51:30 +02:00
if (( bool ) check_acl ( $config [ 'id_user' ], 0 , 'ER' ) === true ) {
$event_filter = '<div class="label_select"><p class="edit_user_labels">' . __ ( 'Event filter' ) . '</p>' ;
$user_groups = implode ( ',' , array_keys (( users_get_groups ( $config [ 'id_user' ], 'AR' , true ))));
$event_filter .= html_print_select_from_sql (
'SELECT id_filter, id_name FROM tevent_filter WHERE id_group_filter IN (' . $user_groups . ')' ,
'event_filter' ,
$user_info [ 'default_event_filter' ],
'' ,
__ ( 'None' ),
null ,
true
) . '</div>' ;
}
2019-09-16 15:51:04 +02:00
2023-04-28 09:51:30 +02:00
$autorefresh_list_out = [];
if ( is_metaconsole () === false || is_centralized () === true ) {
$autorefresh_list_out [ 'operation/agentes/estado_agente' ] = 'Agent detail' ;
$autorefresh_list_out [ 'operation/agentes/alerts_status' ] = 'Alert detail' ;
$autorefresh_list_out [ 'enterprise/operation/cluster/cluster' ] = 'Cluster view' ;
$autorefresh_list_out [ 'operation/gis_maps/render_view' ] = 'Gis Map' ;
$autorefresh_list_out [ 'operation/reporting/graph_viewer' ] = 'Graph Viewer' ;
$autorefresh_list_out [ 'operation/snmpconsole/snmp_view' ] = 'SNMP console' ;
if ( enterprise_installed ()) {
$autorefresh_list_out [ 'general/sap_view' ] = 'SAP view' ;
}
}
2021-07-06 10:14:59 +02:00
2023-04-28 09:51:30 +02:00
$autorefresh_list_out [ 'operation/agentes/tactical' ] = 'Tactical view' ;
$autorefresh_list_out [ 'operation/agentes/group_view' ] = 'Group view' ;
$autorefresh_list_out [ 'operation/agentes/status_monitor' ] = 'Monitor detail' ;
$autorefresh_list_out [ 'enterprise/operation/services/services' ] = 'Services' ;
$autorefresh_list_out [ 'operation/dashboard/dashboard' ] = 'Dashboard' ;
$autorefresh_list_out [ 'operation/visual_console/render_view' ] = 'Visual console' ;
$autorefresh_list_out [ 'operation/events/events' ] = 'Events' ;
if ( ! isset ( $autorefresh_list )) {
$select = db_process_sql ( " SELECT autorefresh_white_list FROM tusuario WHERE id_user = ' " . $config [ 'id_user' ] . " ' " );
$autorefresh_list = json_decode ( $select [ 0 ][ 'autorefresh_white_list' ]);
if ( $autorefresh_list === null ) {
$autorefresh_list [ 0 ] = __ ( 'None' );
} else {
$aux = [];
$count_autorefresh_list = count ( $autorefresh_list );
for ( $i = 0 ; $i < $count_autorefresh_list ; $i ++ ) {
2023-08-29 08:52:50 +02:00
if ( $autorefresh_list [ $i ] === 'operation/agentes/pandora_networkmap' ) {
continue ;
}
2023-04-28 09:51:30 +02:00
$aux [ $autorefresh_list [ $i ]] = $autorefresh_list_out [ $autorefresh_list [ $i ]];
unset ( $autorefresh_list_out [ $autorefresh_list [ $i ]]);
$autorefresh_list [ $i ] = $aux ;
}
2019-01-30 16:18:44 +01:00
2023-04-28 09:51:30 +02:00
$autorefresh_list = $aux ;
2019-01-30 16:18:44 +01:00
}
} else {
2023-04-28 09:51:30 +02:00
if ( is_array ( $autorefresh_list ) === false || empty ( $autorefresh_list [ 0 ]) === true || $autorefresh_list [ 0 ] === '0' ) {
$autorefresh_list = [];
$autorefresh_list [ 0 ] = __ ( 'None' );
} else {
$aux = [];
$count_autorefresh_list = count ( $autorefresh_list );
for ( $i = 0 ; $i < $count_autorefresh_list ; $i ++ ) {
$aux [ $autorefresh_list [ $i ]] = $autorefresh_list_out [ $autorefresh_list [ $i ]];
unset ( $autorefresh_list_out [ $autorefresh_list [ $i ]]);
$autorefresh_list [ $i ] = $aux ;
}
2016-09-05 10:31:43 +02:00
2023-04-28 09:51:30 +02:00
$autorefresh_list = $aux ;
}
2019-01-30 16:18:44 +01:00
}
2016-09-05 10:31:43 +02:00
2023-04-28 09:51:30 +02:00
$autorefresh_show = '<p class="edit_user_labels">' . _ ( 'Autorefresh' ) . ui_print_help_tip (
__ ( 'This will activate autorefresh in selected pages' ),
true
) . '</p>' ;
$select_out = html_print_select (
$autorefresh_list_out ,
'autorefresh_list_out[]' ,
'' ,
'' ,
'' ,
'' ,
true ,
true ,
true ,
'' ,
false ,
'width:100%'
);
$arrows = ' ' ;
$select_in = html_print_select (
$autorefresh_list ,
'autorefresh_list[]' ,
'' ,
'' ,
'' ,
'' ,
true ,
true ,
true ,
'' ,
false ,
'width:100%'
);
2016-09-05 10:31:43 +02:00
2023-04-28 09:51:30 +02:00
$table_ichanges = ' < div class = " autorefresh_select " >
2019-03-20 13:26:15 +01:00
< div class = " autorefresh_select_list_out " >
< p class = " autorefresh_select_text " > '.__(' Full list of pages ').' : </ p >
< div > '.$select_out.' </ div >
</ div >
2021-03-17 16:44:57 +01:00
< div class = " autorefresh_select_arrows " style = " display:grid " >
2019-03-20 13:26:15 +01:00
< a href = " javascript: " > ' . html_print_image (
2022-01-18 10:17:19 +01:00
'images/darrowright_green.png' ,
true ,
[
'id' => 'right_autorefreshlist' ,
'alt' => __ ( 'Push selected pages into autorefresh list' ),
'title' => __ ( 'Push selected pages into autorefresh list' ),
]
2019-02-19 14:55:44 +01:00
) . ' </ a >
2019-03-20 13:26:15 +01:00
< a href = " javascript: " > ' . html_print_image (
'images/darrowleft_green.png' ,
2019-02-19 14:55:44 +01:00
true ,
[
'id' => 'left_autorefreshlist' ,
'alt' => __ ( 'Pop selected pages out of autorefresh list' ),
'title' => __ ( 'Pop selected pages out of autorefresh list' ),
]
) . ' </ a >
2019-03-20 13:26:15 +01:00
</ div >
< div class = " autorefresh_select_list " >
< p class = " autorefresh_select_text " > '.__(' List of pages with autorefresh ').' : </ p >
< div > '.$select_in.' </ div >
</ div >
</ div > ' ;
2023-04-28 09:51:30 +02:00
$autorefresh_show .= $table_ichanges ;
2016-09-05 10:31:43 +02:00
2023-04-28 09:51:30 +02:00
// Time autorefresh.
$times = get_refresh_time_array ();
$time_autorefresh = '<div class="label_select"><p class="edit_user_labels">' . __ ( 'Time autorefresh' );
$time_autorefresh .= ui_print_help_tip (
__ ( 'Interval of autorefresh of the elements, by default they are 30 seconds, needing to enable the autorefresh first' ),
true
) . '</p>' ;
$time_autorefresh .= html_print_select (
$times ,
'time_autorefresh' ,
$user_info [ 'time_autorefresh' ],
'' ,
'' ,
'' ,
true ,
false ,
false
) . '</div>' ;
2019-03-12 08:56:45 +01:00
2023-02-03 14:10:26 +01:00
2023-04-28 09:51:30 +02:00
$comments = '<p class="edit_user_labels">' . __ ( 'Comments' ) . ': </p>' ;
$comments .= html_print_textarea (
'comments' ,
2 ,
60 ,
$user_info [ 'comments' ],
(( $view_mode ) ? 'readonly="readonly"' : '' ),
true
);
$comments .= html_print_input_hidden ( 'quick_language_change' , 1 , true );
$allowedIP = '<p class="edit_user_labels">' ;
$allowedIP .= __ ( 'Login allowed IP list' ) . ' ' ;
$allowedIP .= ui_print_help_tip ( __ ( 'Add the source IPs that will allow console access. Each IP must be separated only by comma. * allows all.' ), true ) . ' ' ;
$allowedIP .= html_print_checkbox_switch (
'allowed_ip_active' ,
0 ,
$user_info [ 'allowed_ip_active' ],
true
);
$allowedIP .= '</p>' ;
$allowedIP .= html_print_textarea (
'allowed_ip_list' ,
2 ,
65 ,
$user_info [ 'allowed_ip_list' ],
( $view_mode ? 'readonly="readonly"' : '' ),
true
);
2022-09-12 12:41:09 +02:00
2012-03-08 17:42:31 +01:00
2023-04-28 09:51:30 +02:00
foreach ( $timezones as $timezone_name => $tz ) {
if ( $timezone_name == 'America/Montreal' ) {
$timezone_name = 'America/Toronto' ;
} else if ( $timezone_name == 'Asia/Chongqing' ) {
$timezone_name = 'Asia/Shanghai' ;
}
2019-04-12 09:20:55 +02:00
2023-04-28 09:51:30 +02:00
$area_data_timezone_polys .= '' ;
foreach ( $tz [ 'polys' ] as $coords ) {
$area_data_timezone_polys .= '<area data-timezone="' . $timezone_name . '" data-country="' . $tz [ 'country' ] . '" data-pin="' . implode ( ',' , $tz [ 'pin' ]) . '" data-offset="' . $tz [ 'offset' ] . '" shape="poly" coords="' . implode ( ',' , $coords ) . '" />' ;
}
2019-04-09 18:18:10 +02:00
2023-04-28 09:51:30 +02:00
$area_data_timezone_rects .= '' ;
foreach ( $tz [ 'rects' ] as $coords ) {
$area_data_timezone_rects .= '<area data-timezone="' . $timezone_name . '" data-country="' . $tz [ 'country' ] . '" data-pin="' . implode ( ',' , $tz [ 'pin' ]) . '" data-offset="' . $tz [ 'offset' ] . '" shape="rect" coords="' . implode ( ',' , $coords ) . '" />' ;
}
2019-04-09 18:18:10 +02:00
}
2023-04-28 09:51:30 +02:00
if ( is_metaconsole () === true ) {
echo '<form id="user_profile_form" name="user_mod" method="post" action="' . ui_get_full_url ( 'index.php?sec=advanced&sec2=advanced/users_setup' ) . '&tab=user_edit&modified=1&pure=' . $config [ 'pure' ] . '">' ;
} else {
echo '<form id="user_profile_form" name="user_mod" method="post" action="' . ui_get_full_url ( 'index.php?sec=workspace&sec2=operation/users/user_edit' ) . '&modified=1&pure=' . $config [ 'pure' ] . '">' ;
}
2012-03-08 17:42:31 +01:00
2021-03-31 13:27:58 +02:00
html_print_input_hidden ( 'id' , $id , false , false , false , 'id' );
2019-03-20 13:26:15 +01:00
echo ' < div id = " user_form " >
< div class = " user_edit_first_row " >
< div class = " edit_user_info white_box " >
< div class = " edit_user_info_left " > '.$avatar.$user_id.' </ div >
2020-12-02 16:29:45 +01:00
< div class = " edit_user_info_right " > '.$full_name.$email.$phone.$new_pass.$new_pass_confirm.$current_pass.' </ div >
2019-03-20 13:26:15 +01:00
</ div >
< div class = " edit_user_autorefresh white_box " > '.$autorefresh_show.$time_autorefresh.' </ div >
</ div >
< div class = " user_edit_second_row white_box " >
2021-06-14 13:56:42 +02:00
< div class = " edit_user_options " > '.$language.$size_pagination.$skin.$home_screen.$event_filter.$double_authentication.' </ div >
2019-04-12 09:20:55 +02:00
< div class = " edit_user_timezone " > ' . $timezone ;
2019-05-09 19:23:18 +02:00
2023-04-28 09:51:30 +02:00
if ( is_metaconsole () === false ) {
echo ' < div id = " timezone-picker " >
2019-04-12 10:10:04 +02:00
< img id = " timezone-image " src = " '. $local_file .' " width = " '. $map_width .' " height = " '. $map_height .' " usemap = " #timezone-map " />
2021-03-11 15:40:23 +01:00
< img class = " timezone-pin pdd_t_4px " src = " include/javascript/timezonepicker/images/pin.png " />
2019-04-12 10:10:04 +02:00
< map name = " timezone-map " id = " timezone-map " > '.$area_data_timezone_polys.$area_data_timezone_rects.' </ map >
</ div > ' ;
2023-04-28 09:51:30 +02:00
}
2019-04-12 09:20:55 +02:00
echo ' </ div >
2022-09-12 12:41:09 +02:00
</ div >
2019-03-20 13:26:15 +01:00
< div class = " user_edit_third_row white_box " >
< div class = " edit_user_comments " > '.$comments.' </ div >
2022-09-12 12:41:09 +02:00
</ div >
< div class = " user_edit_third_row white_box " >
< div class = " edit_user_allowed_ip " > '.$allowedIP.' </ div >
</ div >
2019-03-20 13:26:15 +01:00
</ div > ' ;
2019-05-13 17:28:23 +02:00
2023-04-28 09:51:30 +02:00
if ( $config [ 'ehorus_enabled' ] && $config [ 'ehorus_user_level_conf' ]) {
// EHorus user remote login.
$table_remote = new StdClass ();
$table_remote -> data = [];
$table_remote -> width = '100%' ;
$table_remote -> id = 'ehorus-remote-setup' ;
$table_remote -> class = 'white_box' ;
$table_remote -> size [ 'name' ] = '30%' ;
$table_remote -> style [ 'name' ] = 'font-weight: bold' ;
// Title.
$row = [];
$row [ 'control' ] = '<p class="edit_user_labels">' . __ ( 'eHorus user configuration' ) . ': </p>' ;
$table_remote -> data [ 'ehorus_user_level_conf' ] = $row ;
// Enable/disable eHorus for this user.
$row = [];
$row [ 'name' ] = __ ( 'eHorus user acces enabled' );
$row [ 'control' ] = html_print_checkbox_switch ( 'ehorus_user_level_enabled' , 1 , $user_info [ 'ehorus_user_level_enabled' ], true );
$table_remote -> data [ 'ehorus_user_level_enabled' ] = $row ;
// User.
$row = [];
$row [ 'name' ] = __ ( 'User' );
$row [ 'control' ] = html_print_input_text ( 'ehorus_user_level_user' , $user_info [ 'ehorus_user_level_user' ], '' , 30 , 100 , true );
$table_remote -> data [ 'ehorus_user_level_user' ] = $row ;
// Pass.
$row = [];
$row [ 'name' ] = __ ( 'Password' );
$row [ 'control' ] = html_print_input_password ( 'ehorus_user_level_pass' , io_output_password ( $user_info [ 'ehorus_user_level_pass' ]), '' , 30 , 100 , true );
$table_remote -> data [ 'ehorus_user_level_pass' ] = $row ;
// Test.
$ehorus_port = db_get_value ( 'value' , 'tconfig' , 'token' , 'ehorus_port' );
$ehorus_host = db_get_value ( 'value' , 'tconfig' , 'token' , 'ehorus_hostname' );
$row = [];
$row [ 'name' ] = __ ( 'Test' );
$row [ 'control' ] = html_print_button (
__ ( 'Start' ),
'test-ehorus' ,
false ,
'ehorus_connection_test("' . $ehorus_host . '",' . $ehorus_port . ')' ,
[ 'icon' => 'next' ],
true
);
$row [ 'control' ] .= ' <span id="test-ehorus-spinner" class="invisible"> ' . html_print_image ( 'images/spinner.gif' , true ) . '</span>' ;
$row [ 'control' ] .= ' <span id="test-ehorus-success" class="invisible"> ' . html_print_image ( 'images/status_sets/default/severity_normal.png' , true ) . '</span>' ;
$row [ 'control' ] .= ' <span id="test-ehorus-failure" class="invisible"> ' . html_print_image ( 'images/status_sets/default/severity_critical.png' , true ) . '</span>' ;
$row [ 'control' ] .= '<span id="test-ehorus-message" class="invisible"></span>' ;
$table_remote -> data [ 'ehorus_test' ] = $row ;
echo '<div class="ehorus_user_conf user_edit_fourth_row">' ;
html_print_table ( $table_remote );
echo '</div>' ;
}
2019-05-09 19:23:18 +02:00
2023-04-28 09:51:30 +02:00
if ( $is_management_allowed === true ) {
if (( bool ) $config [ 'user_can_update_info' ] === false ) {
$outputButton = '<i>' . __ ( 'You can not change your user info under the current authentication scheme' ) . '</i>' ;
} else {
$outputButton = html_print_submit_button (
__ ( 'Update' ),
'uptbutton' ,
$view_mode ,
[ 'icon' => 'update' ],
true
);
$outputButton .= html_print_csrf_hidden ( true );
}
2009-01-22 18:44:33 +01:00
2023-04-28 09:51:30 +02:00
html_print_div (
[
'class' => 'action-buttons' ,
'content' => $outputButton ,
]
);
}
2009-01-22 18:44:33 +01:00
2023-04-28 09:51:30 +02:00
echo '</form>' ;
2015-03-06 12:28:05 +01:00
2023-04-28 09:51:30 +02:00
echo '<div id="edit_user_profiles" class="white_box">' ;
if ( is_metaconsole () === false ) {
echo '<p class="edit_user_labels">' . __ ( 'Profiles/Groups assigned to this user' ) . '</p>' ;
}
2015-07-14 15:59:39 +02:00
2023-04-28 09:51:30 +02:00
$table = new stdClass ();
$table -> width = '100%' ;
$table -> class = 'info_table' ;
if ( is_metaconsole () === true ) {
$table -> width = '100%' ;
$table -> class = 'databox data' ;
$table -> title = __ ( 'Profiles/Groups assigned to this user' );
$table -> head_colspan [ 0 ] = 0 ;
$table -> headstyle [] = 'background-color: #82B93C' ;
$table -> headstyle [] = 'background-color: #82B93C' ;
$table -> headstyle [] = 'background-color: #82B93C' ;
}
$table -> data = [];
$table -> head = [];
$table -> align = [];
$table -> style = [];
2015-07-14 15:59:39 +02:00
2023-04-28 09:51:30 +02:00
if ( is_metaconsole () === false ) {
$table -> style [ 0 ] = 'font-weight: bold' ;
$table -> style [ 1 ] = 'font-weight: bold' ;
}
2009-01-22 18:44:33 +01:00
2023-04-28 09:51:30 +02:00
$table -> head [ 0 ] = __ ( 'Profile name' );
$table -> head [ 1 ] = __ ( 'Group' );
$table -> head [ 2 ] = __ ( 'Tags' );
$table -> align = [];
$table -> align [ 1 ] = 'left' ;
2009-01-22 18:44:33 +01:00
2023-04-28 09:51:30 +02:00
$table -> data = [];
2009-01-22 18:44:33 +01:00
2023-04-28 09:51:30 +02:00
$result = db_get_all_rows_field_filter ( 'tusuario_perfil' , 'id_usuario' , $id );
if ( $result === false ) {
$result = [];
2019-01-30 16:18:44 +01:00
}
2023-04-28 09:51:30 +02:00
foreach ( $result as $profile ) {
$data [ 0 ] = '<b>' . profile_get_name ( $profile [ 'id_perfil' ]) . '</b>' ;
if ( $config [ 'show_group_name' ]) {
$data [ 1 ] = ui_print_group_icon (
$profile [ 'id_grupo' ],
true
) . '<a href="index.php?sec=estado&sec2=operation/agentes/estado_agente&refr=60&group_id=' . $profile [ 'id_grupo' ] . '"> </a>' ;
} else {
$data [ 1 ] = ui_print_group_icon (
$profile [ 'id_grupo' ],
true
) . '<a href="index.php?sec=estado&sec2=operation/agentes/estado_agente&refr=60&group_id=' . $profile [ 'id_grupo' ] . '"> ' . ui_print_truncate_text ( groups_get_name ( $profile [ 'id_grupo' ], true ), GENERIC_SIZE_TEXT ) . '</a>' ;
}
2019-01-30 16:18:44 +01:00
2023-04-28 09:51:30 +02:00
$tags_ids = explode ( ',' , $profile [ 'tags' ]);
$tags = tags_get_tags ( $tags_ids );
2006-03-27 05:37:27 +02:00
2023-04-28 09:51:30 +02:00
$data [ 2 ] = tags_get_tags_formatted ( $tags );
2019-01-30 16:18:44 +01:00
2023-04-28 09:51:30 +02:00
array_push ( $table -> data , $data );
}
2013-05-20 10:42:02 +02:00
2023-04-28 09:51:30 +02:00
if ( ! empty ( $table -> data )) {
html_print_table ( $table );
} else {
ui_print_info_message ([ 'no_close' => true , 'message' => __ ( 'This user doesn\'t have any assigned profile/group.' ) ]);
}
2019-03-20 13:26:15 +01:00
2023-04-28 09:51:30 +02:00
// Close edit_user_profiles.
echo '</div>' ;
if ( is_metaconsole () === false ) {
?>
2011-08-08 13:20:56 +02:00
2019-03-20 16:45:24 +01:00
< style >
/* Styles for timezone map */
2019-04-12 09:20:55 +02:00
#timezone-picker div.timezone-picker {
margin : 0 auto ;
2019-03-21 15:58:10 +01:00
}
2019-03-20 16:45:24 +01:00
</ style >
2019-04-12 09:20:55 +02:00
< script language = " javascript " type = " text/javascript " >
$ ( document ) . ready ( function () {
// Set up the picker to update target timezone and country select lists.
$ ( '#timezone-image' ) . timezonePicker ({
target : '#timezone' ,
});
// Optionally an auto-detect button to trigger JavaScript geolocation.
$ ( '#timezone-detect' ) . click ( function () {
$ ( '#timezone-image' ) . timezonePicker ( 'detectLocation' );
});
});
</ script >
2023-04-28 09:51:30 +02:00
< ? php
// Include OpenLayers and timezone user map library.
echo '<script type="text/javascript" src="' . ui_get_full_url ( 'include/javascript/timezonepicker/lib/jquery.timezone-picker.min.js' ) . '"></script>' . " \n \t " ;
echo '<script type="text/javascript" src="' . ui_get_full_url ( 'include/javascript/timezonepicker/lib/jquery.maphilight.min.js' ) . '"></script>' . " \n \t " ;
// Closes no meta condition.
}
2019-05-09 19:23:18 +02:00
2023-04-28 09:51:30 +02:00
?>
2019-03-20 13:26:15 +01:00
2011-08-08 13:20:56 +02:00
< script language = " javascript " type = " text/javascript " >
2019-03-20 13:26:15 +01:00
2011-08-08 13:20:56 +02:00
$ ( document ) . ready ( function () {
2019-01-30 16:18:44 +01:00
$ ( " #right_autorefreshlist " ) . click ( function () {
jQuery . each ( $ ( " select[name='autorefresh_list_out[]'] option:selected " ), function ( key , value ) {
imodule_name = $ ( value ) . html ();
if ( imodule_name != < ? php echo " ' " . __ ( 'None' ) . " ' " ; ?> ) {
id_imodule = $ ( value ) . attr ( 'value' );
$ ( " select[name='autorefresh_list[]'] " ) . append ( $ ( " <option></option> " ) . val ( id_imodule ) . html ( '<i>' + imodule_name + '</i>' ));
$ ( " #autorefresh_list_out " ) . find ( " option[value=' " + id_imodule + " '] " ) . remove ();
$ ( " #autorefresh_list " ) . find ( " option[value=''] " ) . remove ();
$ ( " #autorefresh_list " ) . find ( " option[value='0'] " ) . remove ();
if ( $ ( " #autorefresh_list_out option " ) . length == 0 ) {
$ ( " select[name='autorefresh_list_out[]'] " ) . append ( $ ( " <option></option> " ) . val ( '' ) . html ( '<i><?php echo __(' None '); ?></i>' ));
}
}
});
});
$ ( " #left_autorefreshlist " ) . click ( function () {
jQuery . each ( $ ( " select[name='autorefresh_list[]'] option:selected " ), function ( key , value ) {
imodule_name = $ ( value ) . html ();
if ( imodule_name != < ? php echo " ' " . __ ( 'None' ) . " ' " ; ?> ) {
id_imodule = $ ( value ) . attr ( 'value' );
$ ( " #autorefresh_list " ) . find ( " option[value=' " + id_imodule + " '] " ) . remove ();
$ ( " #autorefresh_list_out " ) . find ( " option[value=''] " ) . remove ();
$ ( " select[name='autorefresh_list_out[]'] " ) . append ( $ ( " <option><option> " ) . val ( id_imodule ) . html ( '<i>' + imodule_name + '</i>' ));
$ ( " #autorefresh_list_out option " ) . last () . remove ();
if ( $ ( " #autorefresh_list option " ) . length == 0 ) {
$ ( " select[name='autorefresh_list[]'] " ) . append ( $ ( " <option></option> " ) . val ( '' ) . html ( '<i><?php echo __(' None '); ?></i>' ));
}
}
});
});
check_default_block_size ()
$ ( " #checkbox-default_block_size " ) . change ( function () {
check_default_block_size ();
});
function check_default_block_size () {
if ( $ ( " #checkbox-default_block_size " ) . is ( ':checked' )) {
$ ( " #text-block_size " ) . attr ( 'disabled' , true );
}
else {
$ ( " #text-block_size " ) . removeAttr ( 'disabled' );
}
}
$ ( " input#checkbox-double_auth " ) . change ( function ( e ) {
e . preventDefault ();
2020-10-05 12:29:51 +02:00
if ( this . checked ) {
show_double_auth_activation ();
} else {
show_double_auth_deactivation ();
}
});
2019-01-30 16:18:44 +01:00
show_data_section ();
2011-08-08 13:20:56 +02:00
});
2012-03-08 17:42:31 +01:00
function show_data_section () {
2019-01-30 16:18:44 +01:00
section = $ ( " #section " ) . val ();
switch ( section ) {
case < ? php echo " ' " . 'Dashboard' . " ' " ; ?> :
$ ( " #text-data_section " ) . css ( " display " , " none " );
$ ( " #dashboard " ) . css ( " display " , " " );
$ ( " #visual_console " ) . css ( " display " , " none " );
2021-04-13 13:23:22 +02:00
$ ( " #show_vc " ) . css ( " display " , " none " );
$ ( " #show_db " ) . css ( " display " , " inline-grid " );
2019-01-30 16:18:44 +01:00
break ;
case < ? php echo " ' " . 'Visual console' . " ' " ; ?> :
$ ( " #text-data_section " ) . css ( " display " , " none " );
$ ( " #dashboard " ) . css ( " display " , " none " );
$ ( " #visual_console " ) . css ( " display " , " " );
2021-04-13 13:23:22 +02:00
$ ( " #show_vc " ) . css ( " display " , " inline-grid " );
$ ( " #show_db " ) . css ( " display " , " none " );
2019-01-30 16:18:44 +01:00
break ;
case < ? php echo " ' " . 'Event list' . " ' " ; ?> :
$ ( " #text-data_section " ) . css ( " display " , " none " );
$ ( " #dashboard " ) . css ( " display " , " none " );
$ ( " #visual_console " ) . css ( " display " , " none " );
2021-04-13 13:23:22 +02:00
$ ( " #show_vc " ) . css ( " display " , " none " );
$ ( " #show_db " ) . css ( " display " , " none " );
2019-01-30 16:18:44 +01:00
break ;
case < ? php echo " ' " . 'Group view' . " ' " ; ?> :
$ ( " #text-data_section " ) . css ( " display " , " none " );
$ ( " #dashboard " ) . css ( " display " , " none " );
$ ( " #visual_console " ) . css ( " display " , " none " );
2021-04-13 13:23:22 +02:00
$ ( " #show_vc " ) . css ( " display " , " none " );
$ ( " #show_db " ) . css ( " display " , " none " );
2019-01-30 16:18:44 +01:00
break ;
case < ? php echo " ' " . 'Tactical view' . " ' " ; ?> :
$ ( " #text-data_section " ) . css ( " display " , " none " );
$ ( " #dashboard " ) . css ( " display " , " none " );
$ ( " #visual_console " ) . css ( " display " , " none " );
2021-04-13 13:23:22 +02:00
$ ( " #show_vc " ) . css ( " display " , " none " );
$ ( " #show_db " ) . css ( " display " , " none " );
2019-01-30 16:18:44 +01:00
break ;
case < ? php echo " ' " . 'Alert detail' . " ' " ; ?> :
$ ( " #text-data_section " ) . css ( " display " , " none " );
$ ( " #dashboard " ) . css ( " display " , " none " );
$ ( " #visual_console " ) . css ( " display " , " none " );
2021-04-13 13:23:22 +02:00
$ ( " #show_vc " ) . css ( " display " , " none " );
$ ( " #show_db " ) . css ( " display " , " none " );
2019-01-30 16:18:44 +01:00
break ;
case < ? php echo " ' " . 'Other' . " ' " ; ?> :
$ ( " #text-data_section " ) . css ( " display " , " " );
$ ( " #dashboard " ) . css ( " display " , " none " );
$ ( " #visual_console " ) . css ( " display " , " none " );
2021-04-13 13:23:22 +02:00
$ ( " #show_vc " ) . css ( " display " , " none " );
$ ( " #show_db " ) . css ( " display " , " none " );
2019-01-30 16:18:44 +01:00
break ;
case < ? php echo " ' " . 'Default' . " ' " ; ?> :
$ ( " #text-data_section " ) . css ( " display " , " none " );
$ ( " #dashboard " ) . css ( " display " , " none " );
$ ( " #visual_console " ) . css ( " display " , " none " );
2021-04-13 13:23:22 +02:00
$ ( " #show_vc " ) . css ( " display " , " none " );
$ ( " #show_db " ) . css ( " display " , " none " );
2019-01-30 16:18:44 +01:00
break ;
}
2012-03-08 17:42:31 +01:00
}
2014-12-11 16:17:35 +01:00
function show_double_auth_info () {
2019-01-30 16:18:44 +01:00
var userID = " <?php echo $config['id_user'] ; ?> " ;
var $loadingSpinner = $ ( " <img src= \" <?php echo $config['homeurl'] ; ?>/images/spinner.gif \" /> " );
var $dialogContainer = $ ( " div#dialog-double_auth-container " );
$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 ,
2021-03-02 13:24:03 +01:00
id_user_auth : userID ,
2019-01-30 16:18:44 +01:00
get_double_auth_data_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>'; ?> " );
}
});
$ ( " div#dialog-double_auth " )
2019-03-12 08:56:45 +01:00
. css ( 'display' , 'block' )
2019-01-30 16:18:44 +01:00
. append ( $dialogContainer )
. dialog ({
resizable : true ,
draggable : true ,
modal : true ,
title : " <?php echo __('Double autentication information'); ?> " ,
overlay : {
opacity : 0.5 ,
background : " black "
},
width : 400 ,
height : 375 ,
close : function ( event , ui ) {
// Abort the ajax request
if ( typeof request != 'undefined' )
request . abort ();
// Remove the contained html
$dialogContainer . empty ();
}
})
. show ();
2014-12-11 16:17:35 +01:00
}
function show_double_auth_activation () {
2019-01-30 16:18:44 +01:00
var userID = " <?php echo $config['id_user'] ; ?> " ;
var $loadingSpinner = $ ( " <img src= \" <?php echo $config['homeurl'] ; ?>/images/spinner.gif \" /> " );
var $dialogContainer = $ ( " div#dialog-double_auth-container " );
$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>'; ?> " );
}
});
$ ( " div#dialog-double_auth " ) . dialog ({
resizable : true ,
draggable : true ,
modal : true ,
2022-09-22 08:59:39 +02:00
title : " <?php echo __('Double authentication activation'); ?> " ,
2019-01-30 16:18:44 +01:00
overlay : {
opacity : 0.5 ,
background : " black "
},
width : 500 ,
height : 400 ,
close : function ( event , ui ) {
// Abort the ajax request
if ( typeof request != 'undefined' )
request . abort ();
// Remove the contained html
$dialogContainer . empty ();
document . location . reload ();
}
})
. show ();
2014-12-11 16:17:35 +01:00
}
function show_double_auth_deactivation () {
2019-01-30 16:18:44 +01:00
var userID = " <?php echo $config['id_user'] ; ?> " ;
var $loadingSpinner = $ ( " <img src= \" <?php echo $config['homeurl'] ; ?>/images/spinner.gif \" /> " );
var $dialogContainer = $ ( " div#dialog-double_auth-container " );
var message = " <p><?php echo __('Are you sure?').'<br>'.__('The double authentication will be deactivated'); ?></p> " ;
var $button = $ ( " <input type= \" button \" value= \" <?php echo __('Deactivate'); ?> \" /> " );
$dialogContainer
. empty ()
. append ( message )
. append ( $button );
var request ;
$button . click ( function ( e ) {
e . preventDefault ();
$dialogContainer . html ( $loadingSpinner );
// Deactivate the double auth
request = $ . ajax ({
url : " <?php echo ui_get_full_url('ajax.php', false, false, false); ?> " ,
type : 'POST' ,
dataType : 'json' ,
data : {
page : 'include/ajax/double_auth.ajax' ,
id_user : userID ,
deactivate_double_auth : 1
},
complete : function ( xhr , textStatus ) {
},
success : function ( data , textStatus , xhr ) {
if ( data === - 1 ) {
$dialogContainer . html ( " <?php echo '<b><div class= \" red \" >'.__('Authentication error').'</div></b>'; ?> " );
}
else if ( data ) {
$dialogContainer . html ( " <?php echo '<b><div class= \" green \" >'.__('The double autentication was deactivated successfully').'</div></b>'; ?> " );
}
else {
$dialogContainer . html ( " <?php echo '<b><div class= \" red \" >'.__('There was an error deactivating the double autentication').'</div></b>'; ?> " );
}
},
error : function ( xhr , textStatus , errorThrown ) {
$dialogContainer . html ( " <?php echo '<b><div class= \" red \" >'.__('There was an error deactivating the double autentication').'</div></b>'; ?> " );
}
});
});
$ ( " div#dialog-double_auth " ) . dialog ({
resizable : true ,
draggable : true ,
modal : true ,
2022-09-22 08:59:39 +02:00
title : " <?php echo __('Double authentication activation'); ?> " ,
2019-01-30 16:18:44 +01:00
overlay : {
opacity : 0.5 ,
background : " black "
},
width : 300 ,
height : 150 ,
close : function ( event , ui ) {
// Abort the ajax request
if ( typeof request != 'undefined' )
request . abort ();
// Remove the contained html
$dialogContainer . empty ();
document . location . reload ();
}
})
. show ();
2014-12-11 16:17:35 +01:00
}
2019-05-09 19:23:18 +02:00
2019-05-10 15:32:25 +02:00
function ehorus_connection_test ( host , port ) {
2019-05-28 13:14:42 +02:00
var user = $ ( 'input#text-ehorus_user_level_user' ) . val ();
var pass = $ ( 'input#password-ehorus_user_level_pass' ) . val ();
2019-05-09 19:23:18 +02:00
2019-09-16 15:51:04 +02:00
2019-05-09 19:23:18 +02:00
var badRequestMessage = '<?php echo __(' Empty user or password '); ?>' ;
var notFoundMessage = '<?php echo __(' User not found '); ?>' ;
var invalidPassMessage = '<?php echo __(' Invalid password '); ?>' ;
var hideLoadingImage = function () {
2019-05-10 15:32:25 +02:00
$ ( '#test-ehorus-spinner' ) . hide ();
2019-05-09 19:23:18 +02:00
}
var showLoadingImage = function () {
2019-05-10 15:32:25 +02:00
$ ( '#test-ehorus-spinner' ) . show ();
2019-05-09 19:23:18 +02:00
}
var hideSuccessImage = function () {
2019-05-10 15:32:25 +02:00
$ ( '#test-ehorus-success' ) . hide ();
2019-05-09 19:23:18 +02:00
}
var showSuccessImage = function () {
2019-05-10 15:32:25 +02:00
$ ( '#test-ehorus-success' ) . show ();
2019-05-09 19:23:18 +02:00
}
var hideFailureImage = function () {
2019-05-10 15:32:25 +02:00
$ ( '#test-ehorus-failure' ) . hide ();
2019-05-09 19:23:18 +02:00
}
var showFailureImage = function () {
2019-05-10 15:32:25 +02:00
$ ( '#test-ehorus-failure' ) . show ();
2019-05-09 19:23:18 +02:00
}
var hideMessage = function () {
2019-05-10 15:32:25 +02:00
$ ( '#test-ehorus-message' ) . hide ();
2019-05-09 19:23:18 +02:00
}
var showMessage = function () {
2019-05-10 15:32:25 +02:00
$ ( '#test-ehorus-message' ) . show ();
2019-05-09 19:23:18 +02:00
}
var changeTestMessage = function ( message ) {
2019-05-10 15:32:25 +02:00
$ ( '#test-ehorus-message' ) . text ( message );
2019-05-09 19:23:18 +02:00
}
hideSuccessImage ();
hideFailureImage ();
hideMessage ();
showLoadingImage ();
$ . ajax ({
url : 'https://' + host + ':' + port + '/login' ,
type : 'POST' ,
dataType : 'json' ,
data : {
user : user ,
pass : pass
}
})
. done ( function ( data , textStatus , xhr ) {
showSuccessImage ();
})
. fail ( function ( xhr , textStatus , errorThrown ) {
showFailureImage ();
if ( xhr . status === 400 ) {
changeTestMessage ( badRequestMessage );
}
else if ( xhr . status === 401 || xhr . status === 403 ) {
changeTestMessage ( invalidPassMessage );
}
else if ( xhr . status === 404 ) {
changeTestMessage ( notFoundMessage );
}
else if ( errorThrown === 'timeout' ) {
changeTestMessage ( timeoutMessage );
}
else {
changeTestMessage ( errorThrown );
}
showMessage ();
})
. always ( function ( xhr , textStatus ) {
hideLoadingImage ();
});
}
2013-03-14 17:52:05 +01:00
</ script >