13

我知道这已经被问过很多次了,但我相信我的情况有所不同。

我正在尝试向我们的 SVN 存储库添加一个 pre-revprop-change 挂钩,以启用对日志消息的更改。

在我添加pre-revprop-change文件之前,我收到了这个错误:

$ svn propset -r 557 --revprop svn:log "New message!" https://myserver/repos/myrepo
svn: DAV request failed; it's possible that the repository's 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's possible that the repository's 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 core 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 端设置什么以允许 pre-revprop-change 更改吗?

4

2 回答 2

11

经过几个小时的尝试,我找到了答案。而且,由于它似乎在互联网上的其他任何地方都不存在,所以我会在这里发布......

这个问题是由 SELinux 引起的(这并不奇怪)。似乎 apache ( /usr/sbin/httpd) 没有必要的权限来运行具有上述 SE 权限的钩子脚本。要让它执行,需要更改 SELinux 权限

$ chcon -t httpd_exec_t pre-revprop-change

(我首先尝试将其更改为httpd_sys_script_exec_t,但这还不足以让脚本执行。但使用它的httpd_exec_t类型。)

最后一个问题:这是一件安全的事情吗?

于 2012-05-24T13:32:36.140 回答
1

在 CentOS 上有类似的事情。问题可能出在缓存中,因为当我编辑文件然后将其改回它开始工作时。

因此,如果有人遇到类似问题,只需尝试:

touch hooks/pre-revprop-change
于 2013-07-17T14:24:53.907 回答