Commit 8b6eecc5 authored by mkanat%bugzilla.org's avatar mkanat%bugzilla.org

Bug 342757: searching results in "YOUR BROWSER DOESN'T SUPPORT THIS SERVER-PUSH…

Bug 342757: searching results in "YOUR BROWSER DOESN'T SUPPORT THIS SERVER-PUSH TECHNOLOGY" warning on brower under mod_perl Patch By Max Kanat-Alexander <mkanat@bugzilla.org> r=justdave, a=justdave
parent dbb4dc8e
...@@ -158,14 +158,27 @@ sub multipart_init { ...@@ -158,14 +158,27 @@ sub multipart_init {
# CGI.pm's header() sets nph according to a param or $CGI::NPH, which # CGI.pm's header() sets nph according to a param or $CGI::NPH, which
# is the desired behaviour. # is the desired behaviour.
# Allow multiple calls to $cgi->header()
$CGI::HEADERS_ONCE = 0;
return $self->header( return $self->header(
%param, %param,
) . "WARNING: YOUR BROWSER DOESN'T SUPPORT THIS SERVER-PUSH TECHNOLOGY." . $self->multipart_end; ) . "WARNING: YOUR BROWSER DOESN'T SUPPORT THIS SERVER-PUSH TECHNOLOGY." . $self->multipart_end;
} }
# Have to add the cookies in.
sub multipart_start {
my $self = shift;
my $headers = $self->SUPER::multipart_start(@_);
# Eliminate the one extra CRLF at the end.
$headers =~ s/$CGI::CRLF$//;
# Add the cookies. We have to do it this way instead of
# passing them to multpart_start, because CGI.pm's multipart_start
# doesn't understand a '-cookie' argument pointing to an arrayref.
foreach my $cookie (@{$self->{Bugzilla_cookie_list}}) {
$headers .= "Set-Cookie: ${cookie}${CGI::CRLF}";
}
$headers .= $CGI::CRLF;
return $headers;
}
# Override header so we can add the cookies in # Override header so we can add the cookies in
sub header { sub header {
my $self = shift; my $self = shift;
...@@ -183,13 +196,6 @@ sub header { ...@@ -183,13 +196,6 @@ sub header {
return $self->SUPER::header(@_) || ""; return $self->SUPER::header(@_) || "";
} }
# Override multipart_start to ensure our cookies are added and avoid bad quoting of
# CGI's multipart_start (bug 275108)
sub multipart_start {
my $self = shift;
return $self->header(@_);
}
# The various parts of Bugzilla which create cookies don't want to have to # The various parts of Bugzilla which create cookies don't want to have to
# pass them around to all of the callers. Instead, store them locally here, # pass them around to all of the callers. Instead, store them locally here,
# and then output as required from |header|. # and then output as required from |header|.
......
...@@ -884,6 +884,12 @@ if ($serverpush) { ...@@ -884,6 +884,12 @@ if ($serverpush) {
$template->process("list/server-push.html.tmpl", $vars) $template->process("list/server-push.html.tmpl", $vars)
|| ThrowTemplateError($template->error()); || ThrowTemplateError($template->error());
# Under mod_perl, flush stdout so that the page actually shows up.
if ($ENV{MOD_PERL}) {
require Apache2::RequestUtil;
Apache2::RequestUtil->request->rflush();
}
# Don't do multipart_end() until we're ready to display the replacement # Don't do multipart_end() until we're ready to display the replacement
# page, otherwise any errors that happen before then (like SQL errors) # page, otherwise any errors that happen before then (like SQL errors)
# will result in a blank page being shown to the user instead of the error. # will result in a blank page being shown to the user instead of the error.
......
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