git.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* Calling ssh from git-gui
@ 2008-09-03 16:54 Petr Baudis
  2008-09-03 17:15 ` Shawn O. Pearce
  0 siblings, 1 reply; 5+ messages in thread
From: Petr Baudis @ 2008-09-03 16:54 UTC (permalink / raw)
  To: git, msysgit

  Hi,

  I'm quite at loss by now searching for a reasonable solution for
invoking ssh (either directly or through git fetch/git push) from
git-gui, which is very problematic right now - doubly so when
considering both UNIX and Win32.

  There are several scenarios to consider:

  (i) SSH to known host with key managed by a running agent.
  (ii) SSH to host without agent running or without keys set up.
  (iii) SSH to unknown host (unregistered fingerprint).

  Currently, (i) is the only scenario git-gui can handle, which means
that users usually have to use Other Means (tm) to "seed" their ssh tool
(OpenSSH or PuTTY) - it forces them to install keys and manually connect
to the machine once. Furthermore, this is pretty much undocumented (and
even if it was, GUI users assume they don't have to read documentation)
and there is no way to give the user feedback why on the earth is the
thing hanging.

  Handling (ii) and (iii) unfortunately turned out to be very tricky.

  On Linux, things are at least manageable - running ssh in a separate
session and setting $SSH_ASKPASS to point at a GUI helper should do.
(Even though the separate session part might get rather tricky to
implement in TCL.) On Windows, there is PuTTY and OpenSSH to consider:

  With PuTTY, I know about no good solutions for both (ii) and (iii)
short of including PuTTY code with custom frontend in msysGit itself -
this might be interesting approach, though. PuTTY is licenced under
something that looks like an MIT licence and can run on UNIX too.

  With OpenSSH, I was not able to get $SSH_ASKPASS to work, even after
going through the ordeal of setting up msysdvlpr and compiling my own
setsid.exe - setsid.exe cat /dev/tty shows it does not exist, yet
OpenSSH still declines to call $SSH_ASKPASS. By now, I'm at loss and
running out of time to investigate this further.


  To sum it up, there are two possible solutions to driving ssh through
git-gui:

  * Call setsid'd ssh with $SSH_ASKPASS; this might get very tricky to
implement in TCL. Either git-gui.sh could execute wish setsid'd already
(which is probably not portable and changes current semantics as git-gui
detaches from the current terminal, but that could be ok), or Git itself
could get support of setsid()ing before calling ssh (probably better
option). To get this working on Win32 would require further work and
possibly ssh or msys code hacking. (Heck, we could customize the ssh we
ship with msysGit to remove the braindead no-controlling-terminal
requirement.)

  * Use PuTTY code with custom frontend for the ssh transport. This is
probably not realistic since I can't think of any benefits this would
get non-Win32 users now - though for Win32 users the benefits might be
significant; making embedding-friendly PuTTY frontend (not even
necessarily git-specific) could be nic next year's GSoC project
candidate?


  Comments, thoughts?

-- 
				Petr "Pasky" Baudis
The next generation of interesting software will be done
on the Macintosh, not the IBM PC.  -- Bill Gates

^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2008-09-03 17:34 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-09-03 16:54 Calling ssh from git-gui Petr Baudis
2008-09-03 17:15 ` Shawn O. Pearce
2008-09-03 17:22   ` Thomas Rast
2008-09-03 17:25     ` Shawn O. Pearce
2008-09-03 17:33   ` Petr Baudis

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).