diff options
author | Junio C Hamano <junkio@cox.net> | 2006-06-09 23:09:49 -0700 |
---|---|---|
committer | Junio C Hamano <junkio@cox.net> | 2006-06-10 01:31:31 -0700 |
commit | 94df2506edd76a886a1044376f8c99349b2f226e (patch) | |
tree | 08bd44a53885e963bc6e7915c2e8c95df6db7d37 /setup.c | |
parent | 5e3a620cd5f7baaf27198192a614271c6145ec3b (diff) | |
download | git-94df2506edd76a886a1044376f8c99349b2f226e.tar.gz git-94df2506edd76a886a1044376f8c99349b2f226e.tar.xz |
shared repository: optionally allow reading to "others".
This enhances core.sharedrepository to have additionally
specify that read and exec permissions to be given to others as
well. It is useful when serving a repository via gitweb and
git-daemon that runs as a user outside the project group.
The configuration item can take the following values:
[core]
sharedrepository ; the same as "group"
sharedrepository = true ; ditto
sharedrepository = 1 ; ditto
sharedrepository = group ; allow rwx to group
sharedrepository = all ; allow rwx to group, allow rx to other
sharedrepository = umask ; not shared - use umask
It also extends "git init-db" to take "--shared=all" and friends
from the command line.
Signed-off-by: Junio C Hamano <junkio@cox.net>
Diffstat (limited to 'setup.c')
-rw-r--r-- | setup.c | 17 |
1 files changed, 16 insertions, 1 deletions
@@ -219,12 +219,27 @@ const char *setup_git_directory_gently(int *nongit_ok) return cwd + offset; } +int git_config_perm(const char *var, const char *value) +{ + if (value) { + if (!strcmp(value, "umask")) + return PERM_UMASK; + if (!strcmp(value, "group")) + return PERM_GROUP; + if (!strcmp(value, "all") || + !strcmp(value, "world") || + !strcmp(value, "everybody")) + return PERM_EVERYBODY; + } + return git_config_bool(var, value); +} + int check_repository_format_version(const char *var, const char *value) { if (strcmp(var, "core.repositoryformatversion") == 0) repository_format_version = git_config_int(var, value); else if (strcmp(var, "core.sharedrepository") == 0) - shared_repository = git_config_bool(var, value); + shared_repository = git_config_perm(var, value); return 0; } |