Re: [PATCHv2 2/2] gitweb: support to globally enable/disable a snapshot format

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Mark A Rada <marada@xxxxxxxxxxxx> writes:

> ------->8-------------
> From: Mark Rada <marada@xxxxxxxxxxxx>
> Date: Sat, 1 Aug 2009 13:24:03 -0400
> Subject: [PATCH 2/2] gitweb: support to globally enable/disable a snapshot format
> 
> I added a 'disabled' variable to to the $known_snapshot_formats keys so
> that a Gitweb administrator can globally enable or disable a specific
> format for snapshots.
> 
> All formats are enabled by default because project specific overriding
> is disabled by default.
> 
> Signed-off-by: Mark Rada <marada@xxxxxxxxxxxx>

O.K.  I think this patch now covers everything needed.  Well, except
documentation.

> ---
>   gitweb/gitweb.perl |   17 ++++++++++++-----
>   1 files changed, 12 insertions(+), 5 deletions(-)
> 
> diff --git a/gitweb/gitweb.perl b/gitweb/gitweb.perl
> index 3398163..a59569f 100755
> --- a/gitweb/gitweb.perl
> +++ b/gitweb/gitweb.perl
> @@ -167,27 +167,31 @@ our %known_snapshot_formats = (

At the beginning of %known_snapshot_formats definition there is a
comment with description of structure of this hash.  You should have
updated it, for example in the following way:

@@ -168,7 +168,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',

The above is, of course, not the only possible way.

>   		'type' => 'application/x-gzip',
>   		'suffix' => '.tar.gz',
>   		'format' => 'tar',
> -		'compressor' => ['gzip']},
> +		'compressor' => ['gzip'],
> +		'disabled' => 0},
> 
>   	'tbz2' => {
>   		'display' => 'tar.bz2',
>   		'type' => 'application/x-bzip2',
>   		'suffix' => '.tar.bz2',
>   		'format' => 'tar',
> -		'compressor' => ['bzip2']},
> +		'compressor' => ['bzip2'],
> +		'disabled' => 0},
> 
>   	'txz' => {
>   		'display' => 'tar.xz',
>   		'type' => 'application/x-xz',
>   		'suffix' => '.tar.xz',
>   		'format' => 'tar',
> -		'compressor' => ['xz']},
> +		'compressor' => ['xz'],
> +		'disabled' => 0},
> 
>   	'zip' => {
>   		'display' => 'zip',
>   		'type' => 'application/x-zip',
>   		'suffix' => '.zip',
> -		'format' => 'zip'},
> +		'format' => 'zip',
> +		'disabled' => 0},
>   );

Although I though that we don't need to put "'disabled' => 0", as 
the fact that 'disabled' key does not exist means that it is enabled.

But if you chose to have all known formats not disabled, then I think
it is a correct solution.  (And then choosing between 'enabled' and
'disabled' is mainly a matter of taste.)

> 
>   # Aliases so we understand old gitweb.snapshot values in repository
> @@ -502,7 +506,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++";
> @@ -5171,6 +5176,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) {

Now I think that covers everything: preventing displaying known but
disabled snapshot formats in snapshots links in gitweb, and preventing
using known but disabled snapshot format.

-- 
Jakub Narebski

Git User's Survey 2009
http://tinyurl.com/GitSurvey2009
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]