diff options
| author | Junio C Hamano <gitster@pobox.com> | 2010-01-10 08:52:37 -0800 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2010-01-10 08:52:37 -0800 | 
| commit | df248216fd0602e06d3b441e46efa6c74b94d081 (patch) | |
| tree | 64f37333759f1a90922fea7dc8e37e413d04f19a | |
| parent | 0196f4b5a325251f62192f164cd1061a3fd98be8 (diff) | |
| parent | 03bd0d601ea842b2db5bd40a1f7f036989f9b517 (diff) | |
| download | git-df248216fd0602e06d3b441e46efa6c74b94d081.tar.gz | |
Merge branch 'pm/cvs-environ'
* pm/cvs-environ:
  CVS Server: Support reading base and roots from environment
| -rw-r--r-- | Documentation/git-cvsserver.txt | 15 | ||||
| -rwxr-xr-x | git-cvsserver.perl | 22 | 
2 files changed, 36 insertions, 1 deletions
| diff --git a/Documentation/git-cvsserver.txt b/Documentation/git-cvsserver.txt index 99a7c14700..fbab29550a 100644 --- a/Documentation/git-cvsserver.txt +++ b/Documentation/git-cvsserver.txt @@ -277,6 +277,21 @@ In `dbdriver` and `dbuser` you can use the following variables:  	If no name can be determined, the  	numeric uid is used. +ENVIRONMENT +----------- + +These variables obviate the need for command-line options in some +circumstances, allowing easier restricted usage through git-shell. + +GIT_CVSSERVER_BASE_PATH takes the place of the argument to --base-path. + +GIT_CVSSERVER_ROOT specifies a single-directory whitelist. The +repository must still be configured to allow access through +git-cvsserver, as described above. + +When these environment variables are set, the corresponding +command-line arguments may not be used. +  Eclipse CVS Client Notes  ------------------------ diff --git a/git-cvsserver.perl b/git-cvsserver.perl index 15da2789e0..28041060c8 100755 --- a/git-cvsserver.perl +++ b/git-cvsserver.perl @@ -104,6 +104,7 @@ $log->info("--------------- STARTING -----------------");  my $usage =      "Usage: git cvsserver [options] [pserver|server] [<directory> ...]\n".      "    --base-path <path>  : Prepend to requested CVSROOT\n". +    "                          Can be read from GIT_CVSSERVER_BASE_PATH\n".      "    --strict-paths      : Don't allow recursing into subdirectories\n".      "    --export-all        : Don't check for gitcvs.enabled in config\n".      "    --version, -V       : Print version information and exit\n". @@ -111,7 +112,8 @@ my $usage =      "\n".      "<directory> ... is a list of allowed directories. If no directories\n".      "are given, all are allowed. This is an additional restriction, gitcvs\n". -    "access still needs to be enabled by the gitcvs.enabled config option.\n"; +    "access still needs to be enabled by the gitcvs.enabled config option.\n". +    "Alternately, one directory may be specified in GIT_CVSSERVER_ROOT.\n";  my @opts = ( 'help|h|H', 'version|V',  	     'base-path=s', 'strict-paths', 'export-all' ); @@ -148,6 +150,24 @@ if ($state->{'export-all'} && !@{$state->{allowed_roots}}) {      die "--export-all can only be used together with an explicit whitelist\n";  } +# Environment handling for running under git-shell +if (exists $ENV{GIT_CVSSERVER_BASE_PATH}) { +    if ($state->{'base-path'}) { +	die "Cannot specify base path both ways.\n"; +    } +    my $base_path = $ENV{GIT_CVSSERVER_BASE_PATH}; +    $state->{'base-path'} = $base_path; +    $log->debug("Picked up base path '$base_path' from environment.\n"); +} +if (exists $ENV{GIT_CVSSERVER_ROOT}) { +    if (@{$state->{allowed_roots}}) { +	die "Cannot specify roots both ways: @ARGV\n"; +    } +    my $allowed_root = $ENV{GIT_CVSSERVER_ROOT}; +    $state->{allowed_roots} = [ $allowed_root ]; +    $log->debug("Picked up allowed root '$allowed_root' from environment.\n"); +} +  # if we are called with a pserver argument,  # deal with the authentication cat before entering the  # main loop | 
