X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=src%2Ffolders_create.php;h=2aa59316155a8a3fbde75755307d5f30ba2bbb46;hb=35aaf66653399a1e8e7e243e539dd35e2f3f5a1f;hp=e4809731914f6f33fb3bbd7df4903d937dd15c01;hpb=aff57ea55796bf1f66d7ab9b374d3e7ca5cd11bb;p=squirrelmail.git diff --git a/src/folders_create.php b/src/folders_create.php index e4809731..2aa59316 100644 --- a/src/folders_create.php +++ b/src/folders_create.php @@ -1,46 +1,76 @@ - -\n"; - displayPageHeader($color, "None"); - - $imapConnection = loginToImapServer($username, $key, $imapServerAddress, 0); - $dm = findMailboxDelimeter($imapConnection); - - if (strpos($folder_name, "\"") || strpos($folder_name, ".") || - strpos($folder_name, "/") || strpos($folder_name, "\\") || - strpos($folder_name, "'") || strpos($folder_name, "$dm")) { - plain_error_message(_("Illegal folder name. Please select a different name.
Click here to go back."), $color); - exit; - } - - if ($contain_subs == true) - $folder_name = "$folder_name$dm"; - - if (trim($subfolder) == "[ None ]") { - createFolder($imapConnection, "$folder_name"); - } else { - createFolder($imapConnection, "$subfolder$folder_name"); - } - fputs($imapConnection, "1 logout\n"); - - echo ""; - echo "


"; - echo _("Folder Created!"); - echo "

"; - echo _("The folder has been successfully created."); - echo "
"; - echo _("Click here"); - echo " "; - echo _("to continue."); - echo "
"; -?> - +'._("Click here to go back").'.', $color); + + exit; +} +$folder_name = imap_utf7_encode_local($folder_name); + +if (isset($contain_subs) && $contain_subs ) { + $folder_name = $folder_name . $delimiter; +} + +if ($folder_prefix && (substr($folder_prefix, -1) != $delimiter)) { + $folder_prefix = $folder_prefix . $delimiter; +} +if ($folder_prefix && (substr($subfolder, 0, strlen($folder_prefix)) != $folder_prefix)){ + $subfolder_orig = $subfolder; + $subfolder = $folder_prefix . $subfolder; +} else { + $subfolder_orig = $subfolder; +} + +$imapConnection = sqimap_login($username, $key, $imapServerAddress, $imapPort, 0); + +if (trim($subfolder_orig) == '') { + sqimap_mailbox_create ($imapConnection, $folder_prefix.$folder_name, ''); +} else { + sqimap_mailbox_create ($imapConnection, $subfolder.$delimiter.$folder_name, ''); +} + +sqimap_logout($imapConnection); + +$location = get_location(); +header ("Location: $location/folders.php?success=create"); + +?>