diff options
author | thomascube <thomas@roundcube.net> | 2009-08-07 16:22:30 +0000 |
---|---|---|
committer | thomascube <thomas@roundcube.net> | 2009-08-07 16:22:30 +0000 |
commit | 2a34eb949210a43ab7fd0b2ba41d2b0006c81e48 (patch) | |
tree | ebfd7eb15e85a3d3899056a63064ba6b57f92801 /program | |
parent | 4d97074e084e7b4ae227177e530bb135c12a587f (diff) |
Add 'imap_connect' hook (#1485956)
Diffstat (limited to 'program')
-rw-r--r-- | program/include/rcube_imap.php | 17 |
1 files changed, 11 insertions, 6 deletions
diff --git a/program/include/rcube_imap.php b/program/include/rcube_imap.php index aaa77849d..b27124582 100644 --- a/program/include/rcube_imap.php +++ b/program/include/rcube_imap.php @@ -70,6 +70,8 @@ class rcube_imap var $debug_level = 1; var $error_code = 0; var $options = array('imap' => 'check'); + + private $host, $user, $pass, $port, $ssl; /** @@ -101,19 +103,22 @@ class rcube_imap // check for Open-SSL support in PHP build if ($use_ssl && extension_loaded('openssl')) $ICL_SSL = $use_ssl == 'imaps' ? 'ssl' : $use_ssl; - else if ($use_ssl) - { + else if ($use_ssl) { raise_error(array('code' => 403, 'type' => 'imap', 'file' => __FILE__, 'message' => 'Open SSL not available;'), TRUE, FALSE); $port = 143; - } + } $ICL_PORT = $port; $IMAP_USE_INTERNAL_DATE = false; + + $data = rcmail::get_instance()->plugins->exec_hook('imap_connect', array('host' => $host, 'user' => $user)); + if (!empty($data['pass'])) + $pass = $data['pass']; - $this->conn = iil_Connect($host, $user, $pass, $this->options); - $this->host = $host; - $this->user = $user; + $this->conn = iil_Connect($data['host'], $data['user'], $pass, $this->options); + $this->host = $data['host']; + $this->user = $data['user']; $this->pass = $pass; $this->port = $port; $this->ssl = $use_ssl; |