Назад | Перейти на главную страницу

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 не выполняется (проверено путем встраивания эха). Так что я здесь делаю не так?

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