X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=src%2Ffolders_delete.php;h=7cda7013ae9fd11ed9989aa0421b6d8821af99ce;hb=e7a988c11df2354f360c56864500091acc1d21fa;hp=7290dc8f1b571ddc1530de68543767a55790a70d;hpb=abddc974c228ad2762c276ad68778dde7cdfeabf;p=squirrelmail.git diff --git a/src/folders_delete.php b/src/folders_delete.php index 7290dc8f..7cda7013 100644 --- a/src/folders_delete.php +++ b/src/folders_delete.php @@ -1,49 +1,59 @@ -"; - echo "\n"; - displayPageHeader($color, "None"); - - - $imap_stream = sqimap_login($username, $key, $imapServerAddress, 0); + $imap_stream = sqimap_login($username, $key, $imapServerAddress, $imapPort, 0); $boxes = sqimap_mailbox_list ($imap_stream); $dm = sqimap_get_delimiter($imap_stream); + if (substr($mailbox, -1) == $dm) $mailbox_no_dm = substr($mailbox, 0, strlen($mailbox) - 1); else $mailbox_no_dm = $mailbox; - /** lets see if we CAN move folders to the trash.. otherwise, just delete them **/ - for ($i = 0; $i < count($boxes); $i++) { - if ($boxes[$i]["unformatted"] == $trash_folder) { - $can_move_to_trash = true; - for ($j = 0; $j < count($boxes[$i]["flags"]); $j++) { - if (strtolower($boxes[$i]["flags"][$j]) == "noinferiors") - $can_move_to_trash = false; + /** lets see if we CAN move folders to the trash.. otherwise, + ** just delete them **/ + + // Courier IMAP doesn't like subfolders of Trash + if (strtolower($imap_server_type) == "courier") { + $can_move_to_trash = false; + } + + // If it's already a subfolder of trash, we'll have to delete it + else if(eregi("^".$trash_folder.".+", $mailbox)) { + + $can_move_to_trash = false; + + } + + // Otherwise, check if trash folder exits and support sub-folders + else { + for ($i = 0; $i < count($boxes); $i++) { + if ($boxes[$i]["unformatted"] == $trash_folder) { + $can_move_to_trash = !in_array('noinferiors', $boxes[$i]['flags']); } } } - /** First create the top node in the tree **/ for ($i = 0;$i < count($boxes);$i++) { if (($boxes[$i]["unformatted-dm"] == $mailbox) && (strlen($boxes[$i]["unformatted-dm"]) == strlen($mailbox))) { @@ -58,7 +68,6 @@ $j = 0; for ($i = 0;$i < count($boxes);$i++) { if (substr($boxes[$i]["unformatted"], 0, strlen($mailbox_no_dm . $dm)) == ($mailbox_no_dm . $dm)) { -// echo "".$boxes[$i]["unformatted-dm"] . "
"; addChildNodeToTree($boxes[$i]["unformatted"], $boxes[$i]["unformatted-dm"], $foldersTree); } } @@ -75,7 +84,9 @@ /** Log out this session **/ sqimap_logout($imap_stream); - echo ""; + $location = get_location(); + header ("Location: $location/folders.php?success=delete"); + /* echo "


"; echo _("Folder Deleted!"); echo "

"; @@ -84,7 +95,8 @@ echo _("Click here"); echo " "; echo _("to continue."); - echo "
"; + echo ""; echo ""; + */ ?>