Commit fee83091 authored by Jonas Bernoulli's avatar Jonas Bernoulli

magit-process-password-auth-source: Bugfix

* Use `:user', not `:login'.
* Behave as documented.  This also involves fixing the
  respective entry of `magit-process-password-prompt-regexps'.

Fixes #3651.
parent bec8b45b
......@@ -158,8 +158,8 @@ itself from the hook, to avoid further futile attempts."
(defcustom magit-process-password-prompt-regexps
'("^\\(Enter \\)?[Pp]assphrase\\( for \\(RSA \\)?key '.*'\\)?: ?$"
;; match-group 99 is used to identify a host
"^\\(Enter \\)?[Pp]assword\\( for '\\(?99:.*\\)'\\)?: ?$"
;; Match-group 99 is used to identify the "user@host" part.
"^\\(Enter \\)?[Pp]assword\\( for '\\(https?://\\)?\\(?99:.*\\)'\\)?: ?$"
"^.*'s password: ?$"
"^Yubikey for .*: ?$"
"^Enter PIN for .*: ?$")
......@@ -749,19 +749,18 @@ which matches the ~/.authinfo.gpg entry
machine login tarsius password 12345
or iff that is undefined, for backward compatibility
machine password 12345"
(message "key: %S" key)
(require 'auth-source)
(let ((secret
(car (or (and (string-match "\\([^@]+\\)@\\([^@]+\\)" key)
(auth-source-search :max 1
:host (match-string 2 key)
:login (match-string 1 key)))
(auth-source-search :max 1 :host key)))
(if (functionp secret)
(funcall secret)
(and (string-match "\\`\\([^@]+\\)@\\([^@]+\\)\\'" key)
(let* ((user (match-string 1 key))
(host (match-string 2 key))
(car (or (auth-source-search :max 1 :host host :user user)
(auth-source-search :max 1 :host key)))
(if (functionp secret)
(funcall secret)
(defun magit-process-password-prompt (process string)
"Find a password based on prompt STRING and send it to git.
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment