diff options
| author | Frank Lichtenheld <frank@lichtenheld.de> | 2007-06-15 03:01:53 +0200 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2007-06-15 22:38:48 -0700 | 
| commit | 226bccb9ad42441269507a2101b47424d7c9c477 (patch) | |
| tree | 1e852b988345967220866a605ab29717dd104631 /git-cvsserver.perl | |
| parent | fd1cd91e9407bccba3380dad6dcb60c4154d94a2 (diff) | |
| download | git-226bccb9ad42441269507a2101b47424d7c9c477.tar.gz | |
cvsserver: Actually implement --export-all
Embarrassing bug number two in my options patch.
Also enforce that --export-all is only ever used together with an
explicit whitelist. Otherwise people might export every git repository
on the whole system without realising.
Signed-off-by: Frank Lichtenheld <frank@lichtenheld.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'git-cvsserver.perl')
| -rwxr-xr-x | git-cvsserver.perl | 8 | 
1 files changed, 7 insertions, 1 deletions
| diff --git a/git-cvsserver.perl b/git-cvsserver.perl index f78afe812e..5cbf27eebc 100755 --- a/git-cvsserver.perl +++ b/git-cvsserver.perl @@ -130,6 +130,11 @@ if (@ARGV) {  # everything else is a directory  $state->{allowed_roots} = [ @ARGV ]; +# don't export the whole system unless the users requests it +if ($state->{'export-all'} && !@{$state->{allowed_roots}}) { +    die "--export-all can only be used together with an explicit whitelist\n"; +} +  # if we are called with a pserver argument,  # deal with the authentication cat before entering the  # main loop @@ -276,7 +281,8 @@ sub req_Root      my $enabled = ($cfg->{gitcvs}{$state->{method}}{enabled}  		   || $cfg->{gitcvs}{enabled}); -    unless ($enabled && $enabled =~ /^\s*(1|true|yes)\s*$/i) { +    unless ($state->{'export-all'} || +	    ($enabled && $enabled =~ /^\s*(1|true|yes)\s*$/i)) {          print "E GITCVS emulation needs to be enabled on this repo\n";          print "E the repo config file needs a [gitcvs] section added, and the parameter 'enabled' set to 1\n";          print "E \n"; | 
