3 # Save, create or delete a proxy user
5 require './squid-lib.pl';
6 if ($config{'crypt_conf'} == 1) {
9 &error(&text('eauth_nomd5', $module_name));
13 $access{'proxyauth'} || &error($text{'eauth_ecannot'});
15 $conf = &get_config();
16 $file = &get_auth_file($conf);
18 @users = &list_auth_users($file);
20 $user = $users[$in{'index'}];
22 &replace_file_line($file, $user->{'line'});
25 $whatfailed = $text{'suser_ftsu'};
26 $in{'user'} =~ /^[^:\s]+$/ || &error($text{'suser_emsg1'});
27 local ($same) = grep { $_->{'user'} eq $in{'user'} } @users;
28 local $cmt = $in{'enabled'} ? "" : "#";
30 !$same || &error($text{'suser_etaken'});
31 $pass = &encryptpwd($in{'pass'}, $salt);
32 &open_tempfile(FILE,">>$file");
33 &print_tempfile(FILE, "$cmt$in{'user'}:$pass\n");
34 &close_tempfile(FILE);
37 !$same || $same->{'user'} eq $user->{'user'} ||
38 &error($text{'suser_etaken'});
39 $pass = $in{'pass_def'} ? $user->{'pass'}
40 : &encryptpwd($in{'pass'}, $salt);
41 &replace_file_line($file, $user->{'line'},
42 "$cmt$in{'user'}:$pass\n");
46 &webmin_log($in{'delete'} ? 'delete' : $in{'new'} ? 'create' : 'modify',
47 'user', $in{'user'} ? $in{'user'} : $user->{'user'});
48 &redirect("edit_nauth.cgi");
51 if ($config{'crypt_conf'}) {
53 my $encryptpwd = new MD5;
54 $encryptpwd->add($pwd);
55 $pwd = encode_base64($encryptpwd->hexdigest());
61 $salt = substr(time(), -2);
62 my $pwd = &unix_crypt($_[0], $_[1]);