X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=src%2Ffolders_rename_do.php;h=ff29eb11f954bb56b5aa2307647a9d54fed76882;hb=d4eaadbe7c054eee5d869ff29ffc8775bfcaffe9;hp=d3191419f82e4cfd1241e12eac820d4389b731f1;hpb=08185f2a7631c3a12cb1ac085fec3be471b56b00;p=squirrelmail.git diff --git a/src/folders_rename_do.php b/src/folders_rename_do.php index d3191419..ff29eb11 100644 --- a/src/folders_rename_do.php +++ b/src/folders_rename_do.php @@ -3,26 +3,54 @@ /** * folders_rename_do.php * - * Copyright (c) 1999-2002 The SquirrelMail Project Team + * Copyright (c) 1999-2005 The SquirrelMail Project Team * Licensed under the GNU GPL. For full terms see the file COPYING. * * Does the actual renaming of files on the IMAP server. * Called from the folders.php * - * $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/global.php'); require_once(SM_PATH . 'functions/imap.php'); +require_once(SM_PATH . 'functions/display_messages.php'); -global $delimiter, $base_uri; +/* globals */ +sqgetGlobalVar('key', $key, SQ_COOKIE); +sqgetGlobalVar('username', $username, SQ_SESSION); +sqgetGlobalVar('delimiter', $delimiter, SQ_SESSION); +sqgetGlobalVar('onetimepad',$onetimepad, SQ_SESSION); +sqgetGlobalVar('orig', $orig, SQ_POST); +sqgetGlobalVar('old_name', $old_name, SQ_POST); +sqgetGlobalVar('new_name', $new_name, SQ_POST); +/* end globals */ $new_name = trim($new_name); +if (substr_count($new_name, '"') || substr_count($new_name, "\\") || + substr_count($new_name, $delimiter) || ($new_name == '')) { + displayPageHeader($color, 'None'); + + plain_error_message(_("Illegal folder name. Please select a different name."). + '
'._("Click here to go back").'.', $color); + + exit; +} + +$orig = imap_utf7_encode_local($orig); +$old_name = imap_utf7_encode_local($old_name); +$new_name = imap_utf7_encode_local($new_name); + if ($old_name <> $new_name) { $imapConnection = sqimap_login($username, $key, $imapServerAddress, $imapPort, 0); @@ -39,7 +67,7 @@ if ($old_name <> $new_name) { $newone = $new_name; } - // Renaming a folder doesn't renames the folder but leaves you unsubscribed + // Renaming a folder doesn't rename the folder but leaves you unsubscribed // at least on Cyrus IMAP servers. if (isset($isfolder)) { $newone = $newone.$delimiter; @@ -47,9 +75,11 @@ if ($old_name <> $new_name) { } sqimap_mailbox_rename( $imapConnection, $orig, $newone ); - // Log out this session + // Log out this session sqimap_logout($imapConnection); } -header ('Location: ' . $base_uri . 'src/folders.php'); -?> + +header ('Location: ' . get_location() . '/folders.php?success=rename'); + +?> \ No newline at end of file