$new_name ) { global $delimiter, $imap_server_type; if ( substr( $old_name, -1 ) == $delimiter ) { $old_name = substr( $old_name, 0, strlen( $old_name ) - 1 ); $new_name = substr( $new_name, 0, strlen( $new_name ) - 1 ); $postfix = $delimiter; } else { $postfix = ''; } $boxesall = sqimap_mailbox_list($imap_stream); $cmd = 'RENAME "' . quoteIMAP($old_name) . '" "' . quoteIMAP($new_name) . '"'; $data = sqimap_run_command($imap_stream, $cmd, TRUE, $response, $message); sqimap_unsubscribe($imap_stream, $old_name.$postfix); sqimap_subscribe($imap_stream, $new_name.$postfix); do_hook_function("rename_or_delete_folder",$args = array($old_name, 'rename', $new_name)); $l = strlen( $old_name ) + 1; $p = 'unformatted'; foreach ( $boxesall as $box ) { if ( substr( $box[$p], 0, $l ) == $old_name . $delimiter ) { $new_sub = $new_name . $delimiter . substr($box[$p], $l); if ($imap_server_type == 'cyrus') { $cmd = 'RENAME "' . quoteIMAP($box[$p]) . '" "' . quoteIMAP($new_sub) . '"'; $data = sqimap_run_command($imap_stream, $cmd, TRUE, $response, $message); } sqimap_unsubscribe($imap_stream, $box[$p]); sqimap_subscribe($imap_stream, $new_sub); do_hook_function("rename_or_delete_folder",$args = array($box[$p], 'rename', $new_sub)); } } } } /****************************************************************************** ** Formats a mailbox into 4 parts for the $boxesall array ** ** The four parts are: ** ** raw - Raw LIST/LSUB response from the IMAP server ** formatted - nicely formatted folder name ** unformatted - unformatted, but with delimiter at end removed ** unformatted-dm - folder name as it appears in raw response ** unformatted-disp - unformatted without $folder_prefix ** ******************************************************************************/ function sqimap_mailbox_parse ($line, $line_lsub) { global $folder_prefix, $delimiter; /* Process each folder line */ for ($g=0; $g < count($line); $g++) { /* Store the raw IMAP reply */ if (isset($line[$g])) { $boxesall[$g]["raw"] = $line[$g]; } else { $boxesall[$g]["raw"] = ""; } /* Count number of delimiters ($delimiter) in folder name */ $mailbox = trim($line_lsub[$g]); $dm_count = substr_count($mailbox, $delimiter); if (substr($mailbox, -1) == $delimiter) { /* If name ends in delimiter - decrement count by one */ $dm_count--; } /* Format folder name, but only if it's a INBOX.* or have */ /* a parent. */ $boxesallbyname[$mailbox] = $g; $parentfolder = readMailboxParent($mailbox, $delimiter); if ( (strtolower(substr($mailbox, 0, 5)) == "inbox") || (substr($mailbox, 0, strlen($folder_prefix)) == $folder_prefix) || ( isset($boxesallbyname[$parentfolder]) && (strlen($parentfolder) > 0) ) ) { $indent = $dm_count - ( substr_count($folder_prefix, $delimiter)); if ($indent > 0) { $boxesall[$g]['formatted'] = str_repeat("  ", $indent); } else { $boxesall[$g]['formatted'] = ''; } $boxesall[$g]['formatted'] .= readShortMailboxName($mailbox, $delimiter); } else { $boxesall[$g]['formatted'] = $mailbox; } $boxesall[$g]['unformatted-dm'] = $mailbox; if (substr($mailbox, -1) == $delimiter) { $mailbox = substr($mailbox, 0, strlen($mailbox) - 1); } $boxesall[$g]['unformatted'] = $mailbox; if (substr($mailbox,0,strlen($folder_prefix))==$folder_prefix) { $mailbox = substr($mailbox, strlen($folder_prefix)); } $boxesall[$g]['unformatted-disp'] = $mailbox; $boxesall[$g]['id'] = $g; $boxesall[$g]['flags'] = array(); if (isset($line[$g])) { ereg("\(([^)]*)\)",$line[$g],$regs); $flags = trim(strtolower(str_replace('\\', '',$regs[1]))); if ($flags) { $boxesall[$g]['flags'] = explode(' ', $flags); } } } return $boxesall; } /** * Sorting function used to sort mailbox names. * + Original patch from dave_michmerhuizen@yahoo.com * + Allows case insensitivity when sorting folders * + Takes care of the delimiter being sorted to the end, causing * subfolders to be listed in below folders that are prefixed * with their parent folders name. * For example: INBOX.foo, INBOX.foobar, and INBOX.foo.bar * Without special sort function: foobar between foo and foo.bar * With special sort function: foobar AFTER foo and foo.bar :) */ function user_strcasecmp($a, $b) { global $delimiter; /* Calculate the length of some strings. */ $a_length = strlen($a); $b_length = strlen($b); $min_length = min($a_length, $b_length); $delimiter_length = strlen($delimiter); /* Set the initial result value. */ $result = 0; /* Check the strings... */ for ($c = 0; $c < $min_length; ++$c) { $a_del = substr($a, $c, $delimiter_length); $b_del = substr($b, $c, $delimiter_length); if (($a_del == $delimiter) && ($b_del == $delimiter)) { $result = 0; } else if (($a_del == $delimiter) && ($b_del != $delimiter)) { $result = -1; } else if (($a_del != $delimiter) && ($b_del == $delimiter)) { $result = 1; } else { $result = strcasecmp($a{$c}, $b{$c}); } if ($result != 0) { break; } } /* If one string is a prefix of the other... */ if ($result == 0) { if ($a_length < $b_length) { $result = -1; } else if ($a_length > $b_length) { $result = 1; } } return ($result); } /****************************************************************************** ** Returns sorted mailbox lists in several different ways. ** See comment on sqimap_mailbox_parse() for info about the returned array. ******************************************************************************/ function sqimap_mailbox_list($imap_stream) { GLOBAL $boxesnew; if ( !isset( $boxesnew ) ) { GLOBAL $data_dir, $username, $list_special_folders_first, $folder_prefix, $trash_folder, $sent_folder, $draft_folder, $move_to_trash, $move_to_sent, $save_as_draft, $delimiter; $inbox_in_list = $inbox_subscribed = FALSE; require_once('../src/load_prefs.php'); require_once('../functions/array.php'); /** LSUB array **/ $lsub_ary = sqimap_run_command ($imap_stream, "LSUB \"$folder_prefix\" \"*%\"", TRUE, $response, $message); /* Section about removing the last element was removed */ /* We don't return "* OK" anymore from sqimap_read_data */ $sorted_lsub_ary = array(); for ($i=0;$i < count($lsub_ary); $i++) { /* Workaround for EIMS */ /* Doesn't work if the mailbox name is multiple lines */ if (isset($lsub_ary[$i + 1]) && ereg("^(\\* [A-Z]+.*)\\{[0-9]+\\}([ \n\r\t]*)$", $lsub_ary[$i], $regs)) { $i ++; $lsub_ary[$i] = $regs[1] . '"' . addslashes(trim($lsub_ary[$i])) . '"' . $regs[2]; } $temp_mailbox_name = find_mailbox_name($lsub_ary[$i]); $sorted_lsub_ary[] = $temp_mailbox_name; if (strtoupper($temp_mailbox_name) == 'INBOX') { $inbox_subscribed = TRUE; } } $new_ary = array(); for ($i=0; $i < count($sorted_lsub_ary); $i++) { if (!in_array($sorted_lsub_ary[$i], $new_ary)) { $new_ary[] = $sorted_lsub_ary[$i]; } } $sorted_lsub_ary = $new_ary; if (isset($sorted_lsub_ary)) { usort($sorted_lsub_ary, 'user_strcasecmp'); } /** LIST array **/ $sorted_list_ary = array(); for ($i=0; $i < count($sorted_lsub_ary); $i++) { if (substr($sorted_lsub_ary[$i], -1) == $delimiter) { $mbx = substr($sorted_lsub_ary[$i], 0, strlen($sorted_lsub_ary[$i])-1); } else { $mbx = $sorted_lsub_ary[$i]; } $read = sqimap_run_command ($imap_stream, "LIST \"\" \"$mbx\"", TRUE, $response, $message); /* Another workaround for EIMS */ if (isset($read[1]) && ereg("^(\\* [A-Z]+.*)\\{[0-9]+\\}([ \n\r\t]*)$", $read[0], $regs)) { $read[0] = $regs[1] . '"' . addslashes(trim($read[1])) . '"' . $regs[2]; } if (isset($sorted_list_ary[$i])) { $sorted_list_ary[$i] = ''; } if (isset($read[0])) { $sorted_list_ary[$i] = $read[0]; } else { $sorted_list_ary[$i] = ''; } if (isset($sorted_list_ary[$i]) && strtoupper(find_mailbox_name($sorted_list_ary[$i])) == 'INBOX') { $inbox_in_list = TRUE; } } /** * Just in case they're not subscribed to their inbox, * we'll get it for them anyway */ if ($inbox_subscribed == false || $inbox_in_list == false) { $inbox_ary = sqimap_run_command ($imap_stream, "LIST \"\" \"INBOX\"", TRUE, $response, $message); /* Another workaround for EIMS */ if (isset($inbox_ary[1]) && ereg("^(\\* [A-Z]+.*)\\{[0-9]+\\}([ \n\r\t]*)$", $inbox_ary[0], $regs)) { $inbox_ary[0] = $regs[1] . '"' . addslashes(trim($inbox_ary[1])) . '"' . $regs[2]; } $sorted_list_ary[] = $inbox_ary[0]; $sorted_lsub_ary[] = find_mailbox_name($inbox_ary[0]); } $boxesall = sqimap_mailbox_parse ($sorted_list_ary, $sorted_lsub_ary); /** Now, lets sort for special folders **/ $boxesnew = $used = array(); /* Find INBOX */ foreach ( $boxesall as $k => $box ) { if ( strtolower($box['unformatted']) == 'inbox') { $boxesnew[] = $box; $used[$k] = TRUE; } else { $used[$k] = FALSE; } } /* List special folders and their subfolders, if requested. */ if ($list_special_folders_first == TRUE) { foreach ( $boxesall as $k => $box ) { if ( !$used[$k] && isSpecialMailbox( $box['unformatted'] ) ) { $boxesnew[] = $box; $used[$k] = TRUE; } } } /* Rest of the folders */ foreach ( $boxesall as $k => $box ) { if ( !$used[$k] ) { $boxesnew[] = $box; } } } return( $boxesnew ); } /* * Returns a list of all folders, subscribed or not */ function sqimap_mailbox_list_all($imap_stream) { GLOBAL $list_special_folders_first, $folder_prefix, $delimiter; require_once('../functions/array.php'); $ssid = sqimap_session_id(); $lsid = strlen( $ssid ); fputs ($imap_stream, $ssid . " LIST \"$folder_prefix\" *\r\n"); $read_ary = sqimap_read_data ($imap_stream, $ssid, TRUE, $response, $message); $g = 0; $phase = 'inbox'; for ($i = 0; $i < count($read_ary); $i++) { /* Another workaround for EIMS */ if (isset($read_ary[$i + 1]) && ereg("^(\\* [A-Z]+.*)\\{[0-9]+\\}([ \n\r\t]*)$", $read_ary[$i], $regs)) { $i ++; $read_ary[$i] = $regs[1] . '"' . addslashes(trim($read_ary[$i])) . '"' . $regs[2]; } if (substr($read_ary[$i], 0, $lsid) != $ssid ) { /* Store the raw IMAP reply */ $boxes[$g]['raw'] = $read_ary[$i]; /* Count number of delimiters ($delimiter) in folder name */ $mailbox = find_mailbox_name($read_ary[$i]); $dm_count = substr_count($mailbox, $delimiter); if (substr($mailbox, -1) == $delimiter) { /* If name ends in delimiter - decrement count by one */ $dm_count--; } /* Format folder name, but only if it's a INBOX.* or have */ /* a parent. */ $boxesallbyname[$mailbox] = $g; $parentfolder = readMailboxParent($mailbox, $delimiter); if((eregi('^inbox'.quotemeta($delimiter), $mailbox)) || (ereg('^'.$folder_prefix, $mailbox)) || ( isset($boxesallbyname[$parentfolder]) && (strlen($parentfolder) > 0) ) ) { if ($dm_count) { $boxes[$g]['formatted'] = str_repeat('  ', $dm_count); } else { $boxes[$g]['formatted'] = ''; } $boxes[$g]['formatted'] .= readShortMailboxName($mailbox, $delimiter); } else { $boxes[$g]['formatted'] = $mailbox; } $boxes[$g]['unformatted-dm'] = $mailbox; if (substr($mailbox, -1) == $delimiter) { $mailbox = substr($mailbox, 0, strlen($mailbox) - 1); } $boxes[$g]['unformatted'] = $mailbox; $boxes[$g]['unformatted-disp'] = ereg_replace('^' . $folder_prefix, '', $mailbox); $boxes[$g]['id'] = $g; /** Now lets get the flags for this mailbox **/ $read_mlbx = sqimap_run_command ($imap_stream, "LIST \"\" \"$mailbox\"", TRUE, $response, $message); /* Another workaround for EIMS */ if (isset($read_mlbx[1]) && ereg("^(\\* [A-Z]+.*)\\{[0-9]+\\}([ \n\r\t]*)$", $read_mlbx[0], $regs)) { $read_mlbx[0] = $regs[1] . '"' . addslashes(trim($read_mlbx[1])) . '"' . $regs[2]; } $flags = substr($read_mlbx[0], strpos($read_mlbx[0], '(')+1); $flags = substr($flags, 0, strpos($flags, ')')); $flags = str_replace('\\', '', $flags); $flags = trim(strtolower($flags)); if ($flags) { $boxes[$g]['flags'] = explode(' ', $flags); } else { $boxes[$g]['flags'] = array(); } } $g++; } if(is_array($boxes)) { $boxes = ary_sort ($boxes, 'unformatted', 1); } return $boxes; } ?>