X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=src%2Fmove_messages.php;h=bc1cd4eb020e4593185e7a3ddd623a7e91e7def6;hb=c3ccfa1912b4ca47279d259bb587ceb293ce5d83;hp=943538656cc62e5d0fddac3b2db9e2c88a763d9e;hpb=76911253eb850bacde3d86c8cb7b4af072e67ebe;p=squirrelmail.git diff --git a/src/move_messages.php b/src/move_messages.php index 94353865..bc1cd4eb 100644 --- a/src/move_messages.php +++ b/src/move_messages.php @@ -16,56 +16,34 @@ 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/display_messages.php'); require_once(SM_PATH . 'functions/imap.php'); require_once(SM_PATH . 'functions/html.php'); global $compose_new_win; -if (isset($_SESSION['composesession'])) { - $composesession = $_SESSION['composesession']; -} else { - $composesession = 0; -} -/* obsolete ?? */ -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; - } - $selectedMessages .= "selMsg[$j]=$msg[$i]"; - $j++; - } - $i++; - } +if ( !sqgetGlobalVar('composesession', $composesession, SQ_SESSION) ) { + $composesession = 0; } function attachSelectedMessages($msg, $imapConnection) { - global $username, $attachment_dir, + global $username, $attachment_dir, $startMessage, $data_dir, $composesession, $uid_support, - $msgs, $thread_sort_messages, $allow_server_sort, $show_num, - $compose_messages; + $msgs, $thread_sort_messages, $allow_server_sort, $show_num, + $compose_messages; if (!isset($compose_messages)) { - $compose_messages = array(); + $compose_messages = array(); sqsession_register($compose_messages,'compose_messages'); } if (!$composesession) { - $composesession = 1; - sqsession_register($composesession,'composesession'); + $composesession = 1; + sqsession_register($composesession,'composesession'); } else { - $composesession++; - sqsession_register($composesession,'composesession'); + $composesession++; + sqsession_register($composesession,'composesession'); } $hashed_attachment_dir = getHashedDir($username, $attachment_dir, $composesession); @@ -87,28 +65,28 @@ function attachSelectedMessages($msg, $imapConnection) { 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++; + $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'); @@ -119,64 +97,30 @@ function attachSelectedMessages($msg, $imapConnection) { /* get globals */ +sqgetGlobalVar('key', $key, SQ_COOKIE); +sqgetGlobalVar('username', $username, SQ_SESSION); +sqgetGlobalVar('onetimepad',$onetimepad, SQ_SESSION); +sqgetGlobalVar('delimiter', $delimiter, SQ_SESSION); +sqgetGlobalVar('base_uri', $base_uri, SQ_SESSION); + +sqgetGlobalVar('mailbox', $mailbox); +sqgetGlobalVar('startMessage', $startMessage); +sqgetGlobalVar('msg', $msg); + +sqgetGlobalVar('msgs', $msgs, SQ_SESSION); +sqgetGlobalVar('composesession', $composesession, SQ_SESSION); +sqgetGlobalVar('lastTargetMailbox', $lastTargetMailbox, SQ_SESSION); + +sqgetGlobalVar('moveButton', $moveButton, SQ_POST); +sqgetGlobalVar('expungeButton', $expungeButton, SQ_POST); +sqgetGlobalVar('targetMailbox', $targetMailbox, SQ_POST); +sqgetGlobalVar('expungeButton', $expungeButton, SQ_POST); +sqgetGlobalVar('undeleteButton', $undeleteButton, SQ_POST); +sqgetGlobalVar('markRead', $markRead, SQ_POST); +sqgetGlobalVar('markUnread', $markUnread, SQ_POST); +sqgetGlobalVar('attache', $attache, SQ_POST); +sqgetGlobalVar('location', $location, SQ_POST); -$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($_SESSION['msgs'])) { - $msgs = $_SESSION['msgs']; -} - -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']; -} - -if (isset($_POST['location'])) { - $location = $_POST['location']; -} - -if (isset($_SESSION['composesession'])) { - $composesession = $_SESSION['composesession']; -} /* end of get globals */ $imapConnection = sqimap_login($username, $key, $imapServerAddress, $imapPort, 0); @@ -195,116 +139,95 @@ if ($targetMailbox != $lastTargetMailbox) { sqsession_register($lastTargetMailbox, 'lastTargetMailbox'); } $exception = false; + +do_hook('move_before_move'); + + +/* + Move msg list sorting up here, as it is used several times, + makes it more efficient to do it in one place for the code +*/ +$id = array(); +if (isset($msg) && is_array($msg)) { + foreach( $msg as $key=>$uid ) { + // using foreach removes the risk of infinite loops that was there // + $id[] = $uid; + } +} + // 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,false); - } else { - $location = set_url_var($location,'startMessage',1,false); - } + $location = set_url_var($location,'startMessage',$startMessage-$show_num,false); + } else { + $location = set_url_var($location,'startMessage',1,false); + } } } 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 = $i = 0; - $id = array(); - // 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]) { - $id[] = $msg[$i]; - $j++; - } - $i++; - } - if (count($id)) { - sqimap_toggle_flag($imapConnection, $id, '\\Deleted',false,true); - } + // Removes \Deleted flag from selected messages + if (count($id)) { + sqimap_toggle_flag($imapConnection, $id, '\\Deleted',false,true); } else { - $exception = true; + $exception = true; } } elseif (!isset($moveButton)) { - // If the delete button was pressed, the moveButton variable will not be set. - if (is_array($msg)) { - // Marks the selected messages as 'Deleted' - $j = $i = $cnt = 0; - $id = array(); - // 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 (isset($msg[$i])) { - $id[] = $msg[$i]; - $j++; + if (count($id)) { + $cnt = count($id); + if (!isset($attache)) { + if (isset($markRead)) { + sqimap_toggle_flag($imapConnection, $id, '\\Seen',true,true); + } else if (isset($markUnread)) { + sqimap_toggle_flag($imapConnection, $id, '\\Seen',false,true); + } else { + sqimap_msgs_list_delete($imapConnection, $mailbox, $id); + if ($auto_expunge) { + $cnt = sqimap_mailbox_expunge($imapConnection, $mailbox, true); + } } - $i++; - } - if (count($id) && !isset($attache)) { - if (isset($markRead)) { - sqimap_toggle_flag($imapConnection, $id, '\\Seen',true,true); - } else if (isset($markUnread)) { - sqimap_toggle_flag($imapConnection, $id, '\\Seen',false,true); - } else { - sqimap_msgs_list_delete($imapConnection, $mailbox, $id); - if ($auto_expunge) { - $cnt = sqimap_mailbox_expunge($imapConnection, $mailbox, true); - } - } } if (isset($attache)) { - $composesession = attachSelectedMessages($msg, $imapConnection); - $location = set_url_var($location, 'session', $composesession, false); - if ($compose_new_win) { - $location = set_url_var($location, 'composenew', 1, false); - } else { - $location = str_replace('search.php','compose.php',$location); - $location = str_replace('right_main.php','compose.php',$location); - } - } else { - if (($startMessage+$cnt-1) >= $mbx_response['EXISTS']) { - if ($startMessage > $show_num) { - $location = set_url_var($location,'startMessage',$startMessage-$show_num, false); - } else { - $location = set_url_var($location,'startMessage',1, false); - } - } - } + $composesession = attachSelectedMessages($id, $imapConnection); + $location = set_url_var($location, 'session', $composesession, false); + if ($compose_new_win) { + $location = set_url_var($location, 'composenew', 1, false); + } else { + $location = str_replace('search.php','compose.php',$location); + $location = str_replace('right_main.php','compose.php',$location); + } + } else { + if (($startMessage+$cnt-1) >= $mbx_response['EXISTS']) { + if ($startMessage > $show_num) { + $location = set_url_var($location,'startMessage',$startMessage-$show_num, false); + } else { + $location = set_url_var($location,'startMessage',1, false); + } + } + } } else { - $exception = true; + $exception = true; } } else { // Move messages - // lets check to see if they selected any messages - if (is_array($msg)) { - $j = $i = 0; - $id = array(); - // 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. - $cnt = count($msg); - while ($j < $cnt) { - if (isset($msg[$i])) { - $id[] = $msg[$i]; - $j++; - } - $i++; - } - sqimap_msgs_list_copy($imapConnection,$id,$targetMailbox); + + if (count($id)) { + sqimap_msgs_list_copy($imapConnection,$id,$targetMailbox); if ($auto_expunge) { $cnt = sqimap_mailbox_expunge($imapConnection, $mailbox, true); - } else { - $cnt = 0; - } - - if (($startMessage+$cnt-1) >= $mbx_response['EXISTS']) { - if ($startMessage > $show_num) { - $location = set_url_var($location,'startMessage',$startMessage-$show_num, false); - } else { - $location = set_url_var($location,'startMessage',1, false); - } - } + } else { + $cnt = 0; + } + + if (($startMessage+$cnt-1) >= $mbx_response['EXISTS']) { + if ($startMessage > $show_num) { + $location = set_url_var($location,'startMessage',$startMessage-$show_num, false); + } else { + $location = set_url_var($location,'startMessage',1, false); + } + } } else { - $exception = true; + $exception = true; } } // Log out this session