]> git.eshelyaron.com Git - emacs.git/commitdiff
nntp.el (nntp-send-authinfo): Query `auth-source-search' with the logical server...
authorTeodor Zlatanov <tzz@lifelogs.com>
Tue, 10 Jan 2012 22:04:51 +0000 (22:04 +0000)
committerKatsumi Yamaoka <yamaoka@jpl.org>
Tue, 10 Jan 2012 22:04:51 +0000 (22:04 +0000)
auth-source.el (auth-source-user-and-password): Add convenience wrapper to search by just host and optionally user.

lisp/gnus/ChangeLog
lisp/gnus/auth-source.el
lisp/gnus/nntp.el

index 9a4d8abe3e882bda65efd08c8bb8c28b99f035df..c7358779818c38a165c50e2c9253410978f5503b 100644 (file)
@@ -1,3 +1,11 @@
+2012-01-10  Teodor Zlatanov  <tzz@lifelogs.com>
+
+       * nntp.el (nntp-send-authinfo): Query `auth-source-search' with the
+       logical server name in addition to the actual machine address.
+
+       * auth-source.el (auth-source-user-and-password): Add convenience
+       wrapper to search by just host and optionally user.
+
 2012-01-07  Lars Magne Ingebrigtsen  <larsi@gnus.org>
 
        * shr.el (shr-visit-file): Move point to the beginning of the buffer
index acbc541512f3961b0e6d25d8bdfa2b7ecc80927e..5e946372d04c45b2b256d2fe0a3e5e6ec08e827a 100644 (file)
@@ -1781,6 +1781,26 @@ MODE can be \"login\" or \"password\"."
 
     found))
 
+(defun auth-source-user-and-password (host &optional user)
+  (let* ((auth-info (car
+                     (if user
+                         (auth-source-search
+                          :host host
+                          :user "yourusername"
+                          :max 1
+                          :require '(:user :secret)
+                          :create nil)
+                       (auth-source-search
+                        :host host
+                        :max 1
+                        :require '(:user :secret)
+                        :create nil))))
+         (user (plist-get auth-info :user))
+         (password (plist-get auth-info :secret)))
+    (when (functionp password)
+      (setq password (funcall password)))
+    (list user password auth-info)))
+
 (provide 'auth-source)
 
 ;;; auth-source.el ends here
index db9d9e252bef40e4d7c9ddb94a737b8bd69b8c12..c740f6143568027d4ac0311c2659e947cf467236 100644 (file)
@@ -1249,8 +1249,8 @@ If SEND-IF-FORCE, only send authinfo to the server if the
         (alist (netrc-machine list nntp-address "nntp"))
          (auth-info
           (nth 0 (auth-source-search :max 1
-                                     ;; TODO: allow the virtual server name too
-                                     :host nntp-address
+                                     :host (list nntp-address
+                                                 (nnoo-current-server 'nntp))
                                      :port '("119" "nntp"))))
          (auth-user (plist-get auth-info :user))
          (auth-force (plist-get auth-info :force))