]>
git.ipfire.org Git - people/pmueller/ipfire-2.x.git/blob - html/cgi-bin/chpasswd.cgi
2 ###############################################################################
4 # IPFire.org - A linux based firewall #
5 # Copyright (C) 2007 Michael Tremer & Christian Schmidt #
7 # This program is free software: you can redistribute it and/or modify #
8 # it under the terms of the GNU General Public License as published by #
9 # the Free Software Foundation, either version 3 of the License, or #
10 # (at your option) any later version. #
12 # This program is distributed in the hope that it will be useful, #
13 # but WITHOUT ANY WARRANTY; without even the implied warranty of #
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
15 # GNU General Public License for more details. #
17 # You should have received a copy of the GNU General Public License #
18 # along with this program. If not, see <http://www.gnu.org/licenses/>. #
20 ###############################################################################
24 $swroot = "/var/ipfire";
30 $proxysettings{'NCSA_MIN_PASS_LEN'} = 6;
32 ### Initialize environment
33 &readhash
("${swroot}/main/settings", \
%mainsettings);
34 &readhash
("${swroot}/proxy/advanced/settings", \
%proxysettings);
35 $language = $mainsettings{'LANGUAGE'};
37 ### Initialize language
38 if ($language =~ /^(\w+)$/) {$language = $1;}
40 # Uncomment this to force a certain language:
43 require "${swroot}/langs/en.pl";
44 require "${swroot}/langs/${language}.pl";
46 my $userdb = "$swroot/proxy/advanced/ncsa/passwd";
48 &readhash
("$swroot/ethernet/settings", \
%netsettings);
52 &getcgihash
(\
%cgiparams);
54 if ($cgiparams{'SUBMIT'} eq $tr{'advproxy chgwebpwd change password'})
56 if ($cgiparams{'USERNAME'} eq '')
58 $errormessage = $tr{'advproxy errmsg no username'};
61 if (($cgiparams{'OLD_PASSWORD'} eq '') || ($cgiparams{'NEW_PASSWORD_1'} eq '') || ($cgiparams{'NEW_PASSWORD_2'} eq ''))
63 $errormessage = $tr{'advproxy errmsg no password'};
66 if (!($cgiparams{'NEW_PASSWORD_1'} eq $cgiparams{'NEW_PASSWORD_2'}))
68 $errormessage = $tr{'advproxy errmsg passwords different'};
71 if (length($cgiparams{'NEW_PASSWORD_1'}) < $proxysettings{'NCSA_MIN_PASS_LEN'})
73 $errormessage = $tr{'advproxy errmsg password length 1'}.$proxysettings{'NCSA_MIN_PASS_LEN'}.$tr{'advproxy errmsg password length 2'};
88 @temp = split(/:/,$_);
89 if ($temp[0] =~ /^$cgiparams{'USERNAME'}$/i)
98 $errormessage = $tr{'advproxy errmsg invalid user'};
101 if (!(crypt($cgiparams{'OLD_PASSWORD'}, $cryptpwd) eq $cryptpwd))
103 $errormessage = $tr{'advproxy errmsg password incorrect'};
106 $returncode = system("/usr/sbin/htpasswd -b $userdb $username $cgiparams{'NEW_PASSWORD_1'}");
107 if ($returncode == 0)
112 $errormessage = $tr{'advproxy errmsg change fail'};
119 print "Pragma: no-cache\n";
120 print "Cache-control: no-cache\n";
121 print "Connection: close\n";
122 print "Content-type: text/html\n\n";
127 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
131 <body bgcolor="#FFFFFF">
135 <form method='post' action='$ENV{'SCRIPT_NAME'}'>
137 <table width="80%" cellspacing="10" cellpadding="5">
140 <td bgcolor="#FFFFFF" align="center">
141 <table width="100%" cellspacing="10" cellpadding="10" bordercolor="#9A9A9A" border="1">
143 <td nowrap bgcolor="#993333" align="center" >
144 <font face="trebuchet ms, helvetica, sans-serif" color="#FFFFFF" size="4">
145 <b>$tr{'advproxy chgwebpwd change web password'}</b>
151 <table width="50%" cellspacing="7" cellpadding="7">
153 <td nowrap bgcolor="#FFFFFF" align="left">
154 <font face="trebuchet ms, helvetica, sans-serif" color="#666666" size="2">
155 <b>$tr{'advproxy chgwebpwd username'}:</b>
158 <td ><input type="text" name="USERNAME" value="$cgiparams{'USERNAME'}" size="30"></td>
161 <td nowrap bgcolor="#FFFFFF" align="left">
162 <font face="trebuchet ms, helvetica, sans-serif" color="#666666" size="2">
163 <b>$tr{'advproxy chgwebpwd old password'}:</b>
166 <td><input type="password" name="OLD_PASSWORD" value="$cgiparams{'OLD_PASSWORD'}" size="30"></td>
169 <td nowrap bgcolor="#FFFFFF" align="left">
170 <font face="trebuchet ms, helvetica, sans-serif" color="#666666" size="2">
171 <b>$tr{'advproxy chgwebpwd new password'}:</b>
174 <td><input type="password" name="NEW_PASSWORD_1" value="$cgiparams{'NEW_PASSWORD_1'}" size="30"></td>
177 <td nowrap bgcolor="#FFFFFF" align="left">
178 <font face="trebuchet ms, helvetica, sans-serif" color="#666666" size="2">
179 <b>$tr{'advproxy chgwebpwd new password confirm'}:</b>
182 <td><input type="password" name="NEW_PASSWORD_2" value="$cgiparams{'NEW_PASSWORD_2'}" size="30"></td>
185 <table width="100%" cellspacing="7" cellpadding="7">
187 <td align="center"><br><input type='submit' name='SUBMIT' value="$tr{'advproxy chgwebpwd change password'}"></td>
199 <td nowrap bgcolor="#FF0000" align="center">
200 <font face="trebuchet ms, helvetica, sans-serif" color="#FFFFFF" size="2">
201 <b>$tr{'advproxy chgwebpwd ERROR'}</b> $errormessage
213 <td nowrap bgcolor="#00C000" align="center">
214 <font face="trebuchet ms, helvetica, sans-serif" color="#FFFFFF" size="2">
215 <b>$tr{'advproxy chgwebpwd SUCCESS'}</b> $tr{'advproxy errmsg change success'}
242 # -------------------------------------------------------------------
246 my $filename = $_[0];
252 open(FILE
, $filename) or die "Unable to read file $filename";
256 ($var, $val) = split /=/, $_, 2;
262 # Untaint variables read from hash
263 $var =~ /([A-Za-z0-9_-]*)/; $var = $1;
264 $val =~ /([\w\W]*)/; $val = $1;
265 $hash->{$var} = $val;
272 # -------------------------------------------------------------------
276 my ($hash, $params) = @_;
277 my $cgi = CGI
->new ();
278 return if ($ENV{'REQUEST_METHOD'} ne 'POST');
279 if (!$params->{'wantfile'}) {
280 $CGI::DISABLE_UPLOADS
= 1;
281 $CGI::POST_MAX
= 512 * 1024;
283 $CGI::POST_MAX
= 10 * 1024 * 1024;
286 $cgi->referer() =~ m/^https?\:\/\
/([^\/]+)/;
288 $cgi->url() =~ m/^https?\:\/\
/([^\/]+)/;
290 return if ($referer ne $servername);
292 ### Modified for getting multi-vars, split by |
293 %temp = $cgi->Vars();
294 foreach my $key (keys %temp) {
295 $hash->{$key} = $temp{$key};
296 $hash->{$key} =~ s/\0/|/g;
297 $hash->{$key} =~ s/^\s*(.*?)\s*$/$1/;
300 if (($params->{'wantfile'})&&($params->{'filevar'})) {
301 $hash->{$params->{'filevar'}} = $cgi->upload
302 ($params->{'filevar'});
307 # -------------------------------------------------------------------