3 # Change a user's password
5 require './cluster-passwd-lib.pl';
6 &foreign_require("useradmin", "user-lib.pl");
7 &error_setup($text{'passwd_err'});
9 @hosts = &cluster_useradmin::list_useradmin_hosts();
10 @ulist = &get_all_users(\@hosts);
11 ($user) = grep { $_->{'user'} eq $in{'user'} } @ulist;
12 $user || &error($passwd::text{'passwd_euser'});
13 &can_edit_passwd($user) || &error($passwd::text{'passwd_ecannot'});
16 if ($access{'old'} == 1 ||
17 $access{'old'} == 2 && $user->{'user'} ne $remote_user) {
18 &useradmin::validate_password($in{'old'}, $user->{'pass'}) ||
19 &error($passwd::text{'passwd_eold'});
21 if ($access{'repeat'}) {
22 $in{'new'} eq $in{'repeat'} || &error($passwd::text{'passwd_erepeat'});
24 $err = &useradmin::check_password_restrictions(
25 $in{'new'}, $user->{'user'});
26 &error($err) if ($err);
31 &ui_print_header(undef, $text{'passwd_title'}, "");
33 # Do it on all servers
34 &modify_on_hosts(\@hosts, $user->{'user'}, $in{'new'},
35 ($access{'others'} == 1 ||
36 $access{'others'} == 2 && $in{'others'}), \&print_func);
39 delete($user->{'plainpass'});
40 delete($user->{'pass'});
41 &webmin_log("passwd", undef, $user->{'user'}, $user);
43 &ui_print_footer($in{'one'} ? ( "/", $text{'index'} )
44 : ( "", $passwd::text{'index_return'} ));
46 # print_func(mode, message)
50 print "<b>$_[1]</b><p>\n";