Tenho um repositório HG local para o trabalho do meu cliente. Eu configurei o servidor HG antes em versões anteriores do OS X sem problemas, mas no Yosemite estou preso. Usei o pacote mercurial do MacPorts, configurei o apache com um certificado SSL autoassinado e estou pronto para usar ... hgweb funciona bem e posso extrair e executar outros comandos.
No entanto, não posso empurrar:
$ 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
O nome de usuário e a senha estão corretos... eles funcionam na interface hgweb e até funcionaram na saída acima nas etapas anteriores (linha 8). Também verifiquei várias vezes as permissões do repositório... o usuário _www tem acesso total:
$ 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
Versão HG: 3.1.2, versão OSX: 10.10, versão Apache: 2.4.9
Qualquer ajuda ou sugestão seria muito apreciada - desde já obrigado!
Responder1
Eu encontrei a resposta. Não sei por que isso resolve o problema, mas tudo que tive que fazer foi criar um arquivo hgrc no diretório .hg do repositório em questão (não no diretório clonado local) e adicionar:
[web]
allow_push = *
Caso alguém encontre esta resposta ao tentar depurar uma parte diferente da configuração, aqui está um tutorial para toda a configuração do Mercurial no Yosemite.
http://www.curvingspace.com/2014/11/05/mercurial-on-yosemite/