У меня проблемы с настройкой gitweb с gitolite. Gitolite работает правильно, но gitweb продолжает давать мне 404 - проектов не найдено.
Странно то, что когда я запускаю cgi-скрипт как пользователь apache, он работает правильно.
# su apache /var/www/git/gitweb.cgi --shell=/bin/sh
....
<tr class="dark">
<td><a class="list" href="?p=testing.git;a=summary">testing.git</a></td>
<td><a class="list" title="Test repo 3" href="?p=testing.git;a=summary">Test repo 3</a></td>
...
Gitweb должен иметь доступ для чтения, и я установил $REPO_UMASK = 0022;
в gitweb.conf и добавил apache в группу gitolite # usermod -a -G gitolite apache
# ls -l gitolite/
total 8
-rw-r--r--. 1 gitolite gitolite 12 Sep 28 08:47 projects.list
drwxr-x---. 4 gitolite gitolite 4096 Sep 28 04:52 repositories
Моя конфигурация apache git:
Alias /git /var/www/git
<Directory /var/www/git>
Options +ExecCGI
AddHandler cgi-script .cgi
DirectoryIndex gitweb.cgi
</Directory>
Может ли кто-нибудь помочь мне заставить это работать? Целый день пытался, читал разные блоги и посты, но ничего не вышло
Починил это! Я работаю на RHEL, и оказалось, что это проблема с SELinux. Когда я отключил, все заработало правильно. Поскольку я не хотел отключать его навсегда, я обнаружил решение в блоге для написания модуля, который устанавливает правильные политики и устанавливает его.
Что я сделал:
# mkdir gitolite-selinux; cd gitolite-selinux
# touch local.te local.if local.fc
# vim local.te
module gitolite 1.0;
require {
type git_system_t;
type httpd_t;
type var_t;
type gitosis_var_lib_t;
type httpd_git_script_t;
class dir { search read getattr open };
class file { getattr read open ioctl };
}
#============= git_system_t ==============
allow git_system_t gitosis_var_lib_t:dir { read search open getattr };
allow git_system_t gitosis_var_lib_t:file { read getattr open };
#============= httpd_git_script_t ==============
allow httpd_git_script_t gitosis_var_lib_t:dir { read search open getattr };
allow httpd_git_script_t gitosis_var_lib_t:file { read getattr open ioctl };
#============= httpd_t ==============
allow httpd_t var_t:file getattr;
# make -f /usr/share/selinux/devel/Makefile
# semodule -i gitolite.pp