У меня есть локальный репозиторий HG для работы с клиентами. Я настраивал сервер HG на более ранних версиях OS X без каких-либо проблем, но на Yosemite я застрял. Я использовал пакет mercurial от MacPorts, настроил Apache с самоподписанным SSL-сертификатом и в целом могу продолжать... hgweb работает отлично, и я могу извлекать и выполнять другие команды.
Однако я не могу настаивать:
$ hg push --debug --traceback -v
pushing to https://localhost/hg/website.com
using https://localhost/hg/website.com
sending capabilities command
using auth.default.* for authentication
localhost certificate matched fingerprint ************
using auth.default.* for authentication
http auth: user mike, password ************
using auth.default.* for authentication
localhost certificate matched fingerprint ************
query 1; heads
sending batch command
using auth.default.* for authentication
searching for changes
all remote heads known locally
sending branchmap command
using auth.default.* for authentication
sending branchmap command
using auth.default.* for authentication
preparing listkeys for "bookmarks"
sending listkeys command
using auth.default.* for authentication
1 changesets found
list of changesets:
c05e7b9045cf27f7508dcaaace632ba8a9940c4e
bundling: 1/1 changesets (100.00%)
bundling: 1/1 manifests (100.00%)
bundling: file1.txt 1/2 files (50.00%)
bundling: file2.txt 2/2 files (100.00%)
sending unbundle command
sending 12141 bytes
using auth.default.* for authentication
sending: 11/22 kb (50.00%)
sending: 11/22 kb (50.00%)
Traceback (most recent call last):
File "/opt/local/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/site-packages/mercurial/dispatch.py", line 138, in _runcatch
return _dispatch(req)
...
File "/opt/local/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/site-packages/mercurial/httppeer.py", line 172, in _call
fp = self._callstream(cmd, **args)
File "/opt/local/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/site-packages/mercurial/httppeer.py", line 122, in _callstream
raise util.Abort(_('authorization failed'))
Abort: authorization failed
abort: authorization failed
Имя пользователя и пароль верны... они работают в интерфейсе hgweb, и они даже работали в выводе выше на предыдущих шагах (строка 8). Я также проверил права доступа к репозиторию несколько раз... пользователь _www имеет полный доступ:
$ ls -al /var/repos/website.com
total 0
drwxrwxr-x 3 _www staff 102 Oct 19 23:34 .
drwxrwxr-x 11 _www staff 374 Oct 27 02:09 ..
drwxrwxr-x 10 _www staff 340 Oct 19 23:34 .hg
Версия HG: 3.1.2, Версия OSX: 10.10, Версия Apache: 2.4.9
Любая помощь или предложения будут высоко оценены. Спасибо заранее!
решение1
Я нашел ответ. Не уверен, почему это исправляет проблему, но все, что мне нужно было сделать, это создать файл hgrc в каталоге .hg репозитория, о котором идет речь (не в локальном клонированном каталоге), и добавить:
[web]
allow_push = *
На случай, если кто-то найдет этот ответ при попытке отладки другой части настройки, вот руководство по полной настройке Mercurial на Yosemite.
http://www.curvingspace.com/2014/11/05/mercurial-on-yosemite/