Commit 7bb05f06 authored by gerv%gerv.net's avatar gerv%gerv.net

Bug 140103 - various templatisations or cleanups in CGI.pl. Patch by gerv; r=justdave, bbaetz.

parent 2ab1c5c3
...@@ -242,11 +242,9 @@ sub CheckFormFieldDefined (\%$) { ...@@ -242,11 +242,9 @@ sub CheckFormFieldDefined (\%$) {
$fieldname, # the fieldname to check $fieldname, # the fieldname to check
) = @_; ) = @_;
if ( !defined $formRef->{$fieldname} ) { if (!defined $formRef->{$fieldname}) {
print "$fieldname was not defined; "; ThrowCodeError("$fieldname was not defined; " .
print Param("browserbugmessage"); Param("browserbugmessage"));
PutFooter();
exit 0;
} }
} }
...@@ -489,22 +487,12 @@ sub CheckEmailSyntax { ...@@ -489,22 +487,12 @@ sub CheckEmailSyntax {
my ($addr) = (@_); my ($addr) = (@_);
my $match = Param('emailregexp'); my $match = Param('emailregexp');
if ($addr !~ /$match/ || $addr =~ /[\\\(\)<>&,;:"\[\] \t\r\n]/) { if ($addr !~ /$match/ || $addr =~ /[\\\(\)<>&,;:"\[\] \t\r\n]/) {
print "Content-type: text/html\n\n"; ThrowUserError("The e-mail address you entered(<b>" .
html_quote($addr) . "</b>) didn't pass our syntax checking
# For security, escape HTML special characters. for a legal email address. " . Param('emailregexpdesc') .
$addr = html_quote($addr); ' It must also not contain any of these special characters:
<tt>\ ( ) &amp; &lt; &gt; , ; : " [ ]</tt>, or any whitespace.',
PutHeader("Check e-mail syntax"); "Check e-mail address syntax");
print "The e-mail address you entered\n";
print "(<b>$addr</b>) didn't match our minimal\n";
print "syntax checking for a legal email address.\n";
print Param('emailregexpdesc') . "\n";
print "It must also not contain any of these special characters: " .
"<tt>\\ ( ) &amp; &lt; &gt; , ; : \" [ ]</tt> " .
"or any whitespace.\n";
print "<p>Please click <b>Back</b> and try again.\n";
PutFooter();
exit;
} }
} }
...@@ -559,24 +547,17 @@ sub confirm_login { ...@@ -559,24 +547,17 @@ sub confirm_login {
if ( defined $::FORM{"PleaseMailAPassword"} && !$userid ) { if ( defined $::FORM{"PleaseMailAPassword"} && !$userid ) {
# Ensure the new login is valid # Ensure the new login is valid
if(!ValidateNewUser($enteredlogin)) { if(!ValidateNewUser($enteredlogin)) {
DisplayError("Account Exists"); ThrowUserError("That account already exists.");
exit;
} }
my $password = InsertNewUser($enteredlogin, ""); my $password = InsertNewUser($enteredlogin, "");
# There's a template for this - account_created.tmpl - but
# it's easier to wait to use it until templatisation has progressed
# further; we want to avoid sprinkling multiple copies of the
# template setup code everywhere - Gerv.
print "Content-Type: text/html\n\n";
PutHeader("Account Created");
MailPassword($enteredlogin, $password); MailPassword($enteredlogin, $password);
print "The password for the e-mail address\n";
print "$enteredlogin has been e-mailed to that address.\n"; $vars->{'login'} = $enteredlogin;
print "<p>When the e-mail arrives, you can click <b>Back</b>\n";
print "and enter your password in the form there.\n"; print "Content-Type: text/html\n\n";
PutFooter(); $template->process("account/created.html.tmpl", $vars)
exit; || ThrowTemplateError($template->error());
} }
# Otherwise, authenticate the user. # Otherwise, authenticate the user.
...@@ -755,14 +736,10 @@ Set-Cookie: Bugzilla_logincookie= ; path=$cookiepath; expires=Sun, 30-Jun-80 00: ...@@ -755,14 +736,10 @@ Set-Cookie: Bugzilla_logincookie= ; path=$cookiepath; expires=Sun, 30-Jun-80 00:
Content-type: text/html Content-type: text/html
"; ";
PutHeader("Your account has been disabled"); ThrowUserError($::disabledreason . "<hr>" .
print $::disabledreason; "If you believe your account should be restored, please " .
print "<HR>\n"; "send email to " . Param("maintainer") . " explaining why.",
print "If you believe your account should be restored, please\n"; "Your account has been disabled");
print "send email to " . Param("maintainer") . " explaining\n";
print "why.\n";
PutFooter();
exit();
} }
print "Content-type: text/html\n\n"; print "Content-type: text/html\n\n";
PutHeader("Login"); PutHeader("Login");
...@@ -871,72 +848,17 @@ Content-type: text/html ...@@ -871,72 +848,17 @@ Content-type: text/html
return $::userid; return $::userid;
} }
sub PutHeader { sub PutHeader {
my ($title, $h1, $h2, $extra, $jscript) = (@_); ($vars->{'title'}, $vars->{'h1'}, $vars->{'h2'},
$vars->{'extra'}, $vars->{'jscript'}) = (@_);
if (!defined $h1) {
$h1 = $title; $::template->process("global/header.html.tmpl", $::vars)
} || ThrowTemplateError($::template->error());
if (!defined $h2) {
$h2 = "";
}
if (!defined $extra) {
$extra = "";
}
$jscript ||= "";
print qq|
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<HTML>
<HEAD>
<TITLE>$title</TITLE>
| . Param("headerhtml") . qq|
$jscript
</HEAD>
<BODY | . Param("bodyhtml") . qq| $extra>
| . PerformSubsts(Param("bannerhtml"), undef) . qq|
<TABLE BORDER="0" CELLSPACING="0">
<TR>
<TD VALIGN="TOP" ALIGN="LEFT">
<TABLE BORDER="0" CELLPADDING="0" CELLSPACING="2">
<TR><TD VALIGN="TOP" ALIGN="LEFT">
<FONT SIZE="+1">
<B>$h1</B>
</FONT>
</TD></TR>
</TABLE>
</TD>
<TD VALIGN="MIDDLE">&nbsp;</TD>
<TD VALIGN="MIDDLE" ALIGN="LEFT">
$h2
</TD></TR></TABLE>
|;
if (Param("shutdownhtml")) {
# If we are dealing with the params page, we want
# to ignore shutdownhtml
if ($0 !~ m:[\\/](do)?editparams.cgi$:) {
print "<p>\n";
print Param("shutdownhtml");
exit;
}
}
} }
# Putfooter echoes footerhtml and by default prints closing tags
#
# param
# dontclose (boolean): avoid sending </body></html>
#
# Example:
# Putfooter(); # normal close
# Putfooter(1); # don't send closing tags
sub PutFooter { sub PutFooter {
my ( $dontclose ) = @_; $::template->process("global/footer.html.tmpl", $::vars)
print PerformSubsts(Param("footerhtml")); || ThrowTemplateError($::template->error());
print "\n</body></html>\n" if ( ! $dontclose );
SyncAnyPendingShadowChanges();
} }
############################################################################### ###############################################################################
...@@ -1035,11 +957,19 @@ sub CheckIfVotedConfirmed { ...@@ -1035,11 +957,19 @@ sub CheckIfVotedConfirmed {
"(bug_id,who,bug_when,fieldid,removed,added) VALUES " . "(bug_id,who,bug_when,fieldid,removed,added) VALUES " .
"($id,$who,now(),$fieldid,'0','1')"); "($id,$who,now(),$fieldid,'0','1')");
} }
AppendComment($id, DBID_to_name($who), AppendComment($id, DBID_to_name($who),
"*** This bug has been confirmed by popular vote. ***"); "*** This bug has been confirmed by popular vote. ***");
print "<TABLE BORDER=1><TD><H2>Bug $id has been confirmed by votes.</H2>\n";
system("./processmail", $id); $vars->{'type'} = "votes";
print "<TD><A HREF=\"show_bug.cgi?id=$id\">Go To BUG# $id</A></TABLE>\n"; $vars->{'id'} = $id;
$vars->{'mail'} = "";
open(PMAIL, "-|") or exec('./processmail', $id);
$vars->{'mail'} .= $_ while <PMAIL>;
close(PMAIL);
$template->process("bug/process/results.html.tmpl", $vars)
|| ThrowTemplateError($template->error());
} }
} }
......
...@@ -34,6 +34,7 @@ ...@@ -34,6 +34,7 @@
'bug' => "Changes submitted for bug" , 'bug' => "Changes submitted for bug" ,
'dupe' => "Duplicate notation added to bug" , 'dupe' => "Duplicate notation added to bug" ,
'dep' => "Checking for dependency changes on bug" , 'dep' => "Checking for dependency changes on bug" ,
'votes' => "Confirmed by number of votes: bug" ,
} }
%] %]
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment