Gitweb проверяет права доступа с помощью gitolite

Я несколько git-репозиториев, доступных для разных пользователей. Я хочу позволить пользователям просматривать все репозитории, к которым у него есть доступ по крайней мере ЧИТАТЬ.

Для этого у меня есть следующий конфиг gitweb:

$projectroot = '/var/lib/gitolite/repositories/';
$site_name = "my Git Repos";
$fallback_encoding = 'utf-8';
$projects_list = '/var/lib/gitolite/projects.list';
$strict_export = 1;

$export_auth_hook = sub {
    my $repo = shift;
    my $user = $ENV{GL_USER};
    # gitweb passes us the full repo path; so we strip the beginning                                                                                                                                               
    # and the end, to get the repo name as it is specified in gitolite conf                                                                                                                                        
    return unless $repo =~ s/^\Q$projectroot\E\/?(.+)\.git$/$1/;

    # check for (at least) "R" permission                                                                                                                                                                          
    my $ret = `/usr/local/bin/test_git_access_right $repo $user`;
    my $res = $ret !~ /DENIED/;
    return ($ret !~ /DENIED/);
};

и скрипт test_git_access_right:

#!/bin/sh
su - git -c "gitolite access $*"

Моя проблема в том, что сценарий test_git_acces_right не выполняется (проверяется путем встраивания эха). Так что я тут делаю не так?

Заранее благодарю за любую помощь!

0 ответов

Другие вопросы по тегам