From 0891b1d2ec6b576000c0fe9150257d4f03c53536 Mon Sep 17 00:00:00 2001 From: alecpl <alec@alec.pl> Date: Mon, 27 Jun 2011 12:27:11 -0400 Subject: [PATCH] - Fix handling of untagged responses in LIST/LSUB response parser --- program/include/rcube_imap_generic.php | 10 +++++++++- 1 files changed, 9 insertions(+), 1 deletions(-) diff --git a/program/include/rcube_imap_generic.php b/program/include/rcube_imap_generic.php index 59e314c..02211aa 100644 --- a/program/include/rcube_imap_generic.php +++ b/program/include/rcube_imap_generic.php @@ -2180,7 +2180,7 @@ while ($this->tokenizeResponse($response, 1) == '*') { $cmd = strtoupper($this->tokenizeResponse($response, 1)); // * LIST (<options>) <delimiter> <mailbox> - if (!$lstatus || $cmd == 'LIST' || $cmd == 'LSUB') { + if ($cmd == 'LIST' || $cmd == 'LSUB') { list($opts, $delim, $mailbox) = $this->tokenizeResponse($response, 3); // Add to result array @@ -2209,6 +2209,14 @@ $folders[$mailbox][$name] = $value; } } + // other untagged response line, skip it + else { + $response = ltrim($response); + if (($position = strpos($response, "\n")) !== false) + $response = substr($response, $position+1); + else + $response = ''; + } } return $folders; -- Gitblit v1.9.1