}
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;
+ global $username, $attachment_dir,
+ $data_dir, $composesession, $uid_support,
+ $msgs, $thread_sort_messages, $allow_server_sort, $show_num,
+ $compose_messages;
- if (!isset($attachments)) {
- $attachments = array();
- session_register('attachments');
+
+ if (!isset($compose_messages)) {
+ $compose_messages = array();
+ sqsession_register($compose_messages,'compose_messages');
}
if (!isset($composesession) ) {
$composesession = 1;
- session_register('composesession');
+ sqsession_register($composesession,'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 {
$i = 0;
$j = 0;
$hashed_attachment_dir = getHashedDir($username, $attachment_dir);
+
+ $composeMessage = new Message();
+ $rfc822_header = new Rfc822Header();
+ $composeMessage->rfc822_header = $rfc822_header;
+ $composeMessage->reply_rfc822_header = '';
+
while ($j < count($msg)) {
if (isset($msg[$i])) {
$id = $msg[$i];
$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();
+ $composeMessage->initAttachment('message/rfc822',$subject.'.eml',
+ $full_localfilename);
}
$j++;
}
$i++;
}
- setPref($data_dir, $username, 'attachments', serialize($attachments));
+ $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);
}
if ($targetMailbox != $lastTargetMailbox) {
$lastTargetMailbox = $targetMailbox;
- session_register('lastTargetMailbox');
+ sqsession_register($lastTargetMailbox, 'lastTargetMailbox');
}
// expunge-on-demand if user isn't using move_to_trash or auto_expunge
$location = set_url_var($location,'startMessage',1);
}
}
- echo $location . ' ' .$show_num. ' '.$cnt;
header ("Location: $location");
}
} else {