* Git GUI vs interactive post-commit hooks @ 2008-05-19 10:48 Alexander Gladysh 2008-05-19 13:19 ` Björn Steinbrink 0 siblings, 1 reply; 9+ messages in thread From: Alexander Gladysh @ 2008-05-19 10:48 UTC (permalink / raw) To: git Hi, list! $ git --version git version 1.5.5.1 I have a post-commit hook which does backups for me: username=agladysh for name in `git branch | cut -b3-` do remote=$username-$name echo pushing $name as $remote git push backup +$name:refs/heads/$remote done The backup repo is behind ssh. Recently I have put password on my ssh key and post-commit hook ask me for password once for each branch. This makes unhappy commit process from Git GUI -- after I shut it down, there are multiple ssh key password prompts in the shell from where I launched it, and it does not display any input I enter. Any advice? I do want to input password for my key each time I use it. Thanks in advance, Alexander. ^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: Git GUI vs interactive post-commit hooks 2008-05-19 10:48 Git GUI vs interactive post-commit hooks Alexander Gladysh @ 2008-05-19 13:19 ` Björn Steinbrink 2008-05-19 13:42 ` Alexander Gladysh 2008-05-20 22:31 ` Alex Riesen 0 siblings, 2 replies; 9+ messages in thread From: Björn Steinbrink @ 2008-05-19 13:19 UTC (permalink / raw) To: Alexander Gladysh; +Cc: Shawn O. Pearce, git On 2008.05.19 14:48:14 +0400, Alexander Gladysh wrote: > Hi, list! > > $ git --version > git version 1.5.5.1 > > I have a post-commit hook which does backups for me: > > username=agladysh > for name in `git branch | cut -b3-` > do > remote=$username-$name > echo pushing $name as $remote > git push backup +$name:refs/heads/$remote > done Isn't that what "git push --all" does? And that will only ask for a password once, not for every branch. > The backup repo is behind ssh. Recently I have put password on my ssh > key and post-commit hook ask me for password once for each branch. > This makes unhappy commit process from Git GUI -- after I shut it > down, there are multiple ssh key password prompts in the shell from > where I launched it, and it does not display any input I enter. > > Any advice? I do want to input password for my key each time I use it. For a graphical tool, you might want to use something like gtk-led-askpass, which shows a window with a password prompt. SSH will make use of it if SSH_ASKPASS contains its path _and_ ssh is not started from a terminal. Unfortunately, the latter is probably not true for git gui most of the time. One way hack around this is to do "setsid git push ..." in your post-commit hook. But that will break if you have no X or no tool for SSH_ASKPASS. Another really hackish work-around is to replace: exec 'wish' "$argv0" -- "$@" with exec 'setsid' 'wish' "$argv0" -- "$@" in git-gui. Git gui will then get its own session, detached from the terminal and ssh will start using SSH_ASKPASS. That at least won't break when you're not running X (simply because you won't be running git gui then ;-)), but doesn't feel smart either. Maybe someone else can come up with a sane solution that makes git gui more SSH_ASKPASS-friendly. Björn ^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: Git GUI vs interactive post-commit hooks 2008-05-19 13:19 ` Björn Steinbrink @ 2008-05-19 13:42 ` Alexander Gladysh 2008-05-19 14:11 ` Björn Steinbrink 2008-05-20 22:31 ` Alex Riesen 1 sibling, 1 reply; 9+ messages in thread From: Alexander Gladysh @ 2008-05-19 13:42 UTC (permalink / raw) To: Björn Steinbrink; +Cc: Shawn O. Pearce, git On Mon, May 19, 2008 at 5:19 PM, Björn Steinbrink <B.Steinbrink@gmx.de> wrote: > On 2008.05.19 14:48:14 +0400, Alexander Gladysh wrote: >> Hi, list! >> >> $ git --version >> git version 1.5.5.1 >> >> I have a post-commit hook which does backups for me: >> >> username=agladysh >> for name in `git branch | cut -b3-` >> do >> remote=$username-$name >> echo pushing $name as $remote >> git push backup +$name:refs/heads/$remote >> done > > Isn't that what "git push --all" does? And that will only ask for a > password once, not for every branch. git push --all would not rename my branches... But, I guess, this can be done as preparation step somehow. >> The backup repo is behind ssh. Recently I have put password on my ssh >> key and post-commit hook ask me for password once for each branch. >> This makes unhappy commit process from Git GUI -- after I shut it >> down, there are multiple ssh key password prompts in the shell from >> where I launched it, and it does not display any input I enter. >> >> Any advice? I do want to input password for my key each time I use it. > > For a graphical tool, you might want to use something like > gtk-led-askpass, which shows a window with a password prompt. SSH will > make use of it if SSH_ASKPASS contains its path _and_ ssh is not started > from a terminal. Unfortunately, the latter is probably not true for git > gui most of the time. <Useful advice regarding how to solve SSH_ASKPASS issue skipped.> Thanks, I would try that. I'm mostly working from X, so lack of X should be not an issue... However I'd like to avoid patching my local copy of git as much as possible. :-) > Maybe someone else can come up with a sane solution that makes git gui > more SSH_ASKPASS-friendly. That would be great. Thank you, Alexander. ^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: Git GUI vs interactive post-commit hooks 2008-05-19 13:42 ` Alexander Gladysh @ 2008-05-19 14:11 ` Björn Steinbrink 0 siblings, 0 replies; 9+ messages in thread From: Björn Steinbrink @ 2008-05-19 14:11 UTC (permalink / raw) To: Alexander Gladysh; +Cc: Shawn O. Pearce, git On 2008.05.19 17:42:05 +0400, Alexander Gladysh wrote: > On Mon, May 19, 2008 at 5:19 PM, Björn Steinbrink <B.Steinbrink@gmx.de> wrote: > > On 2008.05.19 14:48:14 +0400, Alexander Gladysh wrote: > >> Hi, list! > >> > >> $ git --version > >> git version 1.5.5.1 > >> > >> I have a post-commit hook which does backups for me: > >> > >> username=agladysh > >> for name in `git branch | cut -b3-` > >> do > >> remote=$username-$name > >> echo pushing $name as $remote > >> git push backup +$name:refs/heads/$remote > >> done > > > > Isn't that what "git push --all" does? And that will only ask for a > > password once, not for every branch. > > git push --all would not rename my branches... But, I guess, this can > be done as preparation step somehow. Oh, oops, didn't notice the $remote stuff, sorry. > >> The backup repo is behind ssh. Recently I have put password on my ssh > >> key and post-commit hook ask me for password once for each branch. > >> This makes unhappy commit process from Git GUI -- after I shut it > >> down, there are multiple ssh key password prompts in the shell from > >> where I launched it, and it does not display any input I enter. > >> > >> Any advice? I do want to input password for my key each time I use it. > > > > For a graphical tool, you might want to use something like > > gtk-led-askpass, which shows a window with a password prompt. SSH will > > make use of it if SSH_ASKPASS contains its path _and_ ssh is not started > > from a terminal. Unfortunately, the latter is probably not true for git > > gui most of the time. > > <Useful advice regarding how to solve SSH_ASKPASS issue skipped.> > > Thanks, I would try that. I'm mostly working from X, so lack of X > should be not an issue... However I'd like to avoid patching my local > copy of git as much as possible. :-) Well, the "lack of X" issue only arises if you patch your post-commit hook. Adding setsid to the git push command was supposed to happen there ;-) You could probably even make that conditional, so that setsid is only used then DISPLAY is set, then it should even work when there's no X, but still be annoying when you commit from a terminal... (At least I would prefer to enter the password in the terminal then). Björn ^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: Git GUI vs interactive post-commit hooks 2008-05-19 13:19 ` Björn Steinbrink 2008-05-19 13:42 ` Alexander Gladysh @ 2008-05-20 22:31 ` Alex Riesen 2008-05-20 23:02 ` Björn Steinbrink 1 sibling, 1 reply; 9+ messages in thread From: Alex Riesen @ 2008-05-20 22:31 UTC (permalink / raw) To: Bj?rn Steinbrink; +Cc: Alexander Gladysh, Shawn O. Pearce, git Bj?rn Steinbrink, Mon, May 19, 2008 15:19:42 +0200: > On 2008.05.19 14:48:14 +0400, Alexander Gladysh wrote: > > > > Any advice? I do want to input password for my key each time I use it. > > For a graphical tool, you might want to use something like > gtk-led-askpass, which shows a window with a password prompt. SSH will > make use of it if SSH_ASKPASS contains its path _and_ ssh is not started > from a terminal. Unfortunately, the latter is probably not true for git > gui most of the time. Redirect stdin from /dev/null ^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: Git GUI vs interactive post-commit hooks 2008-05-20 22:31 ` Alex Riesen @ 2008-05-20 23:02 ` Björn Steinbrink 2008-05-20 23:16 ` Jeff King 2008-05-22 12:53 ` Alex Riesen 0 siblings, 2 replies; 9+ messages in thread From: Björn Steinbrink @ 2008-05-20 23:02 UTC (permalink / raw) To: Alex Riesen; +Cc: Alexander Gladysh, Shawn O. Pearce, git On 2008.05.21 00:31:58 +0200, Alex Riesen wrote: > Bj?rn Steinbrink, Mon, May 19, 2008 15:19:42 +0200: > > On 2008.05.19 14:48:14 +0400, Alexander Gladysh wrote: > > > > > > Any advice? I do want to input password for my key each time I use it. > > > > For a graphical tool, you might want to use something like > > gtk-led-askpass, which shows a window with a password prompt. SSH will > > make use of it if SSH_ASKPASS contains its path _and_ ssh is not started > > from a terminal. Unfortunately, the latter is probably not true for git > > gui most of the time. > > Redirect stdin from /dev/null Does that actually work for you? It didn't work for me, because ssh then simply goes and opens /dev/tty to ask for the password. $ ssh -V OpenSSH_4.7p1 Debian-10, OpenSSL 0.9.8g 19 Oct 2007 Björn ^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: Git GUI vs interactive post-commit hooks 2008-05-20 23:02 ` Björn Steinbrink @ 2008-05-20 23:16 ` Jeff King 2008-05-22 12:53 ` Alex Riesen 1 sibling, 0 replies; 9+ messages in thread From: Jeff King @ 2008-05-20 23:16 UTC (permalink / raw) To: Björn Steinbrink Cc: Alex Riesen, Alexander Gladysh, Shawn O. Pearce, git On Wed, May 21, 2008 at 01:02:04AM +0200, Björn Steinbrink wrote: > > Redirect stdin from /dev/null > > Does that actually work for you? It didn't work for me, because ssh then > simply goes and opens /dev/tty to ask for the password. > > $ ssh -V > OpenSSH_4.7p1 Debian-10, OpenSSL 0.9.8g 19 Oct 2007 I had to perform this same task a few weeks ago, and ended up using 'setsid' to get rid of the controlling tty. You may also need to unset SSH_ASKPASS and DISPLAY. -Peff ^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: Git GUI vs interactive post-commit hooks 2008-05-20 23:02 ` Björn Steinbrink 2008-05-20 23:16 ` Jeff King @ 2008-05-22 12:53 ` Alex Riesen 2008-05-22 15:12 ` Björn Steinbrink 1 sibling, 1 reply; 9+ messages in thread From: Alex Riesen @ 2008-05-22 12:53 UTC (permalink / raw) To: Björn Steinbrink; +Cc: Alexander Gladysh, Shawn O. Pearce, git Björn Steinbrink, Wed, May 21, 2008 01:02:04 +0200: > On 2008.05.21 00:31:58 +0200, Alex Riesen wrote: > > Bj?rn Steinbrink, Mon, May 19, 2008 15:19:42 +0200: > > > On 2008.05.19 14:48:14 +0400, Alexander Gladysh wrote: > > > > > > > > Any advice? I do want to input password for my key each time I use it. > > > > > > For a graphical tool, you might want to use something like > > > gtk-led-askpass, which shows a window with a password prompt. SSH will > > > make use of it if SSH_ASKPASS contains its path _and_ ssh is not started > > > from a terminal. Unfortunately, the latter is probably not true for git > > > gui most of the time. > > > > Redirect stdin from /dev/null > > Does that actually work for you? It didn't work for me, because ssh then > simply goes and opens /dev/tty to ask for the password. > > $ ssh -V > OpenSSH_4.7p1 Debian-10, OpenSSL 0.9.8g 19 Oct 2007 > No :( I took this information from sshs manpage: SSH_ASKPASS If ssh needs a passphrase, it will read the passphrase from the current terminal if it was run from a terminal. If ssh does not have a terminal associated with it but DISPLAY and SSH_ASKPASS are set, it will execute the program specified by SSH_ASKPASS and open an X11 window to read the passphrase. This is particularly useful when call‐ ing ssh from a .xsession or related script. (Note that on some machines it may be necessary to redi‐ rect the input from /dev/null to make this work.) ^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: Git GUI vs interactive post-commit hooks 2008-05-22 12:53 ` Alex Riesen @ 2008-05-22 15:12 ` Björn Steinbrink 0 siblings, 0 replies; 9+ messages in thread From: Björn Steinbrink @ 2008-05-22 15:12 UTC (permalink / raw) To: Alex Riesen; +Cc: Alexander Gladysh, Shawn O. Pearce, git On 2008.05.22 14:53:01 +0200, Alex Riesen wrote: > Björn Steinbrink, Wed, May 21, 2008 01:02:04 +0200: > > On 2008.05.21 00:31:58 +0200, Alex Riesen wrote: > > > Bj?rn Steinbrink, Mon, May 19, 2008 15:19:42 +0200: > > > > On 2008.05.19 14:48:14 +0400, Alexander Gladysh wrote: > > > > > > > > > > Any advice? I do want to input password for my key each time I use it. > > > > > > > > For a graphical tool, you might want to use something like > > > > gtk-led-askpass, which shows a window with a password prompt. SSH will > > > > make use of it if SSH_ASKPASS contains its path _and_ ssh is not started > > > > from a terminal. Unfortunately, the latter is probably not true for git > > > > gui most of the time. > > > > > > Redirect stdin from /dev/null > > > > Does that actually work for you? It didn't work for me, because ssh then > > simply goes and opens /dev/tty to ask for the password. > > > > $ ssh -V > > OpenSSH_4.7p1 Debian-10, OpenSSL 0.9.8g 19 Oct 2007 > > > > No :( I took this information from sshs manpage: > > SSH_ASKPASS If ssh needs a passphrase, it will read the > passphrase from the current terminal if it was run > from a terminal. If ssh does not have a terminal > associated with it but DISPLAY and SSH_ASKPASS are > set, it will execute the program specified by > SSH_ASKPASS and open an X11 window to read the > passphrase. This is particularly useful when call‐ > ing ssh from a .xsession or related script. (Note > that on some machines it may be necessary to redi‐ > rect the input from /dev/null to make this work.) Yeah, that got me trying the redirection, too. But the "If ssh does not have a terminal associated" part is actually what counts, it seems. Because ssh falls back to /dev/tty if stdin doesn't work. Guess the stdin redirect might just be required in some cases, where it would use /dev/stdin directly, so you force it to try /dev/tty and then use SSH_ASKPASS. Björn ^ permalink raw reply [flat|nested] 9+ messages in thread
end of thread, other threads:[~2008-05-22 15:13 UTC | newest] Thread overview: 9+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2008-05-19 10:48 Git GUI vs interactive post-commit hooks Alexander Gladysh 2008-05-19 13:19 ` Björn Steinbrink 2008-05-19 13:42 ` Alexander Gladysh 2008-05-19 14:11 ` Björn Steinbrink 2008-05-20 22:31 ` Alex Riesen 2008-05-20 23:02 ` Björn Steinbrink 2008-05-20 23:16 ` Jeff King 2008-05-22 12:53 ` Alex Riesen 2008-05-22 15:12 ` Björn Steinbrink
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).