Problema de autorização Mercurial no Yosemite

Problema de autorização Mercurial no Yosemite

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/

informação relacionada