Подтвердить что ты не робот

SVN-перехват pre-revprop-change не работает

Я знаю, что это было задано много раз раньше, но я считаю, что моя ситуация другая.

Я пытаюсь добавить привязку pre-revprop-change к нашему репозиторию SVN, чтобы включить внесение изменений в сообщения журнала.

Прежде чем я добавил файл pre-revprop-change, я получал эту ошибку:

$ svn propset -r 557 --revprop svn:log "New message!" https://myserver/repos/myrepo
svn: DAV request failed; it possible that the repository pre-revprop-change hook either failed or is non-existent
svn: At least one property change failed; repository is unchanged
svn: Error setting property 'log': 
Repository has not been enabled to accept revision propchanges;
ask the administrator to create a pre-revprop-change hook

Нет проблем, подумал я. Я добавлю:

$ cd /var/www/svn/myrepo/hooks

$ # Create the simplest hook possible
$ echo '#!/bin/sh' > pre-revprop-change
$ echo 'exit 0' >> pre-revprop-change

$ # Check that it looks correct
$ cat pre-revprop-change
#!/bin/sh
exit 0

$ # Looks good, now make it executable
$ chmod a+x pre-revprop-change

$ # Check the permissions
$ ls -al pre-revprop-change
-rwxr-xr-x 1 apache apache 17 2012-05-24 12:05 pre-revprop-change

$ # Run it, to make sure it runs, and check the error code
$ ./pre-revprop-change 
$ echo $?
0

Итак, в соответствии со всем остальным, что я прочитал на SO, это должно быть все, что мне нужно, чтобы оно работало. Но, когда я пытаюсь изменить сообщение журнала снова, я все равно получаю сообщение об ошибке (другое на этот раз):

$ svn propset -r 557 --revprop svn:log "New message!" https://myserver/repos/myrepo
svn: DAV request failed; it possible that the repository pre-revprop-change hook either failed or is non-existent
svn: At least one property change failed; repository is unchanged
svn: Error setting property 'log': 
Revprop change blocked by pre-revprop-change hook (exit code 255) with no output.

Следует отметить несколько замечаний:

1) Репозиторий размещен на сервере SELinux (ядро Fedora 10). Возможно, есть что-то, что мне нужно сделать в отношении этих разрешений? Ниже приведены разрешения SE на крючок:

$ ls -alZ pre-revprop-change
-rwxr-xr-x  apache apache unconfined_u:object_r:httpd_sys_content_rw_t:s0 pre-revprop-change

2) Доступ к репозиторию осуществляется через WebDAV (обратите внимание на https:// в имени репозитория). Есть ли что-то, что мне нужно настроить на стороне WebDAV, чтобы разрешить изменения, предшествующие revprop?

4b9b3361

Ответ 1

После нескольких часов попыток я нашел ответ. И, поскольку он, кажется, нигде не существует в Интернете, я отправлю его здесь...

Проблема была вызвана SELinux (нет большого удивления там). Кажется, что apache (/usr/sbin/httpd) не имел необходимых разрешений для запуска hook script с вышеупомянутыми разрешениями SE. Чтобы заставить его выполнить, разрешения SELinux необходимо изменить с помощью

$ chcon -t httpd_exec_t pre-revprop-change

(Я сначала попытался изменить его на httpd_sys_script_exec_t, но этого было недостаточно, чтобы выполнить script, но с типом httpd_exec_t он работал.)

Заключительный вопрос: это безопасная вещь?

Ответ 2

Было похожее на CentOS. Вероятно, проблема была в кэшировании, когда я редактировал файл, а затем менял его, и он начал работать.

Итак, если у кого-то есть аналогичная проблема, попробуйте просто:

touch hooks/pre-revprop-change