<?php
- /**
- ** move_messages.php
- **
- ** Copyright (c) 1999-2000 The SquirrelMail development team
- ** Licensed under the GNU GPL. For full terms see the file COPYING.
- **
- ** Enables message moving between folders on the IMAP server.
- **/
- session_start();
+/**
+ * move_messages.php
+ *
+ * Copyright (c) 1999-2002 The SquirrelMail Project Team
+ * Licensed under the GNU GPL. For full terms see the file COPYING.
+ *
+ * Enables message moving between folders on the IMAP server.
+ *
+ * $Id$
+ */
- if (!isset($config_php))
- include("../config/config.php");
- if (!isset($strings_php))
- include("../functions/strings.php");
- if (!isset($page_header_php))
- include("../functions/page_header.php");
- if (!isset($display_messages_php))
- include("../functions/display_messages.php");
- if (!isset($imap_php))
- include("../functions/imap.php");
+/*****************************************************************/
+/*** THIS FILE NEEDS TO HAVE ITS FORMATTING FIXED!!! ***/
+/*** PLEASE DO SO AND REMOVE THIS COMMENT SECTION. ***/
+/*** + Base level indent should begin at left margin, as ***/
+/*** the require_once below looks. ***/
+/*** + All identation should consist of four space blocks ***/
+/*** + Tab characters are evil. ***/
+/*** + all comments should use "slash-star ... star-slash" ***/
+/*** style -- no pound characters, no slash-slash style ***/
+/*** + FLOW CONTROL STATEMENTS (if, while, etc) SHOULD ***/
+/*** ALWAYS USE { AND } CHARACTERS!!! ***/
+/*** + Please use ' instead of ", when possible. Note " ***/
+/*** should always be used in _( ) function calls. ***/
+/*** Thank you for your help making the SM code more readable. ***/
+/*****************************************************************/
- include("../src/load_prefs.php");
+require_once('../src/validate.php');
+require_once('../functions/display_messages.php');
+require_once('../functions/imap.php');
function putSelectedMessagesIntoString($msg) {
$j = 0;
sqimap_mailbox_select($imapConnection, $mailbox);
// expunge-on-demand if user isn't using move_to_trash or auto_expunge
- if($expungeButton) {
- sqimap_mailbox_expunge($imapConnection, $mailbox);
+ if(isset($expungeButton)) {
+ sqimap_mailbox_expunge($imapConnection, $mailbox, true);
$location = get_location();
if ($where && $what)
header ("Location: $location/search.php?mailbox=".urlencode($mailbox)."&what=".urlencode($what)."&where=".urlencode($where));
header ("Location: $location/right_main.php?sort=$sort&startMessage=$startMessage&mailbox=". urlencode($mailbox));
}
// undelete messages if user isn't using move_to_trash or auto_expunge
- elseif($undeleteButton) {
+ elseif(isset($undeleteButton)) {
if (is_array($msg) == 1) {
// Removes \Deleted flag from selected messages
$j = 0;
}
}
// If the delete button was pressed, the moveButton variable will not be set.
- elseif (!$moveButton) {
+ elseif (!isset($moveButton)) {
if (is_array($msg) == 1) {
- // Marks the selected messages ad 'Deleted'
+ // Marks the selected messages as 'Deleted'
$j = 0;
$i = 0;
// If they have selected nothing msg is size one still, but will be an infinite
// loop because we never increment j. so check to see if msg[0] is set or not to fix this.
while ($j < count($msg)) {
- if ($msg[$i]) {
- sqimap_messages_delete($imapConnection, $msg[$i], $msg[$i], $mailbox);
+ if (isset($msg[$i])) {
+ if (isset($markRead)) {
+ sqimap_messages_flag($imapConnection, $msg[$i], $msg[$i], "Seen");
+ } else if (isset($markUnread)) {
+ sqimap_messages_remove_flag($imapConnection, $msg[$i], $msg[$i], "Seen");
+ } else {
+ sqimap_messages_delete($imapConnection, $msg[$i], $msg[$i], $mailbox);
+ }
$j++;
}
$i++;
}
if ($auto_expunge) {
- sqimap_mailbox_expunge($imapConnection, $mailbox);
+ sqimap_mailbox_expunge($imapConnection, $mailbox, true);
}
$location = get_location();
- if ($where && $what)
+ if (isset($where) && isset($what))
header ("Location: $location/search.php?mailbox=".urlencode($mailbox)."&what=".urlencode($what)."&where=".urlencode($where));
else
header ("Location: $location/right_main.php?sort=$sort&startMessage=$startMessage&mailbox=". urlencode($mailbox));
// If they have selected nothing msg is size one still, but will be an infinite
// loop because we never increment j. so check to see if msg[0] is set or not to fix this.
while ($j < count($msg)) {
- if ($msg[$i]) {
+ if (isset($msg[$i])) {
/** check if they would like to move it to the trash folder or not */
sqimap_messages_copy($imapConnection, $msg[$i], $msg[$i], $targetMailbox);
sqimap_messages_flag($imapConnection, $msg[$i], $msg[$i], "Deleted");
$i++;
}
if ($auto_expunge == true)
- sqimap_mailbox_expunge($imapConnection, $mailbox);
+ sqimap_mailbox_expunge($imapConnection, $mailbox, true);
$location = get_location();
- if ($where && $what)
+ if (isset($where) && isset($what))
header ("Location: $location/search.php?mailbox=".urlencode($mailbox)."&what=".urlencode($what)."&where=".urlencode($where));
else
header ("Location: $location/right_main.php?sort=$sort&startMessage=$startMessage&mailbox=". urlencode($mailbox));
}
// Log out this session
- sqimap_mailbox_close($imapConnection);
sqimap_logout($imapConnection);
?>