mirror of
https://github.com/sourcegit-scm/sourcegit.git
synced 2025-01-11 23:57:21 -08:00
refactor: a new way to test if this app should be launched as a SSH askpass client
This commit is contained in:
parent
b6ce2bcc85
commit
6151f4dc5f
2 changed files with 12 additions and 18 deletions
|
@ -516,22 +516,20 @@ namespace SourceGit
|
||||||
|
|
||||||
private bool TryLaunchedAsAskpass(IClassicDesktopStyleApplicationLifetime desktop)
|
private bool TryLaunchedAsAskpass(IClassicDesktopStyleApplicationLifetime desktop)
|
||||||
{
|
{
|
||||||
|
var launchAsAskpass = Environment.GetEnvironmentVariable("SOURCEGIT_LAUNCH_AS_ASKPASS");
|
||||||
|
if (launchAsAskpass is not "TRUE")
|
||||||
|
return false;
|
||||||
|
|
||||||
var args = desktop.Args;
|
var args = desktop.Args;
|
||||||
if (args == null || args.Length != 1)
|
if (args.Length > 0)
|
||||||
return false;
|
{
|
||||||
|
desktop.MainWindow = new Views.Askpass(args[0]);
|
||||||
var param = args[0];
|
|
||||||
if (Directory.Exists(param))
|
|
||||||
return false;
|
|
||||||
|
|
||||||
if (!param.StartsWith("enter passphrase", StringComparison.OrdinalIgnoreCase) &&
|
|
||||||
!param.Contains(" password", StringComparison.OrdinalIgnoreCase))
|
|
||||||
return false;
|
|
||||||
|
|
||||||
desktop.MainWindow = new Views.Askpass(param);
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
private void TryLaunchedAsNormal(IClassicDesktopStyleApplicationLifetime desktop)
|
private void TryLaunchedAsNormal(IClassicDesktopStyleApplicationLifetime desktop)
|
||||||
{
|
{
|
||||||
Native.OS.SetupEnternalTools();
|
Native.OS.SetupEnternalTools();
|
||||||
|
|
|
@ -42,7 +42,7 @@ namespace SourceGit.Commands
|
||||||
{
|
{
|
||||||
var start = new ProcessStartInfo();
|
var start = new ProcessStartInfo();
|
||||||
start.FileName = Native.OS.GitExecutable;
|
start.FileName = Native.OS.GitExecutable;
|
||||||
start.Arguments = "--no-pager -c core.quotepath=off ";
|
start.Arguments = "--no-pager -c core.quotepath=off -c credential.helper=manager ";
|
||||||
start.UseShellExecute = false;
|
start.UseShellExecute = false;
|
||||||
start.CreateNoWindow = true;
|
start.CreateNoWindow = true;
|
||||||
start.RedirectStandardOutput = true;
|
start.RedirectStandardOutput = true;
|
||||||
|
@ -56,17 +56,13 @@ namespace SourceGit.Commands
|
||||||
start.Environment.Add("DISPLAY", "required");
|
start.Environment.Add("DISPLAY", "required");
|
||||||
start.Environment.Add("SSH_ASKPASS", selfExecFile); // Can not use parameter here, because it invoked by SSH with `exec`
|
start.Environment.Add("SSH_ASKPASS", selfExecFile); // Can not use parameter here, because it invoked by SSH with `exec`
|
||||||
start.Environment.Add("SSH_ASKPASS_REQUIRE", "prefer");
|
start.Environment.Add("SSH_ASKPASS_REQUIRE", "prefer");
|
||||||
|
start.Environment.Add("SOURCEGIT_LAUNCH_AS_ASKPASS", "TRUE");
|
||||||
|
|
||||||
// If an SSH private key was provided, sets the environment.
|
// If an SSH private key was provided, sets the environment.
|
||||||
if (!string.IsNullOrEmpty(SSHKey))
|
if (!string.IsNullOrEmpty(SSHKey))
|
||||||
{
|
|
||||||
start.Environment.Add("GIT_SSH_COMMAND", $"ssh -o StrictHostKeyChecking=accept-new -i '{SSHKey}'");
|
start.Environment.Add("GIT_SSH_COMMAND", $"ssh -o StrictHostKeyChecking=accept-new -i '{SSHKey}'");
|
||||||
}
|
|
||||||
else
|
else
|
||||||
{
|
|
||||||
start.Environment.Add("GIT_SSH_COMMAND", $"ssh -o StrictHostKeyChecking=accept-new");
|
start.Environment.Add("GIT_SSH_COMMAND", $"ssh -o StrictHostKeyChecking=accept-new");
|
||||||
start.Arguments += "-c credential.helper=manager ";
|
|
||||||
}
|
|
||||||
|
|
||||||
// Force using en_US.UTF-8 locale to avoid GCM crash
|
// Force using en_US.UTF-8 locale to avoid GCM crash
|
||||||
if (OperatingSystem.IsLinux())
|
if (OperatingSystem.IsLinux())
|
||||||
|
|
Loading…
Reference in a new issue