X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=src%2Ffolders.php;h=cc1fc279b90176b81929929231230dcff095284c;hb=0d8a462c52d74cd93af7376ae5bbc994f4699054;hp=e480a6b6e109b95212b51fe2e883beff6ccd1174;hpb=336155db15da67e10eb94b1e1d28d0ccf40e3834;p=squirrelmail.git diff --git a/src/folders.php b/src/folders.php index e480a6b6..cc1fc279 100644 --- a/src/folders.php +++ b/src/folders.php @@ -3,42 +3,44 @@ /** * 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 */ -/* Path for SquirrelMail required files. */ +/** + * Path for SquirrelMail required files. + * @ignore + */ define('SM_PATH','../'); /* SquirrelMail required files. */ require_once(SM_PATH . 'include/validate.php'); -require_once(SM_PATH . 'functions/imap_utf7_decode_local.php'); require_once(SM_PATH . 'functions/imap.php'); -require_once(SM_PATH . 'functions/array.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 */ -$username = $_SESSION['username']; -$key = $_COOKIE['key']; -$delimiter = $_SESSION['delimiter']; -$onetimepad = $_SESSION['onetimepad']; -if (isset($_GET['success'])) { - $success = $_GET['success']; -} +sqgetGlobalVar('username', $username, SQ_SESSION); +sqgetGlobalVar('key', $key, SQ_COOKIE); +sqgetGlobalVar('delimiter', $delimiter, SQ_SESSION); +sqgetGlobalVar('onetimepad', $onetimepad, SQ_SESSION); + +sqgetGlobalVar('success', $success, SQ_GET); /* end of get globals */ -echo '
' . +echo '
' . html_tag( 'table', '', 'center', $color[0], 'width="95%" cellpadding="1" cellspacing="0" border="0"' ) . html_tag( 'tr' ) . html_tag( 'td', '', 'center' ) . '' . _("Folders") . '' . @@ -46,37 +48,49 @@ echo '
' . html_tag( 'tr' ) . html_tag( 'td', '', 'center', $color[4] ); -if ((isset($success) && $success) || - (isset($sent_create) && $sent_create == 'true') || - (isset($trash_create) && $trash_create == 'true')) { - if ($success == "subscribe") { - $td_str = "" . _("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!") . "
"; - } else if ($success == "subscribe-doesnotexist") { - $td_str = "" . - _("Subscription Unsuccessful - Folder does not exist.") . - "
"; +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%" cellpadding="4" cellspacing="0" border="0"' ) . @@ -85,74 +99,91 @@ echo html_tag( 'table', '', 'center', '', 'width="70%" cellpadding="4" cellspaci ) . 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"; +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++; } + +// 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++) { - 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++; + 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; + } } @@ -164,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; @@ -205,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', @@ -238,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"' ) ) . @@ -246,27 +258,27 @@ 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; @@ -275,58 +287,53 @@ echo html_tag( 'td', '', 'center', $color[0], 'width="50%"' ); if(!$no_list_for_subscribe) { $boxes_all = sqimap_mailbox_list_all ($imapConnection); - $box = ""; - $box2 = ""; + $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++; } } if ($box && $box2) { - echo "
\n"; - echo "'; for ($q = 0; $q < count($box); $q++) { - echo " \n"; } - echo "

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

\n"; + echo '

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