* [PATCH] gitweb: hack around CGI's list-context param() handling
@ 2014-11-18 17:10 Jeff King
2014-11-18 17:58 ` Junio C Hamano
0 siblings, 1 reply; 3+ messages in thread
From: Jeff King @ 2014-11-18 17:10 UTC (permalink / raw)
To: git; +Cc: Michael Haggerty, Jonathan Nieder
As of CGI.pm's 4.08 release, the behavior to call
CGI::param() in a list context is deprecated (because it can
be potentially unsafe if called inside a hash constructor).
This cause gitweb to issue a warning for some of our code,
which in turn causes the tests to fail.
Our use is in fact _not_ one of the dangerous cases, as we
are intentionally using a list context. The recommended
route by 4.08 is to use the new CGI::multi_param() call to
make it explicit that we know what we are doing.
However, that function is only available in 4.08, which is
about a month old; we cannot rely on having it.
One option would be to set $CGI::LIST_CONTEXT_WARN globally,
which turns off the warning. However, that would eliminate
the protection these newer releases are trying to provide.
We want to annotate each site as OK using the new function.
So instead, let's check whether CGI provides the
multi_param() function, and if not, provide an
implementation that just wraps param(). That will work on
both old and new versions of CGI. Sadly, we cannot just
check defined(\&CGI::multi_param), because CGI uses the
autoload feature, which claims that all functions are
defined. Instead, we just do a version check.
Signed-off-by: Jeff King <peff@peff.net>
---
Without this patch, all of the gitweb tests consistently fail on Debian
testing/unstable when you have libcgi-pm-perl installed (it works
without that package installed, because an older version of CGI.pm is in
the perl base). I tested with both versions.
Another approach would be to live with the warning, but teach the tests
to be less meticulous. I think it probably makes sense to keep them
pedantic, though, because it can catch potential errors.
gitweb/gitweb.perl | 6 +++++-
1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/gitweb/gitweb.perl b/gitweb/gitweb.perl
index ccf7516..7a5b23a 100755
--- a/gitweb/gitweb.perl
+++ b/gitweb/gitweb.perl
@@ -20,6 +20,10 @@ use File::Basename qw(basename);
use Time::HiRes qw(gettimeofday tv_interval);
binmode STDOUT, ':utf8';
+if (!defined($CGI::VERSION) || $CGI::VERSION < 4.08) {
+ eval 'sub CGI::multi_param { CGI::param(@_) }'
+}
+
our $t0 = [ gettimeofday() ];
our $number_of_git_cmds = 0;
@@ -871,7 +875,7 @@ sub evaluate_query_params {
while (my ($name, $symbol) = each %cgi_param_mapping) {
if ($symbol eq 'opt') {
- $input_params{$name} = [ map { decode_utf8($_) } $cgi->param($symbol) ];
+ $input_params{$name} = [ map { decode_utf8($_) } $cgi->multi_param($symbol) ];
} else {
$input_params{$name} = decode_utf8($cgi->param($symbol));
}
--
2.1.2.596.g7379948
^ permalink raw reply related [flat|nested] 3+ messages in thread
* Re: [PATCH] gitweb: hack around CGI's list-context param() handling
2014-11-18 17:10 [PATCH] gitweb: hack around CGI's list-context param() handling Jeff King
@ 2014-11-18 17:58 ` Junio C Hamano
2014-11-18 18:01 ` Jeff King
0 siblings, 1 reply; 3+ messages in thread
From: Junio C Hamano @ 2014-11-18 17:58 UTC (permalink / raw)
To: Jeff King; +Cc: git, Michael Haggerty, Jonathan Nieder
Jeff King <peff@peff.net> writes:
> As of CGI.pm's 4.08 release, the behavior to call
> CGI::param() in a list context is deprecated (because it can
> be potentially unsafe if called inside a hash constructor).
> This cause gitweb to issue a warning for some of our code,
> which in turn causes the tests to fail.
>
> Our use is in fact _not_ one of the dangerous cases, as we
> are intentionally using a list context. The recommended
> route by 4.08 is to use the new CGI::multi_param() call to
> make it explicit that we know what we are doing.
> However, that function is only available in 4.08, which is
> about a month old; we cannot rely on having it.
>
> One option would be to set $CGI::LIST_CONTEXT_WARN globally,
> which turns off the warning. However, that would eliminate
> the protection these newer releases are trying to provide.
> We want to annotate each site as OK using the new function.
>
> So instead, let's check whether CGI provides the
> multi_param() function, and if not, provide an
> implementation that just wraps param(). That will work on
> both old and new versions of CGI. Sadly, we cannot just
> check defined(\&CGI::multi_param), because CGI uses the
> autoload feature, which claims that all functions are
> defined. Instead, we just do a version check.
The solution does look like the best in the messy situation. Thanks
for looking into it.
> +if (!defined($CGI::VERSION) || $CGI::VERSION < 4.08) {
> + eval 'sub CGI::multi_param { CGI::param(@_) }'
> +}
> +
> our $t0 = [ gettimeofday() ];
> our $number_of_git_cmds = 0;
>
> @@ -871,7 +875,7 @@ sub evaluate_query_params {
>
> while (my ($name, $symbol) = each %cgi_param_mapping) {
> if ($symbol eq 'opt') {
> - $input_params{$name} = [ map { decode_utf8($_) } $cgi->param($symbol) ];
> + $input_params{$name} = [ map { decode_utf8($_) } $cgi->multi_param($symbol) ];
> } else {
> $input_params{$name} = decode_utf8($cgi->param($symbol));
> }
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH] gitweb: hack around CGI's list-context param() handling
2014-11-18 17:58 ` Junio C Hamano
@ 2014-11-18 18:01 ` Jeff King
0 siblings, 0 replies; 3+ messages in thread
From: Jeff King @ 2014-11-18 18:01 UTC (permalink / raw)
To: Junio C Hamano; +Cc: git, Michael Haggerty, Jonathan Nieder
On Tue, Nov 18, 2014 at 09:58:26AM -0800, Junio C Hamano wrote:
> Jeff King <peff@peff.net> writes:
>
> > As of CGI.pm's 4.08 release, the behavior to call
> > CGI::param() in a list context is deprecated (because it can
> > be potentially unsafe if called inside a hash constructor).
> > This cause gitweb to issue a warning for some of our code,
Oops, s/cause/causes/ of course.
-Peff
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2014-11-18 18:01 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-11-18 17:10 [PATCH] gitweb: hack around CGI's list-context param() handling Jeff King
2014-11-18 17:58 ` Junio C Hamano
2014-11-18 18:01 ` Jeff King
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).