From: Ted Zlatanov Date: Thu, 24 Feb 2011 13:05:36 +0000 (-0600) Subject: Resolved ChangeLog merge. X-Git-Url: http://cgit.sxemacs.org/?p=gnus;a=commitdiff_plain;h=dcb73950e208a620704faf2a3d2fcb7c952e4288;hp=4c0611be7b8cf4b34d42531534d14b88ba60c9ca Resolved ChangeLog merge. --- diff --git a/lisp/ChangeLog b/lisp/ChangeLog index 278295c47..851c1c5dd 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,3 +1,14 @@ +2011-02-24 Teodor Zlatanov + + * auth-source.el (auth-source-creation-prompts): New variable to manage + creation-time prompts. + (auth-source-search): Document it. + (auth-source-format-prompt): Add utility function. + (auth-source-netrc-create): Don't default the user name to + user-login-name. Use `auth-source-creation-prompts' and some default + prompts for user, host, port, and password (the default generic prompt + remains ugly). + 2011-02-24 Katsumi Yamaoka * auth-source.el (auth-source-netrc-create): Use `read-char' with no diff --git a/lisp/auth-source.el b/lisp/auth-source.el index 467aa103a..02852ad83 100644 --- a/lisp/auth-source.el +++ b/lisp/auth-source.el @@ -147,6 +147,9 @@ let-binding." (defvar auth-source-creation-defaults nil "Defaults for creating token values. Usually let-bound.") +(defvar auth-source-creation-prompts nil + "Default prompts for token values. Usually let-bound.") + (make-obsolete 'auth-source-hide-passwords nil "Emacs 24.1") (defvar auth-source-magic "auth-source-magic ") @@ -445,12 +448,18 @@ parameter, that parameter will be required in the resulting token. The value for that parameter will be obtained from the search parameters or from user input. If any queries are needed, the alist `auth-source-creation-defaults' will be checked for the -default prompt. +default value. If the user, host, or port are missing, the alist +`auth-source-creation-prompts' will be used to look up the +prompts IN THAT ORDER (so the 'user prompt will be queried first, +then 'host, then 'port, and finally 'secret). Each prompt string +can use %u, %h, and %p to show the user, host, and port. Here's an example: \(let ((auth-source-creation-defaults '((user . \"defaultUser\") - (A . \"default A\")))) + (A . \"default A\"))) + (auth-source-creation-prompts + '((password . \"Enter IMAP password for %h:%p: \")))) (auth-source-search :host '(\"nonesuch\" \"twosuch\") :type 'netrc :max 1 :P \"pppp\" :Q \"qqqq\" :create '(A B Q))) @@ -462,12 +471,11 @@ which says: Create a new entry if you found none. The netrc backend will automatically require host, user, and port. The host will be - 'nonesuch' and Q will be 'qqqq'. We prompt for A with default - 'default A', for B and port with default nil, and for the - user with default 'defaultUser'. We will not prompt for Q. The - resulting token will have keys user, host, port, A, B, and Q. - It will not have P with any value, even though P is used in the - search to find only entries that have P set to 'pppp'.\" + 'nonesuch' and Q will be 'qqqq'. We prompt for the password + with the shown prompt. We will not prompt for Q. The resulting + token will have keys user, host, port, A, B, and Q. It will not + have P with any value, even though P is used in the search to + find only entries that have P set to 'pppp'.\" When multiple values are specified in the search parameter, the user is prompted for which one. So :host (X Y Z) would ask the @@ -913,6 +921,17 @@ See `auth-source-search' for details on SPEC." (nth 0 v) v)) +;; (auth-source-format-prompt "test %u %h %p" '((?u "user") (?h "host"))) + +(defun auth-source-format-prompt (prompt alist) + "Format PROMPT using %x (for any character x) specifiers in ALIST." + (dolist (cell alist) + (let ((c (nth 0 cell)) + (v (nth 1 cell))) + (when (and c v) + (setq prompt (replace-regexp-in-string (format "%%%c" c) v prompt))))) + prompt) + ;;; (auth-source-search :host "nonesuch" :type 'netrc :max 1 :create t) ;;; (auth-source-search :host "nonesuch" :type 'netrc :max 1 :create t :create-extra-keys '((A "default A") (B))) @@ -964,31 +983,50 @@ See `auth-source-search' for details on SPEC." ;; the default supplementals are simple: for the user, ;; try (user-login-name), otherwise take given-default (default (cond - ((and (not given-default) (eq r 'user)) - (user-login-name)) - (t given-default)))) + ;; don't default the user name + ;; ((and (not given-default) (eq r 'user)) + ;; (user-login-name)) + (t given-default))) + (printable-defaults (list + (cons 'user + (or + (auth-source-netrc-element-or-first + (aget valist 'user)) + (plist-get artificial :user) + "[any user]")) + (cons 'host + (or + (auth-source-netrc-element-or-first + (aget valist 'host)) + (plist-get artificial :host) + "[any host]")) + (cons 'port + (or + (auth-source-netrc-element-or-first + (aget valist 'port)) + (plist-get artificial :port) + "[any port]")))) + (prompt (or (aget auth-source-creation-prompts r) + (case r + ('secret "%p password for user %u, host %h: ") + ('user "%p user name: ") + ('host "%p host name for user %u: ") + ('port "%p port for user %u and host %h: ")) + (format "Enter %s (%%u@%%h:%%p): " r))) + (prompt (auth-source-format-prompt + prompt + `((?u ,(aget printable-defaults 'user)) + (?h ,(aget printable-defaults 'host)) + (?p ,(aget printable-defaults 'port)))))) ;; store the data, prompting for the password if needed (setq data (cond ((and (null data) (eq r 'secret)) ;; special case prompt for passwords - (read-passwd (format "Password for %s@%s:%s: " - (or - (auth-source-netrc-element-or-first - (aget valist 'user)) - (plist-get artificial :user) - "[any user]") - (or - (auth-source-netrc-element-or-first - (aget valist 'host)) - (plist-get artificial :host) - "[any host]") - (or - (auth-source-netrc-element-or-first - (aget valist 'port)) - (plist-get artificial :port) - "[any port]")))) + (read-passwd prompt)) + ((null data) + (read-string prompt default)) (t (or data default)))) (when data