A terrible pile of things done to the code. Did a little bit of SM_PATH
[squirrelmail.git] / src / move_messages.php
index 74320bf3874683c69a2ac4137c968ba94d2201b6..9829f0c4e8ededc4648c8b51ce672e132f88a94c 100644 (file)
  * $Id$
  */
 
-require_once('../src/validate.php');
-require_once('../functions/display_messages.php');
-require_once('../functions/imap.php');
+/* Path for SquirrelMail required files. */
+define('SM_PATH','../');
+
+/* SquirrelMail required files. */
+require_once(SM_PATH . 'include/validate.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;
 
 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;
-
+            if ($firstLoop != true) {
+                $selectedMessages .= "&amp;";
+            } else {
+                $firstLoop = false;
+            }
             $selectedMessages .= "selMsg[$j]=$msg[$i]";
-
             $j++;
         }
         $i++;
     }
 }
 
+function attachSelectedMessages($msg, $imapConnection) {
+    global $mailbox, $username, $attachment_dir, $attachments, $identity, 
+           $data_dir, $composesession, $lastTargetMailbox, $uid_support,
+          $msgs, $startMessage, $show_num, $thread_sort_messages,
+          $allow_server_sort;
+
+    if (!isset($attachments)) {
+           $attachments = array();
+           session_register('attachments');
+    }
+
+    if (!isset($composesession) ) {
+           $composesession = 1;
+           session_register('composesession');
+    } else {
+           $composesession++;
+    }
+
+    $hashed_attachment_dir = getHashedDir($username, $attachment_dir, $composesession);
+
+    $rem_attachments = array();
+    foreach ($attachments as $info) {
+       if ($info['session'] == $composesession) {
+           $attached_file = "$hashed_attachment_dir/$info[localfilename]";
+           if (file_exists($attached_file)) {
+                   unlink($attached_file);
+           }
+       } else {
+           $rem_attachments[] = $info;
+       }
+    }
+
+    $attachments = $rem_attachments;
+
+    if ($thread_sort_messages || $allow_server_sort) {
+       $start_index=0;
+    } else {
+       $start_index = ($startMessage-1) * $show_num;
+    }
+
+    $i = 0;
+    $j = 0;
+    $hashed_attachment_dir = getHashedDir($username, $attachment_dir);
+    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);
+               $newAttachment = array();
+               $newAttachment['localfilename'] = $localfilename;
+               $newAttachment['type'] = "message/rfc822";
+               $newAttachment['remotefilename'] = $subject.'.eml';
+               $newAttachment['session'] = $composesession;
+               $attachments[] = $newAttachment;
+               flush();
+           }
+           $j++;
+       }
+       $i++;   
+    }
+    setPref($data_dir, $username, 'attachments', serialize($attachments));
+    return $composesession;
+}
+
 $imapConnection = sqimap_login($username, $key, $imapServerAddress, $imapPort, 0);
 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;
+    session_register('lastTargetMailbox');
+}
+
 // expunge-on-demand if user isn't using move_to_trash or auto_expunge
 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));
-    } else {
-        header ("Location: $location/right_main.php?sort=$sort&startMessage=$startMessage&mailbox=". urlencode($mailbox));
-    }
-
+    header("Location: $location");
 } elseif(isset($undeleteButton)) {
     // undelete messages if user isn't using move_to_trash or auto_expunge
 
@@ -58,22 +148,16 @@ if(isset($expungeButton)) {
         // 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]) {
-            sqimap_messages_remove_flag ($imapConnection, $msg[$i], $msg[$i], "Deleted");
-            $j++;
+                sqimap_messages_remove_flag ($imapConnection, $msg[$i], $msg[$i], "Deleted", true);
+                $j++;
             }
             $i++;
         }
-        $location = get_location();
-
-        if ($where && $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));
+       header ("Location: $location"); 
     } else {
         displayPageHeader($color, $mailbox);
         error_message(_("No messages were selected."), $mailbox, $sort, $startMessage, $color);
@@ -84,16 +168,17 @@ if(isset($expungeButton)) {
         // 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 (isset($msg[$i])) {
                 if (isset($markRead)) {
-                    sqimap_messages_flag($imapConnection, $msg[$i], $msg[$i], "Seen");
+                    sqimap_messages_flag($imapConnection, $msg[$i], $msg[$i], "Seen", true);
                 } else if (isset($markUnread)) {
-                    sqimap_messages_remove_flag($imapConnection, $msg[$i], $msg[$i], "Seen");
-                } else {
+                    sqimap_messages_remove_flag($imapConnection, $msg[$i], $msg[$i], "Seen", true);
+                } else if (isset($attache)) {
+                   break;
+                } else  {
                     sqimap_messages_delete($imapConnection, $msg[$i], $msg[$i], $mailbox);
                 }
                 $j++;
@@ -103,12 +188,18 @@ if(isset($expungeButton)) {
         if ($auto_expunge) {
             sqimap_mailbox_expunge($imapConnection, $mailbox, true);
         }
-        $location = get_location();
-        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 (isset($attache)) {
+           $composesession = attachSelectedMessages($msg, $imapConnection);
+           if ($compose_new_win) {
+               header ("Location: $location&composenew=1&session=$composesession");
+           } else {
+               $location = str_replace('search.php','compose.php',$location);
+               $location = str_replace('right_main.php','compose.php',$location);
+               header ("Location: $location&session=$composesession");
+           }
+       } else {                
+            header ("Location: $location");
+        } 
     } else {
         displayPageHeader($color, $mailbox);
         error_message(_("No messages were selected."), $mailbox, $sort, $startMessage, $color);
@@ -118,32 +209,26 @@ if(isset($expungeButton)) {
     if (is_array($msg) == 1) {
         $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 (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");
+                sqimap_messages_flag($imapConnection, $msg[$i], $msg[$i], "Deleted", true);
                 $j++;
             }
             $i++;
         }
-        if ($auto_expunge == true)
+        if ($auto_expunge) {
             sqimap_mailbox_expunge($imapConnection, $mailbox, true);
-
-        $location = get_location();
-        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));
+       }
+       header ("Location: $location"); 
     } else {
         displayPageHeader($color, $mailbox);
         error_message(_("No messages were selected."), $mailbox, $sort, $startMessage, $color);
     }
 }
-
 // Log out this session
 sqimap_logout($imapConnection);