From 87e3ed6ed09a9fcd3cab45a6ce674396e51b95bb Mon Sep 17 00:00:00 2001 From: thomascube <thomas@roundcube.net> Date: Thu, 10 Aug 2006 14:53:07 -0400 Subject: [PATCH] Updated Slovak translation --- program/include/rcube_imap.inc | 524 +++++++++++++++++++++++++++++++++++++-------------------- 1 files changed, 338 insertions(+), 186 deletions(-) diff --git a/program/include/rcube_imap.inc b/program/include/rcube_imap.inc index c818fa0..9c93f62 100644 --- a/program/include/rcube_imap.inc +++ b/program/include/rcube_imap.inc @@ -26,7 +26,6 @@ */ require_once('lib/imap.inc'); require_once('lib/mime.inc'); -require_once('lib/utf7.inc'); /** @@ -36,7 +35,7 @@ * * @package RoundCube Webmail * @author Thomas Bruederli <roundcube@gmail.com> - * @version 1.22 + * @version 1.31 * @link http://ilohamail.org */ class rcube_imap @@ -52,10 +51,11 @@ var $sort_order = 'DESC'; var $delimiter = NULL; var $caching_enabled = FALSE; - var $default_folders = array('inbox', 'drafts', 'sent', 'junk', 'trash'); + var $default_folders = array('INBOX'); + var $default_folders_lc = array('inbox'); var $cache = array(); var $cache_keys = array(); - var $cache_changes = array(); + var $cache_changes = array(); var $uid_id_map = array(); var $msg_headers = array(); var $capabilities = array(); @@ -208,15 +208,16 @@ { if (is_array($arr)) { - $this->default_folders = array(); - - // add mailbox names lower case - foreach ($arr as $mbox) - $this->default_folders[] = strtolower($mbox); - + $this->default_folders = $arr; + $this->default_folders_lc = array(); + // add inbox if not included - if (!in_array('inbox', $this->default_folders)) - array_unshift($arr, 'inbox'); + if (!in_array_nocase('INBOX', $this->default_folders)) + array_unshift($this->default_folders, 'INBOX'); + + // create a second list with lower cased names + foreach ($this->default_folders as $mbox) + $this->default_folders_lc[] = strtolower($mbox); } } @@ -229,9 +230,9 @@ * @param string Mailbox/Folder name * @access public */ - function set_mailbox($mbox) + function set_mailbox($new_mbox) { - $mailbox = $this->_mod_mailbox($mbox); + $mailbox = $this->_mod_mailbox($new_mbox); if ($this->mailbox == $mailbox) return; @@ -326,12 +327,16 @@ $a_out = array(); $a_mboxes = $this->_list_mailboxes($root, $filter); - foreach ($a_mboxes as $mbox) + foreach ($a_mboxes as $mbox_row) { - $name = $this->_mod_mailbox($mbox, 'out'); + $name = $this->_mod_mailbox($mbox_row, 'out'); if (strlen($name)) $a_out[] = $name; } + + // INBOX should always be available + if (!in_array_nocase('INBOX', $a_out)) + array_unshift($a_out, 'INBOX'); // sort mailboxes $a_out = $this->_sort_mailbox_list($a_out); @@ -362,15 +367,6 @@ if (!is_array($a_folders) || !sizeof($a_folders)) $a_folders = array(); - // create INBOX if it does not exist - if (!in_array_nocase('INBOX', $a_folders)) - { - $this->create_mailbox('INBOX', TRUE); - array_unshift($a_folders, 'INBOX'); - } - - $a_mailbox_cache = array(); - // write mailboxlist to cache $this->update_cache('mailboxes', $a_folders); @@ -387,9 +383,9 @@ * @return number Number of messages * @access public */ - function messagecount($mbox='', $mode='ALL', $force=FALSE) + function messagecount($mbox_name='', $mode='ALL', $force=FALSE) { - $mailbox = $mbox ? $this->_mod_mailbox($mbox) : $this->mailbox; + $mailbox = $mbox_name ? $this->_mod_mailbox($mbox_name) : $this->mailbox; return $this->_messagecount($mailbox, $mode, $force); } @@ -469,9 +465,9 @@ * @return array Indexed array with message header objects * @access public */ - function list_headers($mbox='', $page=NULL, $sort_field=NULL, $sort_order=NULL) + function list_headers($mbox_name='', $page=NULL, $sort_field=NULL, $sort_order=NULL) { - $mailbox = $mbox ? $this->_mod_mailbox($mbox) : $this->mailbox; + $mailbox = $mbox_name ? $this->_mod_mailbox($mbox_name) : $this->mailbox; return $this->_list_headers($mailbox, $page, $sort_field, $sort_order); } @@ -494,73 +490,51 @@ $max = $this->_messagecount($mailbox); $start_msg = ($this->list_page-1) * $this->page_size; - - list($begin, $end) = $this->_get_message_range($max, $page); - - /* - if ($page=='all') - { - $begin = 0; - $end = $max; - } - else if (!$this->get_capability('sort') && $this->sort_order=='DESC') - { - $begin = $max - $this->page_size - $start_msg; - $end = $max - $start_msg; - } - else - { - $begin = $start_msg; - $end = $start_msg + $this->page_size; - } - if ($begin < 0) $begin = 0; - if ($end < 0) $end = $max; - if ($end > $max) $end = $max; - */ - -//console("fetch headers $start_msg to ".($start_msg+$this->page_size)." (msg $begin to $end)"); + list($begin, $end) = $this->_get_message_range($max, $page); + + // mailbox is empty + if ($begin >= $end) + return array(); $headers_sorted = FALSE; $cache_key = $mailbox.'.msg'; $cache_status = $this->check_cache_status($mailbox, $cache_key); -//console("Cache status = $cache_status"); - // cache is OK, we can get all messages from local cache if ($cache_status>0) { $a_msg_headers = $this->get_message_cache($cache_key, $start_msg, $start_msg+$this->page_size, $this->sort_field, $this->sort_order); $headers_sorted = TRUE; } + // cache is dirty, sync it + else if ($this->caching_enabled && $cache_status==-1 && !$recursive) + { + $this->sync_header_index($mailbox); + return $this->_list_headers($mailbox, $page, $this->sort_field, $this->sort_order, TRUE); + } else { // retrieve headers from IMAP if ($this->get_capability('sort') && ($msg_index = iil_C_Sort($this->conn, $mailbox, $this->sort_field, $this->skip_deleted ? 'UNDELETED' : ''))) - { -//console("$mailbox: ".join(',', $msg_index)); - + { $msgs = $msg_index[$begin]; for ($i=$begin+1; $i < $end; $i++) $msgs = $msgs.','.$msg_index[$i]; - - $sorted = TRUE; } else { $msgs = sprintf("%d:%d", $begin+1, $end); - $sorted = FALSE; + + $i = 0; + for ($msg_seqnum = $begin; $msg_seqnum <= $end; $msg_seqnum++) + $msg_index[$i++] = $msg_seqnum; } + // use this class for message sorting + $sorter = new rcube_header_sorter(); + $sorter->set_sequence_numbers($msg_index); - // cache is dirty, sync it - if ($this->caching_enabled && $cache_status==-1 && !$recursive) - { - $this->sync_header_index($mailbox); - return $this->_list_headers($mailbox, $page, $this->sort_field, $this->sort_order, TRUE); - } - - // fetch reuested headers from server $a_msg_headers = array(); $deleted_count = $this->_fetch_headers($mailbox, $msgs, $a_msg_headers, $cache_key); @@ -568,10 +542,10 @@ // delete cached messages with a higher index than $max $this->clear_message_cache($cache_key, $max); - + // kick child process to sync cache // ... - + } @@ -581,17 +555,18 @@ // if not already sorted -// if (!$headers_sorted) -// $a_msg_headers = iil_SortHeaders($a_msg_headers, $this->sort_field, $this->sort_order); + if (!$headers_sorted) + { + $sorter->sort_headers($a_msg_headers); - - if (!$headers_sorted && $this->sort_order == 'DESC') + if ($this->sort_order == 'DESC') $a_msg_headers = array_reverse($a_msg_headers); - + } return array_values($a_msg_headers); } - + + /** * Public method for listing a specific set of headers @@ -605,9 +580,9 @@ * @return array Indexed array with message header objects * @access public */ - function list_header_set($mbox='', $msgs, $page=NULL, $sort_field=NULL, $sort_order=NULL) + function list_header_set($mbox_name='', $msgs, $page=NULL, $sort_field=NULL, $sort_order=NULL) { - $mailbox = $mbox ? $this->_mod_mailbox($mbox) : $this->mailbox; + $mailbox = $mbox_name ? $this->_mod_mailbox($mbox_name) : $this->mailbox; return $this->_list_header_set($mailbox, $msgs, $page, $sort_field, $sort_order); } @@ -735,14 +710,14 @@ // return sorted array of message UIDs - function message_index($mbox='', $sort_field=NULL, $sort_order=NULL) + function message_index($mbox_name='', $sort_field=NULL, $sort_order=NULL) { if ($sort_field!=NULL) $this->sort_field = $sort_field; if ($sort_order!=NULL) $this->sort_order = strtoupper($sort_order); - $mailbox = $mbox ? $this->_mod_mailbox($mbox) : $this->mailbox; + $mailbox = $mbox_name ? $this->_mod_mailbox($mbox_name) : $this->mailbox; $key = "$mbox:".$this->sort_field.":".$this->sort_order.".msgi"; // have stored it in RAM @@ -851,13 +826,19 @@ * @return array search results as list of message ids * @access public */ - function search($mbox='', $criteria='ALL', $str=NULL) + function search($mbox_name='', $criteria='ALL', $str=NULL, $charset=NULL) { - $mailbox = $mbox ? $this->_mod_mailbox($mbox) : $this->mailbox; + $mailbox = $mbox_name ? $this->_mod_mailbox($mbox_name) : $this->mailbox; if ($str && $criteria) { - $criteria .= " \"$str\""; - return $this->_search_index($mailbox, $criteria); + $search = (!empty($charset) ? "CHARSET $charset " : '') . sprintf("%s {%d}\r\n%s", $criteria, strlen($str), $str); + $results = $this->_search_index($mailbox, $search); + + // try search with ISO charset (should be supported by server) + if (empty($results) && !empty($charset) && $charset!='ISO-8859-1') + $results = $this->search($mbox_name, $criteria, rcube_charset_convert($str, $charset, 'ISO-8859-1'), 'ISO-8859-1'); + + return $results; } else return $this->_search_index($mailbox, $criteria); @@ -874,19 +855,21 @@ function _search_index($mailbox, $criteria='ALL') { $a_messages = iil_C_Search($this->conn, $mailbox, $criteria); - // clean message list (there might be some empty entries) - foreach ($a_messages as $i => $val) - if (empty($val)) - unset($a_messages[$i]); + if (is_array($a_messages)) + { + foreach ($a_messages as $i => $val) + if (empty($val)) + unset($a_messages[$i]); + } return $a_messages; } - function get_headers($id, $mbox=NULL, $is_uid=TRUE) + function get_headers($id, $mbox_name=NULL, $is_uid=TRUE) { - $mailbox = $mbox ? $this->_mod_mailbox($mbox) : $this->mailbox; + $mailbox = $mbox_name ? $this->_mod_mailbox($mbox_name) : $this->mailbox; // get cached headers if ($is_uid && ($headers = $this->get_cached_message($mailbox.'.msg', $id))) @@ -934,18 +917,21 @@ // set message flag to one or several messages - // possible flgs are: SEEN, DELETED, RECENT, ANSWERED, DRAFT + // possible flags are: SEEN, UNDELETED, DELETED, RECENT, ANSWERED, DRAFT function set_flag($uids, $flag) { $flag = strtoupper($flag); $msg_ids = array(); if (!is_array($uids)) - $uids = array($uids); + $uids = explode(',',$uids); - foreach ($uids as $uid) + foreach ($uids as $uid) { $msg_ids[$uid] = $this->_uid2id($uid); + } - if ($flag=='UNSEEN') + if ($flag=='UNDELETED') + $result = iil_C_Undelete($this->conn, $this->mailbox, join(',', array_values($msg_ids))); + else if ($flag=='UNSEEN') $result = iil_C_Unseen($this->conn, $this->mailbox, join(',', array_values($msg_ids))); else $result = iil_C_Flag($this->conn, $this->mailbox, join(',', array_values($msg_ids)), $flag); @@ -984,9 +970,10 @@ // append a mail message (source) to a specific mailbox - function save_message($mbox, $message) + function save_message($mbox_name, &$message) { - $mailbox = $this->_mod_mailbox($mbox); + $mbox_name = stripslashes($mbox_name); + $mailbox = $this->_mod_mailbox($mbox_name); // make sure mailbox exists if (in_array($mailbox, $this->_list_mailboxes())) @@ -1005,6 +992,8 @@ // move a message from one mailbox to another function move_message($uids, $to_mbox, $from_mbox='') { + $to_mbox = stripslashes($to_mbox); + $from_mbox = stripslashes($from_mbox); $to_mbox = $this->_mod_mailbox($to_mbox); $from_mbox = $from_mbox ? $this->_mod_mailbox($from_mbox) : $this->mailbox; @@ -1047,8 +1036,8 @@ $start_index = 100000; foreach ($a_uids as $uid) { - $index = array_search($uid, $a_cache_index); - $start_index = min($index, $start_index); + if(($index = array_search($uid, $a_cache_index)) !== FALSE) + $start_index = min($index, $start_index); } // clear cache from the lowest index on @@ -1060,9 +1049,10 @@ // mark messages as deleted and expunge mailbox - function delete_message($uids, $mbox='') + function delete_message($uids, $mbox_name='') { - $mailbox = $mbox ? $this->_mod_mailbox($mbox) : $this->mailbox; + $mbox_name = stripslashes($mbox_name); + $mailbox = $mbox_name ? $this->_mod_mailbox($mbox_name) : $this->mailbox; // convert the list of uids to array $a_uids = is_string($uids) ? explode(',', $uids) : (is_array($uids) ? $uids : NULL); @@ -1107,9 +1097,10 @@ // clear all messages in a specific mailbox - function clear_mailbox($mbox=NULL) + function clear_mailbox($mbox_name=NULL) { - $mailbox = !empty($mbox) ? $this->_mod_mailbox($mbox) : $this->mailbox; + $mbox_name = stripslashes($mbox_name); + $mailbox = !empty($mbox_name) ? $this->_mod_mailbox($mbox_name) : $this->mailbox; $msg_count = $this->_messagecount($mailbox, 'ALL'); if ($msg_count>0) @@ -1133,9 +1124,10 @@ // send IMAP expunge command and clear cache - function expunge($mbox='', $clear_cache=TRUE) + function expunge($mbox_name='', $clear_cache=TRUE) { - $mailbox = $mbox ? $this->_mod_mailbox($mbox) : $this->mailbox; + $mbox_name = stripslashes($mbox_name); + $mailbox = $mbox_name ? $this->_mod_mailbox($mbox_name) : $this->mailbox; return $this->_expunge($mailbox, $clear_cache); } @@ -1160,7 +1152,12 @@ * --------------------------------*/ - // return an array with all folders available in IMAP server + /** + * Get a list of all folders available on the IMAP server + * + * @param string IMAP root dir + * @return array Inbdexed array with folder names + */ function list_unsubscribed($root='') { static $sa_unsubscribed; @@ -1172,9 +1169,9 @@ $a_mboxes = iil_C_ListMailboxes($this->conn, $this->_mod_mailbox($root), '*'); // modify names with root dir - foreach ($a_mboxes as $mbox) + foreach ($a_mboxes as $mbox_name) { - $name = $this->_mod_mailbox($mbox, 'out'); + $name = $this->_mod_mailbox($mbox_name, 'out'); if (strlen($name)) $a_folders[] = $name; } @@ -1202,33 +1199,43 @@ } - // subscribe to a specific mailbox(es) - function subscribe($mbox, $mode='subscribe') + /** + * subscribe to a specific mailbox(es) + */ + function subscribe($mbox_name, $mode='subscribe') { - if (is_array($mbox)) - $a_mboxes = $mbox; - else if (is_string($mbox) && strlen($mbox)) - $a_mboxes = explode(',', $mbox); + if (is_array($mbox_name)) + $a_mboxes = $mbox_name; + else if (is_string($mbox_name) && strlen($mbox_name)) + $a_mboxes = explode(',', $mbox_name); // let this common function do the main work return $this->_change_subscription($a_mboxes, 'subscribe'); } - // unsubscribe mailboxes - function unsubscribe($mbox) + /** + * unsubscribe mailboxes + */ + function unsubscribe($mbox_name) { - if (is_array($mbox)) - $a_mboxes = $mbox; - else if (is_string($mbox) && strlen($mbox)) - $a_mboxes = explode(',', $mbox); + if (is_array($mbox_name)) + $a_mboxes = $mbox_name; + else if (is_string($mbox_name) && strlen($mbox_name)) + $a_mboxes = explode(',', $mbox_name); // let this common function do the main work return $this->_change_subscription($a_mboxes, 'unsubscribe'); } - // create a new mailbox on the server and register it in local cache + /** + * Create a new mailbox on the server and register it in local cache + * + * @param string New mailbox name (as utf-7 string) + * @param boolean True if the new mailbox should be subscribed + * @param string Name of the created mailbox, false on error + */ function create_mailbox($name, $subscribe=FALSE) { $result = FALSE; @@ -1236,50 +1243,81 @@ // replace backslashes $name = preg_replace('/[\\\]+/', '-', $name); - $name_enc = UTF7EncodeString($name); - // reduce mailbox name to 100 chars - $name_enc = substr($name_enc, 0, 100); + $name = substr($name, 0, 100); - $abs_name = $this->_mod_mailbox($name_enc); + $abs_name = $this->_mod_mailbox($name); $a_mailbox_cache = $this->get_cache('mailboxes'); - - if (strlen($abs_name) && (!is_array($a_mailbox_cache) || !in_array($abs_name, $a_mailbox_cache))) + + if (strlen($abs_name) && (!is_array($a_mailbox_cache) || !in_array_nocase($abs_name, $a_mailbox_cache))) $result = iil_C_CreateFolder($this->conn, $abs_name); - // update mailboxlist cache - if ($result && $subscribe) - $this->subscribe($name_enc); + // try to subscribe it + if ($subscribe) + $this->subscribe($name); return $result ? $name : FALSE; } - // set a new name to an existing mailbox - function rename_mailbox($mbox, $new_name) + /** + * Set a new name to an existing mailbox + * + * @param string Mailbox to rename (as utf-7 string) + * @param string New mailbox name (as utf-7 string) + * @param string Name of the renames mailbox, false on error + */ + function rename_mailbox($mbox_name, $new_name) { - // not implemented yet + $result = FALSE; + + // replace backslashes + $name = preg_replace('/[\\\]+/', '-', $new_name); + + // encode mailbox name and reduce it to 100 chars + $name = substr($new_name, 0, 100); + + // make absolute path + $mailbox = $this->_mod_mailbox($mbox_name); + $abs_name = $this->_mod_mailbox($name); + + if (strlen($abs_name)) + $result = iil_C_RenameFolder($this->conn, $mailbox, $abs_name); + + // clear cache + if ($result) + { + $this->clear_message_cache($mailbox.'.msg'); + $this->clear_cache('mailboxes'); + } + + // try to subscribe it + $this->subscribe($name); + + return $result ? $name : FALSE; } - // remove mailboxes from server - function delete_mailbox($mbox) + /** + * remove mailboxes from server + */ + function delete_mailbox($mbox_name) { $deleted = FALSE; - if (is_array($mbox)) - $a_mboxes = $mbox; - else if (is_string($mbox) && strlen($mbox)) - $a_mboxes = explode(',', $mbox); + if (is_array($mbox_name)) + $a_mboxes = $mbox_name; + else if (is_string($mbox_name) && strlen($mbox_name)) + $a_mboxes = explode(',', $mbox_name); if (is_array($a_mboxes)) - foreach ($a_mboxes as $mbox) + foreach ($a_mboxes as $mbox_name) { - $mailbox = $this->_mod_mailbox($mbox); + $mailbox = $this->_mod_mailbox($mbox_name); // unsubscribe mailbox before deleting iil_C_UnSubscribe($this->conn, $mailbox); - + // send delete command to server $result = iil_C_DeleteFolder($this->conn, $mailbox); if ($result>=0) @@ -1296,6 +1334,28 @@ return $deleted; } + + /** + * Create all folders specified as default + */ + function create_default_folders() + { + $a_folders = iil_C_ListMailboxes($this->conn, $this->_mod_mailbox(''), '*'); + $a_subscribed = iil_C_ListSubscribed($this->conn, $this->_mod_mailbox(''), '*'); + + // create default folders if they do not exist + foreach ($this->default_folders as $folder) + { + $abs_name = $this->_mod_mailbox($folder); + if (!in_array_nocase($abs_name, $a_subscribed)) + { + if (!in_array_nocase($abs_name, $a_folders)) + $this->create_mailbox($folder, TRUE); + else + $this->subscribe($folder); + } + } + } @@ -1652,7 +1712,7 @@ { $a = $this->_parse_address_list($input); $out = array(); - + if (!is_array($a)) return $out; @@ -1688,9 +1748,14 @@ return $str; } - - - function decode_mime_string($input) + + + /** + * Decode a mime-encoded string to internal charset + * + * @access static + */ + function decode_mime_string($input, $recursive=false) { $out = ''; @@ -1711,11 +1776,17 @@ return $out; } - else - return $input; + + // no encoding information, defaults to what is specified in the class header + return rcube_charset_convert($input, 'ISO-8859-1'); } + /** + * Decode a part of a mime-encoded string + * + * @access static + */ function _decode_mime_string_part($str) { $a = explode('?', $str); @@ -1788,8 +1859,10 @@ if (is_array($ctype_param) && !empty($ctype_param['charset'])) return rcube_charset_convert($body, $ctype_param['charset']); - return $body; + // defaults to what is specified in the class header + return rcube_charset_convert($body, 'ISO-8859-1'); } + @@ -1798,17 +1871,17 @@ * --------------------------------*/ - function _mod_mailbox($mbox, $mode='in') + function _mod_mailbox($mbox_name, $mode='in') { - if ((!empty($this->root_ns) && $this->root_ns == $mbox) || ($mbox == 'INBOX' && $mode == 'in')) - return $mbox; + if ((!empty($this->root_ns) && $this->root_ns == $mbox_name) || $mbox_name == 'INBOX') + return $mbox_name; if (!empty($this->root_dir) && $mode=='in') - $mbox = $this->root_dir.$this->delimiter.$mbox; + $mbox_name = $this->root_dir.$this->delimiter.$mbox_name; else if (strlen($this->root_dir) && $mode=='out') - $mbox = substr($mbox, strlen($this->root_dir)+1); + $mbox_name = substr($mbox_name, strlen($this->root_dir)+1); - return $mbox; + return $mbox_name; } @@ -1822,8 +1895,8 @@ { if ($folder{0}=='.') continue; - - if (($p = array_search(strtolower($folder), $this->default_folders))!==FALSE) + + if (($p = array_search(strtolower($folder), $this->default_folders_lc))!==FALSE) $a_defaults[$p] = $folder; else $a_out[] = $folder; @@ -1835,33 +1908,33 @@ return array_merge($a_defaults, $a_out); } - function get_id($uid) + function get_id($uid, $mbox_name=NULL) { - return $this->_uid2id($uid); + return $this->_uid2id($uid, $mbox_name); } - function get_uid($id) + function get_uid($id,$mbox_name=NULL) { - return $this->_id2uid($id); + return $this->_id2uid($id, $mbox_name); } - function _uid2id($uid, $mbox=NULL) + function _uid2id($uid, $mbox_name=NULL) { - if (!$mbox) - $mbox = $this->mailbox; + if (!$mbox_name) + $mbox_name = $this->mailbox; - if (!isset($this->uid_id_map[$mbox][$uid])) - $this->uid_id_map[$mbox][$uid] = iil_C_UID2ID($this->conn, $mbox, $uid); + if (!isset($this->uid_id_map[$mbox_name][$uid])) + $this->uid_id_map[$mbox_name][$uid] = iil_C_UID2ID($this->conn, $mbox_name, $uid); - return $this->uid_id_map[$mbox][$uid]; + return $this->uid_id_map[$mbox_name][$uid]; } - function _id2uid($id, $mbox=NULL) + function _id2uid($id, $mbox_name=NULL) { - if (!$mbox) - $mbox = $this->mailbox; + if (!$mbox_name) + $mbox_name = $this->mailbox; - return iil_C_ID2UID($this->conn, $mbox, $id); + return iil_C_ID2UID($this->conn, $mbox_name, $id); } @@ -1898,9 +1971,9 @@ $updated = FALSE; if (is_array($a_mboxes)) - foreach ($a_mboxes as $i => $mbox) + foreach ($a_mboxes as $i => $mbox_name) { - $mailbox = $this->_mod_mailbox($mbox); + $mailbox = $this->_mod_mailbox($mbox_name); $a_mboxes[$i] = $mailbox; if ($mode=='subscribe') @@ -1934,10 +2007,10 @@ // increde/decrese messagecount for a specific mailbox - function _set_messagecount($mbox, $mode, $increment) + function _set_messagecount($mbox_name, $mode, $increment) { $a_mailbox_cache = FALSE; - $mailbox = $mbox ? $mbox : $this->mailbox; + $mailbox = $mbox_name ? $mbox_name : $this->mailbox; $mode = strtoupper($mode); $a_mailbox_cache = $this->get_cache('messagecount'); @@ -1960,10 +2033,10 @@ // remove messagecount of a specific mailbox from cache - function _clear_messagecount($mbox='') + function _clear_messagecount($mbox_name='') { $a_mailbox_cache = FALSE; - $mailbox = $mbox ? $mbox : $this->mailbox; + $mailbox = $mbox_name ? $mbox_name : $this->mailbox; $a_mailbox_cache = $this->get_cache('messagecount'); @@ -1979,12 +2052,13 @@ { $a = $this->_explode_quoted_string(',', $str); $result = array(); - + foreach ($a as $key => $val) { $val = str_replace("\"<", "\" <", $val); - $sub_a = $this->_explode_quoted_string(' ', $val); - + $sub_a = $this->_explode_quoted_string(' ', $this->decode_header($val)); + $result[$key]['name'] = ''; + foreach ($sub_a as $k => $v) { if ((strpos($v, '@') > 0) && (strpos($v, '.') > 0)) @@ -1994,9 +2068,7 @@ } if (empty($result[$key]['name'])) - $result[$key]['name'] = $result[$key]['address']; - - $result[$key]['name'] = $this->decode_header($result[$key]['name']); + $result[$key]['name'] = $result[$key]['address']; } return $result; @@ -2022,9 +2094,89 @@ +/** + * rcube_header_sorter + * + * Class for sorting an array of iilBasicHeader objects in a predetermined order. + * + * @author Eric Stadtherr + */ +class rcube_header_sorter +{ + var $sequence_numbers = array(); + + /** + * set the predetermined sort order. + * + * @param array $seqnums numerically indexed array of IMAP message sequence numbers + */ + function set_sequence_numbers($seqnums) + { + $this->sequence_numbers = $seqnums; + } + + /** + * sort the array of header objects + * + * @param array $headers array of iilBasicHeader objects indexed by UID + */ + function sort_headers(&$headers) + { + /* + * uksort would work if the keys were the sequence number, but unfortunately + * the keys are the UIDs. We'll use uasort instead and dereference the value + * to get the sequence number (in the "id" field). + * + * uksort($headers, array($this, "compare_seqnums")); + */ + uasort($headers, array($this, "compare_seqnums")); + } + + /** + * get the position of a message sequence number in my sequence_numbers array + * + * @param integer $seqnum message sequence number contained in sequence_numbers + */ + function position_of($seqnum) + { + $c = count($this->sequence_numbers); + for ($pos = 0; $pos <= $c; $pos++) + { + if ($this->sequence_numbers[$pos] == $seqnum) + return $pos; + } + return -1; + } + + /** + * Sort method called by uasort() + */ + function compare_seqnums($a, $b) + { + // First get the sequence number from the header object (the 'id' field). + $seqa = $a->id; + $seqb = $b->id; + + // then find each sequence number in my ordered list + $posa = $this->position_of($seqa); + $posb = $this->position_of($seqb); + + // return the relative position as the comparison value + $ret = $posa - $posb; + return $ret; + } +} -function quoted_printable_encode($input="", $line_max=76, $space_conv=false) +/** + * Add quoted-printable encoding to a given string + * + * @param string $input string to encode + * @param int $line_max add new line after this number of characters + * @param boolena $space_conf true if spaces should be converted into =20 + * @return encoded string + */ +function quoted_printable_encode($input, $line_max=76, $space_conv=false) { $hex = array('0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'); $lines = preg_split("/(?:\r\n|\r|\n)/", $input); @@ -2081,4 +2233,4 @@ return trim($output); } -?> \ No newline at end of file +?> -- Gitblit v1.9.1