diff options
author | alecpl <alec@alec.pl> | 2010-11-09 13:49:31 +0000 |
---|---|---|
committer | alecpl <alec@alec.pl> | 2010-11-09 13:49:31 +0000 |
commit | d903fb4dd437423f32054abd5b2164b261776555 (patch) | |
tree | c6eb134e8593c889cc6545d86207dec68d734b71 | |
parent | 6d99f995766d32e6074201b847adf3ce7e5b0dbf (diff) |
- Fix lack of IMAP server response in logged error message when using AUTHENTICATE PLAIN with SASL-IR
-rw-r--r-- | program/include/rcube_imap_generic.php | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/program/include/rcube_imap_generic.php b/program/include/rcube_imap_generic.php index 6de27e806..56f30aa81 100644 --- a/program/include/rcube_imap_generic.php +++ b/program/include/rcube_imap_generic.php @@ -118,6 +118,7 @@ class rcube_imap_generic const COMMAND_NORESPONSE = 1; const COMMAND_CAPABILITY = 2; + const COMMAND_LASTLINE = 4; /** * Object constructor @@ -491,8 +492,8 @@ class rcube_imap_generic // RFC 4959 (SASL-IR): save one round trip if ($this->getCapability('SASL-IR')) { - $result = $this->execute("AUTHENTICATE PLAIN", array($reply), - self::COMMAND_NORESPONSE | self::COMMAND_CAPABILITY); + list($result, $line) = $this->execute("AUTHENTICATE PLAIN", array($reply), + self::COMMAND_LASTLINE | self::COMMAND_CAPABILITY); } else { $this->putLine($this->nextTag() . " AUTHENTICATE PLAIN"); @@ -2888,6 +2889,11 @@ class rcube_imap_generic $this->parseCapability($matches[1], true); } + // return last line only (without command tag and result) + if ($line && ($options & self::COMMAND_LASTLINE)) { + $response = preg_replace("/^$tag (OK|NO|BAD|BYE|PREAUTH)?\s*/i", '', trim($line)); + } + return $noresp ? $code : array($code, $response); } |