diff options
| author | Aleksander Machniak <alec@alec.pl> | 2014-04-11 19:28:52 +0200 | 
|---|---|---|
| committer | Aleksander Machniak <alec@alec.pl> | 2014-04-11 19:28:52 +0200 | 
| commit | 0ca75d488059b685ae344dbb629aa935dce3ab79 (patch) | |
| tree | 510c18bf83cfec2a35c685553bd0e04f62fcb9fe | |
| parent | 209a75c2b2820d093e00cf2b8c1e6221d39c90d1 (diff) | |
Fix messages index cache update under some conditions (e.g. proxy) (#1489756)
| -rw-r--r-- | CHANGELOG | 1 | ||||
| -rw-r--r-- | program/lib/Roundcube/rcube_imap_cache.php | 5 | 
2 files changed, 5 insertions, 1 deletions
| @@ -11,6 +11,7 @@ CHANGELOG Roundcube Webmail  - Fix bug where "With attachment" option in search filter wasn't selected after return from mail view (#1489774)  - Fix "washing" of unicoded style attributes (#1489777)  - Fix unintentional redirect from compose page in Webkit browsers (#1489789) +- Fix messages index cache update under some conditions (e.g. proxy) (#1489756)  RELEASE 1.0.0  ------------- diff --git a/program/lib/Roundcube/rcube_imap_cache.php b/program/lib/Roundcube/rcube_imap_cache.php index 0c3edeaad..e49e77803 100644 --- a/program/lib/Roundcube/rcube_imap_cache.php +++ b/program/lib/Roundcube/rcube_imap_cache.php @@ -171,7 +171,7 @@ class rcube_imap_cache          // Seek in internal cache          if (array_key_exists('index', $this->icache[$mailbox])) {              // The index was fetched from database already, but not validated yet -            if (!array_key_exists('object', $this->icache[$mailbox]['index'])) { +            if (empty($this->icache[$mailbox]['index']['validated'])) {                  $index = $this->icache[$mailbox]['index'];              }              // We've got a valid index @@ -248,6 +248,7 @@ class rcube_imap_cache          }          $this->icache[$mailbox]['index'] = array( +            'validated'  => true,              'object'     => $data,              'sort_field' => $sort_field,              'modseq'     => !empty($index['modseq']) ? $index['modseq'] : $mbox_data['HIGHESTMODSEQ'] @@ -890,6 +891,8 @@ class rcube_imap_cache              return false;          } +        $index['validated'] = true; +          // Get mailbox data (UIDVALIDITY, counters, etc.) for status check          $mbox_data = $this->imap->folder_data($mailbox); | 
