]> git.ipfire.org Git - thirdparty/openssh-portable.git/commitdiff
upstream: let the "Confirm user presence for key ..." ssh-askpass
authordjm@openbsd.org <djm@openbsd.org>
Tue, 11 Aug 2020 09:45:54 +0000 (09:45 +0000)
committerDamien Miller <djm@mindrot.org>
Thu, 27 Aug 2020 01:26:26 +0000 (11:26 +1000)
notification respect $SSH_ASKPASS_REQUIRE; ok markus@

OpenBSD-Commit-ID: 7c1a616b348779bda3b9ad46bf592741f8e206c1

readpass.c

index 69edce306609a76b2de65cd8faee6fce95ab83d3..122d2a87c46555ce9c21537ce2f6c28d04358b3c 100644 (file)
@@ -1,4 +1,4 @@
-/* $OpenBSD: readpass.c,v 1.62 2020/07/14 23:57:01 djm Exp $ */
+/* $OpenBSD: readpass.c,v 1.63 2020/08/11 09:45:54 djm Exp $ */
 /*
  * Copyright (c) 2001 Markus Friedl.  All rights reserved.
  *
@@ -235,8 +235,8 @@ notify_start(int force_askpass, const char *fmt, ...)
        int devnull;
        pid_t pid;
        void (*osigchld)(int);
-       const char *askpass;
-       struct notifier_ctx *ret;
+       const char *askpass, *s;
+       struct notifier_ctx *ret = NULL;
 
        va_start(args, fmt);
        xvasprintf(&prompt, fmt, args);
@@ -248,15 +248,19 @@ notify_start(int force_askpass, const char *fmt, ...)
                (void)write(STDERR_FILENO, "\r", 1);
                (void)write(STDERR_FILENO, prompt, strlen(prompt));
                (void)write(STDERR_FILENO, "\r\n", 2);
-               free(prompt);
-               return NULL;
+               goto out;
        }
        if ((askpass = getenv("SSH_ASKPASS")) == NULL)
                askpass = _PATH_SSH_ASKPASS_DEFAULT;
-       if (getenv("DISPLAY") == NULL || *askpass == '\0') {
-               debug3("%s: cannot notify", __func__);
-               free(prompt);
-               return NULL;
+       if (*askpass == '\0') {
+               debug3("%s: cannot notify: no askpass", __func__);
+               goto out;
+       }
+       if (getenv("DISPLAY") == NULL &&
+           ((s = getenv(SSH_ASKPASS_REQUIRE_ENV)) == NULL ||
+           strcmp(s, "force") != 0)) {
+               debug3("%s: cannot notify: no display", __func__);
+               goto out;
        }
        osigchld = ssh_signal(SIGCHLD, SIG_DFL);
        if ((pid = fork()) == -1) {
@@ -284,6 +288,7 @@ notify_start(int force_askpass, const char *fmt, ...)
        }
        ret->pid = pid;
        ret->osigchld = osigchld;
+ out:
        free(prompt);
        return ret;
 }