summaryrefslogtreecommitdiff
path: root/program/lib
diff options
context:
space:
mode:
authoralecpl <alec@alec.pl>2009-05-22 10:45:01 +0000
committeralecpl <alec@alec.pl>2009-05-22 10:45:01 +0000
commitaa320ede4b10288542e449bf89bdc8537ee1b6db (patch)
treeb92fb1c2a2e4787f5be93b1d5993ab8d194e245e /program/lib
parentb7682cf391fed14684db55fbe846397d6d2763fd (diff)
- handle startup response (#1484853)
Diffstat (limited to 'program/lib')
-rw-r--r--program/lib/imap.inc17
1 files changed, 14 insertions, 3 deletions
diff --git a/program/lib/imap.inc b/program/lib/imap.inc
index 66394dde8..932be4adf 100644
--- a/program/lib/imap.inc
+++ b/program/lib/imap.inc
@@ -81,6 +81,7 @@
- added \* flag support
- use PREG instead of EREG
- removed caching functions
+ - handling connection startup response
********************************************************/
@@ -229,7 +230,7 @@ function iil_PutLineC($fp, $string, $endln=true) {
return $res;
}
-function iil_ReadLine($fp, $size) {
+function iil_ReadLine($fp, $size=1024) {
$line = '';
if (!$fp) {
@@ -614,9 +615,19 @@ function iil_Connect($host, $user, $password, $options=null) {
return false;
}
- $iil_error .= "Socket connection established\r\n";
- $line = iil_ReadLine($conn->fp, 4096);
+ stream_set_timeout($conn->fp, 10);
+ $line = stream_get_line($conn->fp, 8192, "\r\n");
+ // Connected to wrong port or connection error?
+ if (!preg_match('/^\* (OK|PREAUTH)/i', $line)) {
+ if ($line)
+ $iil_error = "Wrong startup greeting ($host:$ICL_PORT): $line";
+ else
+ $iil_error = "Empty startup greeting ($host:$ICL_PORT)";
+ $iil_errornum = -2;
+ return false;
+ }
+
// RFC3501 [7.1] optional CAPABILITY response
if (preg_match('/\[CAPABILITY ([^]]+)\]/i', $line, $matches)) {
$conn->capability = explode(' ', strtoupper($matches[1]));