addElement('text', 'username', get_lang('Login')); $usernameInput->freeze(); // Password $group = []; $auth_sources = 0; //make available wider as we need it in case of form reset (see below) $group[] = &$form->createElement('radio', 'password_auto', get_lang('Password'), get_lang('Automatically generate a new password').'
', 1); $group[] = &$form->createElement('radio', 'password_auto', 'id="radio_user_password"', null, 0); $group[] = &$form->createElement('password', 'password', null, ['onkeydown' => 'javascript: password_switch_radio_button(document.user_add,"password[password_auto]");']); $form->addGroup($group, 'password', get_lang('Password')); // Send email $group = []; $group[] = &$form->createElement('radio', 'send_mail', null, get_lang('Yes'), 1); $group[] = &$form->createElement('radio', 'send_mail', null, get_lang('No'), 0); $form->addGroup($group, 'mail', get_lang('Send mail to new user')); // Set default values $defaults = []; $defaults['username'] = $userInfo['username']; $defaults['mail']['send_mail'] = 0; $defaults['password']['password_auto'] = 1; $form->setDefaults($defaults); // Submit button $select_level = []; $html_results_enabled[] = $form->addButtonUpdate(get_lang('Update'), 'submit', true); $form->addGroup($html_results_enabled); // Validate form if ($form->validate()) { $check = Security::check_token('post'); if ($check) { $user = $form->exportValues(); $email = $userInfo['email']; $username = $userInfo['username']; $send_mail = intval($user['mail']['send_mail']); $auth_source = PLATFORM_AUTH_SOURCE; $resetPassword = $user['password']['password_auto'] == '1' ? 0 : 2; $auth_source = $userInfo['auth_source']; $password = $user['password']['password_auto'] == '1' ? api_generate_password() : $user['password']['password']; UserManager::update_user( $userId, $userInfo['firstname'], $userInfo['lastname'], $userInfo['username'], $password, $auth_source, $userInfo['email'], $userInfo['status'], $userInfo['official_code'], $userInfo['phone'], $userInfo['picture_uri'], $userInfo['expiration_date'], $userInfo['active'], $userInfo['creator_id'], $userInfo['hr_dept_id'], null, //$extra = $userInfo['language'], null, //$encrypt_method false, $resetPassword ); if (!empty($email) && $send_mail) { $emailsubject = '['.api_get_setting('siteName').'] '.get_lang('Your registration on').' '.api_get_setting('siteName'); $portal_url = api_get_path(WEB_PATH); if (api_is_multiple_url_enabled()) { $access_url_id = api_get_current_access_url_id(); if ($access_url_id != -1) { $url = api_get_access_url($access_url_id); $portal_url = $url['url']; } } $emailbody = get_lang('Dear')." ".stripslashes(api_get_person_name($userInfo['firstname'], $userInfo['lastname'])).",\n\n". get_lang('You are registered to')." ".api_get_setting('siteName')." ".get_lang('with the following settings:')."\n\n". get_lang('Username')." : ".$username."\n".get_lang('Pass')." : ".stripslashes($password)."\n\n". get_lang('The address of')." ".api_get_setting('siteName')." ". get_lang('is')." : ".$portal_url."\n\n". get_lang('In case of trouble, contact us.')."\n\n". get_lang('Sincerely').",\n\n". api_get_person_name(api_get_setting('administratorName'), api_get_setting('administratorSurname'))."\n". get_lang('Administrator')." ". api_get_setting('siteName')."\nT. ". api_get_setting('administratorTelephone')."\n". get_lang('e-mail')." : ".api_get_setting('emailAdministrator'); $emailbody = nl2br($emailbody); api_mail_html( api_get_person_name($userInfo['firstname'], $userInfo['lastname'], null, PERSON_NAME_EMAIL_ADDRESS), $email, $emailsubject, $emailbody ); } Security::clear_token(); $tok = Security::get_token(); header('Location: '.$url.'&message=1'); exit(); } } else { if (isset($_POST['submit'])) { Security::clear_token(); } $token = Security::get_token(); $form->addElement('hidden', 'sec_token'); $form->setConstants(['sec_token' => $token]); } $interbreadcrumb[] = [ 'url' => api_get_path(WEB_CODE_PATH)."mySpace/student.php", "name" => get_lang('User list'), ]; if (isset($_REQUEST['message'])) { Display::addFlash(Display::return_message(get_lang('Update successful'), 'normal')); } Display::display_header($tool_name); // Display form $form->display(); Display::display_footer();