]> git.eshelyaron.com Git - emacs.git/commitdiff
* pop3.el (pop3-open-server): Read server greeting before starting TLS negotiation.
authorYuri Karaban <tech@askold.net>
Fri, 19 Nov 2010 16:25:09 +0000 (11:25 -0500)
committerChong Yidong <cyd@stupidchicken.com>
Fri, 19 Nov 2010 16:25:09 +0000 (11:25 -0500)
lisp/gnus/ChangeLog
lisp/gnus/pop3.el

index e6024b3e95eabd73eab643487251ade46668ba88..7350cf97f507429dc21cc5648ef6067162f86edb 100644 (file)
@@ -1,3 +1,8 @@
+2010-11-19  Yuri Karaban  <tech@askold.net>  (tiny change)
+
+       * pop3.el (pop3-open-server): Read server greeting before starting TLS
+       negotiation.
+
 2010-10-12  Juanma Barranquero  <lekktu@gmail.com>
 
        * nnmail.el (nnmail-fancy-expiry-targets): Fix typo in docstring.
index b3012b4b19892a82e31f614ec4ce59f0260cb6c9..b445b8979ea6a399c66705bf31f238c74f8e8b32 100644 (file)
@@ -259,21 +259,22 @@ Returns the process associated with the connection."
              ;; gnutls-cli, openssl don't accept service names
              (if (equal port "pop3")
                  (setq port 110))
-             (let ((process (starttls-open-stream "POP" (current-buffer)
-                                                  mailhost (or port 110))))
-               (pop3-send-command process "STLS")
-               (let ((response (pop3-read-response process t)))
-                 (if (and response (string-match "+OK" response))
-                     (starttls-negotiate process)
-                   (pop3-quit process)
-                   (error "POP server doesn't support starttls")))
-               process))
-            (t 
+             ;; Delay STLS until server greeting is read (Bug#7438).
+             (starttls-open-stream "POP" (current-buffer)
+                                   mailhost (or port 110)))
+            (t
              (open-network-stream "POP" (current-buffer) mailhost port))))
       (let ((response (pop3-read-response process t)))
        (setq pop3-timestamp
              (substring response (or (string-match "<" response) 0)
                         (+ 1 (or (string-match ">" response) -1)))))
+      (when (eq pop3-stream-type 'starttls)
+       (pop3-send-command process "STLS")
+       (let ((response (pop3-read-response process t)))
+         (if (and response (string-match "+OK" response))
+             (starttls-negotiate process)
+           (pop3-quit process)
+           (error "POP server doesn't support starttls"))))
       process)))
 
 ;; Support functions