From: Mark A Rada Date: Thu, 6 Aug 2009 14:25:39 +0000 (-0400) Subject: gitweb: support to globally disable a snapshot format X-Git-Url: https://git.ladys.computer/Gitweb/commitdiff_plain/122a58bcf077a2ae28764f6f2bbc019111b644cf5c864a24e4402a88758d398c?ds=sidebyside gitweb: support to globally disable a snapshot format Allow Gitweb administrators to set a 'disabled' key in the %known_snapshot_formats hash to disable a specific snapshot format. All formats are enabled by default to maintain backwards compatibility. Signed-off-by: Mark Rada Signed-off-by: Junio C Hamano --- diff --git a/gitweb.perl b/gitweb.perl index 3eb82ef..28833a8 100755 --- a/gitweb.perl +++ b/gitweb.perl @@ -161,7 +161,8 @@ our %known_snapshot_formats = ( # 'suffix' => filename suffix, # 'format' => --format for git-archive, # 'compressor' => [compressor command and arguments] - # (array reference, optional)} + # (array reference, optional) + # 'disabled' => boolean (optional)} # 'tgz' => { 'display' => 'tar.gz', @@ -495,7 +496,8 @@ sub filter_snapshot_fmts { exists $known_snapshot_format_aliases{$_} ? $known_snapshot_format_aliases{$_} : $_} @fmts; @fmts = grep { - exists $known_snapshot_formats{$_} } @fmts; + exists $known_snapshot_formats{$_} && + !$known_snapshot_formats{$_}{'disabled'}} @fmts; } our $GITWEB_CONFIG = $ENV{'GITWEB_CONFIG'} || "++GITWEB_CONFIG++"; @@ -5182,6 +5184,8 @@ sub git_snapshot { die_error(400, "Unknown snapshot format"); } elsif (!grep($_ eq $format, @snapshot_fmts)) { die_error(403, "Unsupported snapshot format"); + } elsif ($known_snapshot_formats{$format}{'disabled'}) { + die_error(403, "Snapshot format not allowed"); } if (!defined $hash) {