X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=src%2Ffolders.php;h=cc1fc279b90176b81929929231230dcff095284c;hb=0d8a462c52d74cd93af7376ae5bbc994f4699054;hp=4a72114b0a976751db0e8eba008ba674195e1ca0;hpb=50ed645bfb9c43868ea808995235a3d6b9152e1b;p=squirrelmail.git diff --git a/src/folders.php b/src/folders.php index 4a72114b..cc1fc279 100644 --- a/src/folders.php +++ b/src/folders.php @@ -3,141 +3,187 @@ /** * folders.php * - * Copyright (c) 1999-2002 The SquirrelMail Project Team + * Copyright (c) 1999-2004 The SquirrelMail Project Team * Licensed under the GNU GPL. For full terms see the file COPYING. * * Handles all interaction between the user and the other folder * scripts which do most of the work. Also handles the Special * Folders. * - * $Id$ + * @version $Id$ + * @package squirrelmail */ -require_once('../src/validate.php'); -require_once('../functions/imap_utf7_decode_local.php'); -require_once('../functions/imap.php'); -require_once('../functions/array.php'); -require_once('../functions/plugin.php'); -require_once('../functions/html.php'); +/** + * Path for SquirrelMail required files. + * @ignore + */ +define('SM_PATH','../'); -displayPageHeader($color, 'None'); +/* SquirrelMail required files. */ +require_once(SM_PATH . 'include/validate.php'); +require_once(SM_PATH . 'functions/imap.php'); +require_once(SM_PATH . 'functions/plugin.php'); +require_once(SM_PATH . 'functions/html.php'); +require_once(SM_PATH . 'functions/forms.php'); -?> +displayPageHeader($color, 'None'); -
- -
+/* get globals we may need */ - +sqgetGlobalVar('username', $username, SQ_SESSION); +sqgetGlobalVar('key', $key, SQ_COOKIE); +sqgetGlobalVar('delimiter', $delimiter, SQ_SESSION); +sqgetGlobalVar('onetimepad', $onetimepad, SQ_SESSION); - - \n"; +echo "\n"; +echo "\n"; echo html_tag( 'tr', html_tag( 'td', ' ', 'left', $color[4] ) ) ."\n"; /** count special folders **/ + +// FIX ME, why not check if the folders are defined IMHO move_to_sent, move_to_trash has nothing todo with it $count_special_folders = 0; $num_max = 1; if (strtolower($imap_server_type) == "courier" || $move_to_trash) { - $num_max++; + $num_max++; } if ($move_to_sent) { - $num_max++; + $num_max++; } if ($save_as_draft) { - $num_max++; + $num_max++; } -for ($p = 0; $p < count($boxes) && $count_special_folders < $num_max; $p++) { - if (strtolower($boxes[$p]['unformatted']) == 'inbox') - $count_special_folders++; - else if (strtolower($imap_server_type) == 'courier' && - strtolower($boxes[$p]['unformatted']) == 'inbox.trash') - $count_special_folders++; - else if ($boxes[$p]['unformatted'] == $trash_folder && $trash_folder) - $count_special_folders++; - else if ($boxes[$p]['unformatted'] == $sent_folder && $sent_folder) - $count_special_folders++; - else if ($boxes[$p]['unformatted'] == $draft_folder && $draft_folder) - $count_special_folders++; + +// What if move_to_sent = false and $sent_folder is set? Should it still be skipped? + +for ($p = 0, $cnt = count($boxes); $p < $cnt && $count_special_folders < $num_max; $p++) { + switch ($boxes[$p]['unformatted']) { + case (strtoupper($boxes[$p]['unformatted']) == 'INBOX'): + ++$count_special_folders; + $skip_folders[] = $boxes[$p]['unformatted']; + break; + // FIX ME inbox.trash should be set in conf.pl + case 'inbox.trash': + if (strtolower($imap_server_type) == 'courier') { + ++$count_special_folders; + } + break; + case $trash_folder: + ++$count_special_folders; + $skip_folders[] = $trash_folder; + break; + case $sent_folder: + ++$count_special_folders; + $skip_folders[] = $sent_folder; + break; + case $draft_folder: + ++$count_special_folders; + $skip_folders[] = $draft_folder; + break; + default: break; + } } @@ -149,32 +195,23 @@ echo html_tag( 'tr', html_tag( 'td', '', 'center', $color[0] ); if ($count_special_folders < count($boxes)) { - echo "\n" - . "\n". - "\n". + '\n". - "\n"; + "\" />\n". + "\n"; } else { - echo _("No folders found") . "

"; + echo _("No folders found") . '

'; } $boxes_sub = $boxes; @@ -190,31 +227,21 @@ echo html_tag( 'tr', html_tag( 'td', '', 'center', $color[0] ); if ($count_special_folders < count($boxes)) { - echo "\n" - . "\n"; - echo "\n"; - echo "\n"; + echo addForm('folders_delete.php') + . "\n" + . '\n" + . "\n"; } else { - echo _("No folders found") . "

"; + echo _("No folders found") . "

"; } echo html_tag( 'tr', @@ -223,7 +250,7 @@ echo html_tag( 'tr', /** UNSUBSCRIBE FOLDERS **/ -echo html_tag( 'table', '', 'center', '', 'width="70%" cols="2" cellpadding="4" cellspacing="0" border="0"' ) . +echo html_tag( 'table', '', 'center', '', 'width="70%" cellpadding="4" cellspacing="0" border="0"' ) . html_tag( 'tr', html_tag( 'td', '' . _("Unsubscribe") . '/' . _("Subscribe") . '', 'center', $color[9], 'colspan="2"' ) ) . @@ -231,81 +258,82 @@ echo html_tag( 'table', '', 'center', '', 'width="70%" cols="2" cellpadding="4" html_tag( 'td', '', 'center', $color[0], 'width="50%"' ); if ($count_special_folders < count($boxes)) { - echo "\n"; - echo "\n"; for ($i = 0; $i < count($boxes); $i++) { $use_folder = true; if ((strtolower($boxes[$i]["unformatted"]) != "inbox") && ($boxes[$i]["unformatted"] != $trash_folder) && ($boxes[$i]["unformatted"] != $sent_folder) && ($boxes[$i]["unformatted"] != $draft_folder)) { - $box = $boxes[$i]["unformatted-dm"]; + $box = htmlspecialchars($boxes[$i]["unformatted-dm"]); $box2 = str_replace(' ', ' ', - imap_utf7_decode_local($boxes[$i]["unformatted-disp"])); - echo " \n"; } } - echo "

\n"; - echo "\n"; - echo "\n"; + echo "

\n" + . '\n" + . "\n"; } else { - echo _("No folders were found to unsubscribe from!") . ""; + echo _("No folders were found to unsubscribe from!") . ''; } $boxes_sub = $boxes; /** SUBSCRIBE TO FOLDERS **/ echo html_tag( 'td', '', 'center', $color[0], 'width="50%"' ); -$imap_stream = sqimap_login ($username, $key, $imapServerAddress, $imapPort, 1); -$boxes_all = sqimap_mailbox_list_all ($imap_stream); +if(!$no_list_for_subscribe) { + $boxes_all = sqimap_mailbox_list_all ($imapConnection); -$box = ""; -$box2 = ""; -for ($i = 0, $q = 0; $i < count($boxes_all); $i++) { + $box = ''; + $box2 = ''; + for ($i = 0, $q = 0; $i < count($boxes_all); $i++) { $use_folder = true; for ($p = 0; $p < count ($boxes); $p++) { - if ($boxes_all[$i]["unformatted"] == $boxes[$p]["unformatted"]) { + if ($boxes_all[$i]['unformatted'] == $boxes[$p]['unformatted']) { $use_folder = false; continue; - } else if ($boxes_all[$i]["unformatted-dm"] == $folder_prefix) { + } else if ($boxes_all[$i]['unformatted-dm'] == $folder_prefix) { $use_folder = false; } } if ($use_folder == true) { - $box[$q] = $boxes_all[$i]["unformatted-dm"]; - $box2[$q] = imap_utf7_decode_local($boxes_all[$i]["unformatted-disp"]); + $box[$q] = htmlspecialchars($boxes_all[$i]['unformatted-dm']); + $box2[$q] = htmlspecialchars(imap_utf7_decode_local($boxes_all[$i]['unformatted-disp'])); $q++; } -} -sqimap_logout($imap_stream); - -if ($box && $box2) { - echo "\n"; - echo "'; for ($q = 0; $q < count($box); $q++) { - echo " \n"; } - echo "

"; - echo "\n"; - echo "
+sqgetGlobalVar('success', $success, SQ_GET); -" . _("Subscribed successfully!") . "
"; - } else if ($success == "unsubscribe") { - $td_str = "" . _("Unsubscribed successfully!") . "
"; - } else if ($success == "delete") { - $td_str = "" . _("Deleted folder successfully!") . "
"; - } else if ($success == "create") { - $td_str = "" . _("Created folder successfully!") . "
"; - } else if ($success == "rename") { - $td_str = "" . _("Renamed successfully!") . "
"; +echo '
' . + html_tag( 'table', '', 'center', $color[0], 'width="95%" cellpadding="1" cellspacing="0" border="0"' ) . + html_tag( 'tr' ) . + html_tag( 'td', '', 'center' ) . '' . _("Folders") . '' . + html_tag( 'table', '', 'center', '', 'width="100%" cellpadding="5" cellspacing="0" border="0"' ) . + html_tag( 'tr' ) . + html_tag( 'td', '', 'center', $color[4] ); + +if ( isset($success) && $success ) { + + $td_str = ''; + + switch ($success) + { + case 'subscribe': + $td_str .= _("Subscribed successfully!"); + break; + case 'unsubscribe': + $td_str .= _("Unsubscribed successfully!"); + break; + case 'delete': + $td_str .= _("Deleted folder successfully!"); + break; + case 'create': + $td_str .= _("Created folder successfully!"); + break; + case 'rename': + $td_str .= _("Renamed successfully!"); + break; + case 'subscribe-doesnotexist': + $td_str .= _("Subscription Unsuccessful - Folder does not exist."); + break; } + $td_str .= '
'; + + echo html_tag( 'table', html_tag( 'tr', html_tag( 'td', $td_str . - "" . _("refresh folder list") . "" , + '' . + _("refresh folder list") . '' , 'center' ) ) , - 'center', '', 'width="100%" cellpadding="4" cellspacing="0" border="0"' ) . "
\n"; -} else { - echo "
"; + 'center', '', 'width="100%" cellpadding="4" cellspacing="0" border="0"' ); } + +echo "\n
"; + $imapConnection = sqimap_login ($username, $key, $imapServerAddress, $imapPort, 0); -$boxes = sqimap_mailbox_list($imapConnection); +$boxes = sqimap_mailbox_list($imapConnection,true); /** CREATING FOLDERS **/ -echo html_tag( 'table', '', 'center', '', 'width="70%" cols="1" cellpadding="4" cellspacing="0" border="0"' ) . +echo html_tag( 'table', '', 'center', '', 'width="70%" cellpadding="4" cellspacing="0" border="0"' ) . html_tag( 'tr', html_tag( 'td', '' . _("Create Folder") . '', 'center', $color[9] ) ) . html_tag( 'tr' ) . html_tag( 'td', '', 'center', $color[0] ) . + addForm('folders_create.php', 'POST', 'cf'). + addInput('folder_name', '', 25). + "
\n". _("as a subfolder of"). '
'. + "
\n". - _("as a subfolder of"). - "
". - "\n"; +echo "
\n"; if ($show_contain_subfolders_option) { - echo "
 "; - echo _("Let this folder contain subfolders"); - echo "
"; + echo '
'. + addCheckBox('contain_subs', FALSE, '1') .'  ' + . _("Let this folder contain subfolders") + . '
'; } -echo "\n"; -echo "

\n"; + echo '

' + . '\n" + . "

\n"; + } else { + echo _("No folders were found to subscribe to!") . ''; + } } else { - echo _("No folders were found to subscribe to!") . ""; + /* don't perform the list action -- this is much faster */ + echo addForm('folders_subscribe.php?method=sub') + . _("Subscribe to:") . '
' + . '' + . '\n" + . "
\n"; } -do_hook("folders_bottom"); +do_hook('folders_bottom'); ?> - - - - -