program/lib/Roundcube/rcube_imap.php | ●●●●● patch | view | raw | blame | history | |
program/lib/Roundcube/rcube_imap_cache.php | ●●●●● patch | view | raw | blame | history | |
program/lib/Roundcube/rcube_imap_generic.php | ●●●●● patch | view | raw | blame | history |
program/lib/Roundcube/rcube_imap.php
@@ -62,7 +62,6 @@ protected $sort_field = ''; protected $sort_order = 'DESC'; protected $struct_charset; protected $uid_id_map = array(); protected $msg_headers = array(); protected $search_set; protected $search_string = ''; @@ -2682,7 +2681,6 @@ // really deleted from the folder $this->expunge_message($uids, $folder, false); $this->clear_messagecount($folder); unset($this->uid_id_map[$folder]); // unset threads internal cache unset($this->icache['threads']); @@ -3963,8 +3961,6 @@ return $res; } return null; } /** @@ -3985,7 +3981,6 @@ } // @TODO: log error return null; } @@ -4254,19 +4249,11 @@ $folder = $this->folder; } if ($uid = array_search($id, (array)$this->uid_id_map[$folder])) { return $uid; } if (!$this->check_connection()) { return null; } $uid = $this->conn->ID2UID($folder, $id); $this->uid_id_map[$folder][$uid] = $id; return $uid; return $this->conn->ID2UID($folder, $id); } /** program/lib/Roundcube/rcube_imap_cache.php
@@ -986,7 +986,7 @@ return false; } // ... and max UID if ($object->max() != $this->imap->id2uid($mbox_data['EXISTS'], $mailbox, true)) { if ($object->max() != $this->imap->id2uid($mbox_data['EXISTS'], $mailbox)) { return false; } } program/lib/Roundcube/rcube_imap_generic.php
@@ -1095,6 +1095,8 @@ list($code, $response) = $this->execute('SELECT', $params); if ($code == self::ERROR_OK) { $this->clear_mailbox_cache(); $response = explode("\r\n", $response); foreach ($response as $line) { if (preg_match('/^\* ([0-9]+) (EXISTS|RECENT)$/i', $line, $m)) { @@ -2034,7 +2036,6 @@ return (int) $arr[0]; } } return null; } /** @@ -2055,14 +2056,20 @@ return null; } if ($uid = $this->data['UID-MAP'][$id]) { return $uid; } if (isset($this->data['EXISTS']) && $id > $this->data['EXISTS']) { return null; } $index = $this->search($mailbox, $id, true); if ($index->count() == 1) { $arr = $index->get(); return (int) $arr[0]; return $this->data['UID-MAP'][$id] = (int) $arr[0]; } return null; } /** @@ -3849,9 +3856,27 @@ protected function clear_status_cache($mailbox) { unset($this->data['STATUS:' . $mailbox]); unset($this->data['EXISTS']); unset($this->data['RECENT']); unset($this->data['UNSEEN']); $keys = array('EXISTS', 'RECENT', 'UNSEEN', 'UID-MAP'); foreach ($keys as $key) { unset($this->data[$key]); } } /** * Clear internal cache of the current mailbox */ protected function clear_mailbox_cache() { $this->clear_status_cache($this->selected); $keys = array('UIDNEXT', 'UIDVALIDITY', 'HIGHESTMODSEQ', 'NOMODSEQ', 'PERMANENTFLAGS', 'QRESYNC', 'VANISHED', 'READ-WRITE'); foreach ($keys as $key) { unset($this->data[$key]); } } /**