All,
Security enhancement in 2.45.1 have broken ability to serve git over https
and ssh from local git server running Apache. (web server runs as http:http on
Archlinux)
The fix of adding the following to gitconfig (system-wide and per-user in
~/.gitconfig) does not solve the problem:
[safe]
directory = *
(* or the actual /srv/git/reponame.git makes no difference)
On Archlinux, all repos are served from /srv/git. This has worked well for
both https and ssh allowing repos under /srv/git to be owned by the user with
public-private ssh key. (they are members of group owning /srv/git with write
privileges)
After 2.45.1,
- git will not allow https unless the repositories are OWNED by http.
- git will not allow ssh unless the repositories are OWNED by user.
A catch-22.
I've tried every possible file repository ownership of http:user and
user:http with permissions of 0775, but no luck, it is either one or the
other. I've even tried making users members of the http group, but ssh still
refuses push unless the repository is OWNED by user.
The errors run the gamut from https attmepts:
$ git pull
fatal: unable to access 'https://www.mydomain.com/git/examples.git/': The
requested URL returned error: 500
to ssh attempts:
$ git push
Enumerating objects: 7, done.
Counting objects: 100% (7/7), done.
Delta compression using up to 4 threads
Compressing objects: 100% (4/4), done.
Writing objects: 100% (5/5), 1.01 KiB | 1.01 MiB/s, done.
Total 5 (delta 2), reused 0 (delta 0), pack-reused 0
remote: error: cannot lock ref 'HEAD': Unable to create
'/srv/git/pico.git/./HEAD.lock': Permission denied
To valkyrie:/srv/git/pico.git
! [remote rejected] master -> master (failed to update ref)
error: failed to push some refs to 'valkyrie:/srv/git/pico.git'
This was discussed on the arch-general mailing list under the thread "git
server changes - how to allow https AND ssh now that /srv/git/xxx.git must be
owned by http?" at
https://lists.archlinux.org/archives/list/arch-general@xxxxxxxxxxxxxxxxxxx/thread/3GCCU6QZNGRY45WMQAQEVF572AIHN646/
There was a suggestion to try a bind mount for the repositories, but that
seems like it may introduce other issues, but if that is the correct approach
I'm happy to try it.
What is the correct local-server way to now serve repositories over https
AND ssh from Apache without running into this either-or ownership problem?
(gitweb continues to work fine)
--
David C. Rankin, J.D.,P.E.