X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=src%2Fmove_messages.php;h=d43c3b107d959d40f9ab5024319df6cfd3e113d5;hb=24fc49052db9408811aadf5b2e2740371553ace2;hp=36e966b17b1a132b68a58a68e1818b068b0080d3;hpb=de80e95e61d4a179a0d41ac4512c83818f3243ef;p=squirrelmail.git diff --git a/src/move_messages.php b/src/move_messages.php index 36e966b1..d43c3b10 100644 --- a/src/move_messages.php +++ b/src/move_messages.php @@ -1,91 +1,302 @@ -
- - include("../config/config.php"); - include("../functions/mailbox.php"); - include("../functions/strings.php"); - include("../functions/page_header.php"); - include("../functions/display_messages.php"); - include("../functions/imap.php"); - - function putSelectedMessagesIntoString($msg) { - $j = 0; - $i = 0; - $firstLoop = true; - - // 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)) && ($msg[0])) { - if ($msg[$i]) { - if ($firstLoop != true) - $selectedMessages .= "&"; - else - $firstLoop = false; +rfc822_header = $rfc822_header; + $composeMessage->reply_rfc822_header = ''; + + while ($j < count($msg)) { + if (isset($msg[$i])) { + $id = $msg[$i]; + $body_a = sqimap_run_command($imapConnection, "FETCH $id RFC822",true, $response, $readmessage, $uid_support); + if ($response = 'OK') { + $k = $i + $start_index; + $subject = $msgs[$k]['SUBJECT']; + + array_shift($body_a); + $body = implode('', $body_a); + $body .= "\r\n"; + + $localfilename = GenerateRandomString(32, 'FILE', 7); + $full_localfilename = "$hashed_attachment_dir/$localfilename"; + + $fp = fopen( $full_localfilename, 'wb'); + fwrite ($fp, $body); + fclose($fp); + $composeMessage->initAttachment('message/rfc822',$subject.'.eml', + $full_localfilename); + } + $j++; + } + $i++; + } + $compose_messages[$composesession] = $composeMessage; + sqsession_register($compose_messages,'compose_messages'); + return $composesession; +} + + + +/* get globals */ + +$username = $_SESSION['username']; +$key = $_COOKIE['key']; +$onetimepad = $_SESSION['onetimepad']; +$base_uri = $_SESSION['base_uri']; +$delimiter = $_SESSION['delimiter']; + +if (isset($_GET['mailbox'])) { + $mailbox = $_GET['mailbox']; +} +if (isset($_GET['startMessage'])) { + $startMessage = $_GET['startMessage']; +} +if (isset($_POST['moveButton'])) { + $moveButton = $_POST['moveButton']; +} +if (isset($_POST['msg'])) { + $msg = $_POST['msg']; +} +elseif (isset($_GET['msg'])) { + $msg = $_GET['msg']; +} +if (isset($_POST['expungeButton'])) { + $expungeButton = $_POST['expungeButton']; +} +if (isset($_POST['targetMailbox'])) { + $targetMailbox = $_POST['targetMailbox']; +} +if (isset($_SESSION['lastTargetMailbox'])) { + $lastTargetMailbox = $_SESSION['lastTargetMailbox']; +} +if (isset($_POST['expungeButton'])) { + $expungeButton = $_POST['expungeButton']; +} +if (isset($_POST['undeleteButton'])) { + $undeleteButton = $_POST['undeleteButton']; +} +if (isset($_POST['markRead'])) { + $markRead = $_POST['markRead']; +} +if (isset($_POST['markUnread'])) { + $markUnread = $_POST['markUnread']; +} +if (isset($_POST['attache'])) { + $attache = $_POST['attache']; +} + +/* end of get globals */ + +$imapConnection = sqimap_login($username, $key, $imapServerAddress, $imapPort, 0); +$mbx_response=sqimap_mailbox_select($imapConnection, $mailbox); + +$location = set_url_var($location,'composenew'); +$location = set_url_var($location,'composesession'); +$location = set_url_var($location,'session'); + +/* remember changes to mailbox setting */ +if (!isset($lastTargetMailbox)) { + $lastTargetMailbox = 'INBOX'; +} +if ($targetMailbox != $lastTargetMailbox) { + $lastTargetMailbox = $targetMailbox; + sqsession_register($lastTargetMailbox, 'lastTargetMailbox'); +} + +// expunge-on-demand if user isn't using move_to_trash or auto_expunge +if(isset($expungeButton)) { + $cnt = sqimap_mailbox_expunge($imapConnection, $mailbox, true); + if (($startMessage+$cnt-1) >= $mbx_response['EXISTS']) { + if ($startMessage > $show_num) { + $location = set_url_var($location,'startMessage',$startMessage-$show_num); + } else { + $location = set_url_var($location,'startMessage',1); + } + } + header("Location: $location"); +} elseif(isset($undeleteButton)) { + // undelete messages if user isn't using move_to_trash or auto_expunge + if (is_array($msg) == 1) { + // Removes \Deleted flag from selected messages + $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]) { - deleteMessages($imapConnection, $msg[$i], $msg[$i], $numMessages, $trash_folder, $move_to_trash, $auto_expunge, $mailbox); - $j++; + sqimap_messages_remove_flag ($imapConnection, $msg[$i], $msg[$i], "Deleted", true); + $j++; } $i++; - } - messages_deleted_message($mailbox, $sort, $startMessage); - } else { - echo "