Update Changelog and add one more macosx workaround
[squirrelmail.git] / src / read_body.php
CommitLineData
59177427 1<?php
895905c0 2
35586184 3/**
4 * read_body.php
5 *
15e6162e 6 * Copyright (c) 1999-2002 The SquirrelMail Project Team
35586184 7 * Licensed under the GNU GPL. For full terms see the file COPYING.
8 *
9 * This file is used for reading the msgs array and displaying
10 * the resulting emails in the right frame.
11 *
12 * $Id$
a07cd1a4 13 */
35586184 14
15require_once('../src/validate.php');
16require_once('../functions/imap.php');
17require_once('../functions/mime.php');
18require_once('../functions/date.php');
19require_once('../functions/url_parser.php');
57257333 20require_once('../functions/smtp.php');
5be9f195 21
a07cd1a4 22/**
1fca12b5 23 * Given an IMAP message id number, this will look it up in the cached
24 * and sorted msgs array and return the index. Used for finding the next
25 * and previous messages.
26 *
27 * @return the index of the next valid message from the array
28 */
a07cd1a4 29function findNextMessage() {
92592f0e 30 global $msort, $currentArrayIndex, $msgs, $sort,
cf710efe 31 $thread_sort_messages, $allow_server_sort,
60a3e687 32 $server_sort_array;
2728fa19 33 if (!is_array($server_sort_array)) {
34 $thread_sort_messages = 0;
794d59c0 35 $allow_server_sort = FALSE;
2728fa19 36 }
a07cd1a4 37 $result = -1;
794d59c0 38 if ($thread_sort_messages == 1 || $allow_server_sort == TRUE) {
60a3e687 39 reset($server_sort_array);
40 while(list($key, $value) = each ($server_sort_array)) {
41 if ($currentArrayIndex == $value) {
1fca12b5 42 if ($key == (count($server_sort_array) - 1)) {
60a3e687 43 $result = -1;
44 break;
45 }
1fca12b5 46 $result = $server_sort_array[$key + 1];
60a3e687 47 break;
789b4d79 48 }
60a3e687 49 }
1fca12b5 50 }
794d59c0 51 elseif ($sort == 6 && $allow_server_sort != TRUE &&
cf710efe 52 $thread_sort_messages != 1) {
a07cd1a4 53 if ($currentArrayIndex != 1) {
54 $result = $currentArrayIndex - 1;
55 }
1fca12b5 56 }
794d59c0 57 elseif ($allow_server_sort != TRUE && $thread_sort_messages != 1 ) {
75ef78d8 58 if (!is_array($msort)) {
59 return -1;
60 }
a07cd1a4 61 for (reset($msort); ($key = key($msort)), (isset($key)); next($msort)) {
62 if ($currentArrayIndex == $msgs[$key]['ID']) {
63 next($msort);
64 $key = key($msort);
1fca12b5 65 if (isset($key)){
a07cd1a4 66 $result = $msgs[$key]['ID'];
67 break;
1fca12b5 68 }
10f0ce72 69 }
70 }
10f0ce72 71 }
a07cd1a4 72 return ($result);
73}
74
1fca12b5 75/**
76 * Removes just one address from the list of addresses.
77 *
78 * @param &$addr_list a by-ref array of addresses
79 * @param $addr an address to remove
80 * @return void, since it operates on a by-ref param
81 */
a07cd1a4 82function RemoveAddress(&$addr_list, $addr) {
83 if ($addr != '') {
84 foreach (array_keys($addr_list, $addr) as $key_to_delete) {
85 unset($addr_list[$key_to_delete]);
10f0ce72 86 }
a07cd1a4 87 }
88}
89
90/** returns the index of the previous message from the array. */
91function findPreviousMessage() {
57257333 92 global $msort, $currentArrayIndex, $sort, $msgs, $imapConnection,
cf710efe 93 $mailbox, $data_dir, $username, $thread_sort_messages,
60a3e687 94 $allow_server_sort, $server_sort_array;
a07cd1a4 95 $result = -1;
2728fa19 96 if (!is_array($server_sort_array)) {
97 $thread_sort_messages = 0;
794d59c0 98 $allow_server_sort = FALSE;
2728fa19 99 }
794d59c0 100 if ($thread_sort_messages == 1 || $allow_server_sort == TRUE) {
60a3e687 101 reset($server_sort_array);
102 while(list($key, $value) = each ($server_sort_array)) {
103 if ($currentArrayIndex == $value) {
104 if ($key == 0) {
105 $result = -1;
106 break;
107 }
108 $result = $server_sort_array[$key -1];
109 break;
789b4d79 110 }
60a3e687 111 }
789b4d79 112 }
794d59c0 113 elseif ($sort == 6 && $allow_server_sort != TRUE &&
cf710efe 114 $thread_sort_messages != 1) {
a07cd1a4 115 $numMessages = sqimap_get_num_messages($imapConnection, $mailbox);
116 if ($currentArrayIndex != $numMessages) {
117 $result = $currentArrayIndex + 1;
118 }
60a3e687 119 }
794d59c0 120 elseif ($thread_sort_messages != 1 && $allow_server_sort != TRUE) {
1fca12b5 121 if (!is_array($msort)) {
75ef78d8 122 return -1;
1fca12b5 123 }
a07cd1a4 124 for (reset($msort); ($key = key($msort)), (isset($key)); next($msort)) {
125 if ($currentArrayIndex == $msgs[$key]['ID']) {
126 prev($msort);
127 $key = key($msort);
128 if (isset($key)) {
129 $result = $msgs[$key]['ID'];
130 break;
10f0ce72 131 }
132 }
10f0ce72 133 }
a07cd1a4 134 }
135 return ($result);
136}
10f0ce72 137
a07cd1a4 138/**
1fca12b5 139 * Displays a link to a page where the message is displayed more
140 * "printer friendly".
141 */
a07cd1a4 142function printer_friendly_link() {
57257333 143 global $passed_id, $mailbox, $ent_num, $color,
144 $pf_subtle_link,
145 $javascript_on;
a07cd1a4 146
147 if (strlen(trim($mailbox)) < 1) {
148 $mailbox = 'INBOX';
149 }
10f0ce72 150
57257333 151 $params = '?passed_ent_id=' . $ent_num .
1fca12b5 152 '&mailbox=' . urlencode($mailbox) .
153 '&passed_id=' . $passed_id;
10f0ce72 154
a07cd1a4 155 $print_text = _("View Printable Version");
10f0ce72 156
a07cd1a4 157 if (!$pf_subtle_link) {
158 /* The link is large, on the bottom of the header panel. */
1fca12b5 159 $result = '<tr bgcolor="' . $color[0] . '">' .
160 '<td class="medText" align="right" valign="top">' .
161 '&nbsp;' .
162 '</td><td class="medText" valign="top" colspan="2">'."\n";
a07cd1a4 163 } else {
164 /* The link is subtle, below "view full header". */
165 $result = "<BR>\n";
166 }
10f0ce72 167
a07cd1a4 168 /* Output the link. */
169 if ($javascript_on) {
3d570ba0 170 $result .= '<script language="javascript" type="text/javascript">' . "\n" .
a07cd1a4 171 '<!--' . "\n" .
172 " function printFormat() {\n" .
173 ' window.open("../src/printer_friendly_main.php' .
174 $params . '","Print","width=800,height=600");' . "\n".
175 " }\n" .
176 "// -->\n" .
177 "</script>\n" .
178 "<A HREF=\"javascript:printFormat();\">$print_text</A>\n";
179 } else {
180 $result .= '<A TARGET="_blank" HREF="../src/printer_friendly_bottom.php' .
181 "$params\">$print_text</A>\n";
182 }
10f0ce72 183
a07cd1a4 184 if (!$pf_subtle_link) {
185 /* The link is large, on the bottom of the header panel. */
57257333 186 $result .= '</td></tr>' . "\n";
10f0ce72 187 }
188
a07cd1a4 189 return ($result);
190}
191
57257333 192function ServerMDNSupport( $read ) {
f69feefe 193 /* escaping $ doesn't work -> \x36 */
194 $ret = preg_match( '/(\x36MDNSent|\\\*)/i', $read );
57257333 195 return ( $ret );
196}
197
198function SendMDN ( $recipient , $sender) {
199 global $imapConnection, $mailbox, $username, $attachment_dir, $SERVER_NAME,
200 $version, $attachments, $identity, $data_dir, $passed_id;
201
99fbb343 202 $header = sqimap_get_message_header($imapConnection, $passed_id, $mailbox);
57257333 203 $hashed_attachment_dir = getHashedDir($username, $attachment_dir);
204
205 // part 1 (RFC2298)
206
207 $senton = getLongDateString( $header->date );
208 $to_array = $header->to;
209 $to = '';
210 foreach ($to_array as $line) {
211 $to .= " $line ";
212 }
213
214 $subject = $header->subject;
215 $now = getLongDateString( time() );
46bb8da8 216
78db1583 217 set_my_charset();
218
46bb8da8 219 $body = _("Your message") . "\r\n\r\n" .
220 "\t" . _("To:") . ' ' . $to . "\r\n" .
221 "\t" . _("Subject:") . ' ' . $subject . "\r\n" .
222 "\t" . _("Sent:") . ' ' . $senton . "\r\n" .
223 "\r\n" .
224 sprintf( _("Was displayed on %s"), $now );
f69feefe 225
57257333 226 // part2 (RFC2298)
227
228 $original_recipient = $to;
229 $original_message_id = $header->message_id;
230
231 $part2 = "Reporting-UA : $SERVER_NAME ; SquirrelMail (version $version) \r\n";
232 if ($original_recipient != '') {
233 $part2 .= "Original-Recipient : $original_recipient\r\n";
234 }
235 $final_recipient = $sender;
236 $part2 .= "Final-Recipient: rfc822; $final_recipient\r\n" .
237 "Original-Message-ID : $original_message_id\r\n" .
238 "Disposition: manual-action/MDN-sent-manually; displayed\r\n";
239
240
241 $localfilename = GenerateRandomString(32, 'FILE', 7);
242 $full_localfilename = "$hashed_attachment_dir/$localfilename";
243
244 $fp = fopen( $full_localfilename, 'w');
245 fwrite ($fp, $part2);
246 fclose($fp);
247
248 $newAttachment = array();
249 $newAttachment['localfilename'] = $localfilename;
250 $newAttachment['type'] = "message/disposition-notification";
aa866a40 251 $newAttachment['session']=-1;
57257333 252 $attachments[] = $newAttachment;
253 $MDN_to = trim($recipient);
254 $reply_id = 0;
255
1fca12b5 256 return (SendMessage($MDN_to, '', '', _("Read:") . ' ' . $subject,
257 $body, $reply_id, True, 3, -1) );
57257333 258}
259
260
261function ToggleMDNflag ( $set ) {
77b88425 262 global $imapConnection, $passed_id, $mailbox;
f69feefe 263 sqimap_mailbox_select($imapConnection, $mailbox);
0892e427 264 $sg = $set?'+':'-';
265 $cmd = 'STORE ' . $passed_id . ' ' . $sg . 'FLAGS ($MDNSent)';
0892e427 266 $read = sqimap_run_command ($imapConnection, $cmd, true, $response,
267 $readmessage);
57257333 268}
269
270function ClearAttachments() {
271 global $username, $attachments, $attachment_dir;
272
273 $hashed_attachment_dir = getHashedDir($username, $attachment_dir);
274
aa866a40 275 $rem_attachments = array();
57257333 276 foreach ($attachments as $info) {
b2c19764 277 if ($info['session'] == -1) {
aa866a40 278 $attached_file = "$hashed_attachment_dir/$info[localfilename]";
279 if (file_exists($attached_file)) {
280 unlink($attached_file);
281 }
282 } else {
283 $rem_attachments[] = $info;
284 }
285 }
68c3b52a 286 $attachments = $rem_attachments;
57257333 287}
288
4d0cd98b 289function formatRecipientString($recipients, $item ) {
1fca12b5 290 global $base_uri, $passed_id, $urlMailbox, $startMessage, $show_more_cc,
291 $echo_more, $echo_less, $show_more, $show_more_bcc, $sort;
4d0cd98b 292
293 $i = 0;
294 $url_string = '';
295
296 if (isset ($recipients[0]) && trim($recipients[0])) {
1fca12b5 297 $string = '';
4d0cd98b 298 $ary = $recipients;
299
1fca12b5 300 switch ($item) {
4d0cd98b 301 case 'to':
1fca12b5 302 $show = "&amp;show_more=1&amp;show_more_cc=$show_more_cc&amp;".
303 "show_more_bcc=$show_more_bcc";
304 $show_n = "&amp;show_more=0&amp;show_more_cc=$show_more_cc&amp;".
305 "show_more_bcc=$show_more_bcc";
306 break;
4d0cd98b 307 case 'cc':
1fca12b5 308 $show = "&amp;show_more=$show_more&amp;show_more_cc=1&amp;".
309 "show_more_bcc=$show_more_bcc";
310 $show_n = "&amp;show_more=$show_more&amp;show_more_cc=0&amp;".
311 "show_more_bcc=$show_more_bcc";
312 $show_more = $show_more_cc;
313 break;
4d0cd98b 314 case 'bcc':
1fca12b5 315 $show = "&amp;show_more=$show_more&amp;show_more_cc=$show_more_cc".
316 "&amp;show_more_bcc=1";
317 $show_n = "&amp;show_more=$show_more&amp;show_more_cc=".
318 "$show_more_cc&amp;show_more_bcc=0";
319 $show_more = $show_more_bcc;
320 break;
4d0cd98b 321 default:
1fca12b5 322 $break;
323 }
324
325 while ($i < count($ary)) {
326 $ary[$i] = decodeHeader(htmlspecialchars($ary[$i]));
4d0cd98b 327 $url_string .= $ary[$i];
328 if ($string) {
1fca12b5 329 $string = "$string<BR>$ary[$i]";
4d0cd98b 330 } else {
1fca12b5 331 $string = "$ary[$i]";
4d0cd98b 332 }
333
334 $i++;
335 if (count($ary) > 1) {
1fca12b5 336 if ($show_more == false) {
4d0cd98b 337 if ($i == 1) {
1fca12b5 338 /* From a search... */
339 $string .= '&nbsp;(<A HREF="' . $base_uri .
340 "src/read_body.php?mailbox=$urlMailbox&amp;".
341 "passed_id=$passed_id&amp;";
342 if (isset($where) && isset($what)) {
343 $string .= 'what=' . urlencode($what).
344 "&amp;where=".urlencode($where).
345 "$show\">$echo_more</A>)";
346 } else {
347 $string .= "sort=$sort&amp;startMessage=".
348 "$startMessage"."$show\">$echo_more</A>)";
349 }
350 $i = count($ary);
4d0cd98b 351 }
1fca12b5 352 } else if ($i == 1) {
4d0cd98b 353 /* From a search... */
354 $string .= '&nbsp;(<A HREF="' . $base_uri .
1fca12b5 355 "src/read_body.php?mailbox=$urlMailbox&amp;".
356 "passed_id=$passed_id&amp;";
4d0cd98b 357 if (isset($where) && isset($what)) {
1fca12b5 358 $string .= 'what=' . urlencode($what).
359 "&amp;where=".urlencode($where).
360 "$show_n\">$echo_less</A>)";
4d0cd98b 361 } else {
1fca12b5 362 $string .= "sort=$sort&amp;startMessage=$startMessage".
363 "$show_n\">$echo_less</A>)";
4d0cd98b 364 }
1fca12b5 365 }
4d0cd98b 366 }
1fca12b5 367 }
4d0cd98b 368 }
369 else {
1fca12b5 370 $string = '';
4d0cd98b 371 }
372 $url_string = urlencode($url_string);
373 $result = array();
374 $result['str'] = $string;
375 $result['url_str'] = $url_string;
376 return $result;
377}
378
379
57257333 380
381/*
382 * Main of read_boby.php --------------------------------------------------
383 */
384
385/*
386 Urled vars
387 ----------
388 $passed_id
389*/
a07cd1a4 390
1fca12b5 391if (isset($mailbox)){
4366bea4 392 $mailbox = urldecode( $mailbox );
393}
1fca12b5 394$imapConnection = sqimap_login($username, $key, $imapServerAddress,
395 $imapPort, 0);
650be221 396$read = sqimap_mailbox_select($imapConnection, $mailbox, false, false, true);
57257333 397
a07cd1a4 398do_hook('html_top');
57257333 399
400/*
401 * The following code sets necesarry stuff for the MDN thing
402 */
1fca12b5 403if($default_use_mdn &&
404 ($mdn_user_support = getPref($data_dir, $username, 'mdn_user_support',
405 $default_use_mdn))) {
406
f69feefe 407 $supportMDN = ServerMDNSupport($read["PERMANENTFLAGS"]);
57257333 408 $flags = sqimap_get_flags ($imapConnection, $passed_id);
650be221 409 $FirstTimeSee = !(in_array( 'Seen', $flags ));
57257333 410}
411
a07cd1a4 412displayPageHeader($color, $mailbox);
413
57257333 414
415/*
416 * The following code shows the header of the message and then exit
417 */
a07cd1a4 418if (isset($view_hdr)) {
1fca12b5 419 $read=sqimap_run_command ($imapConnection, "FETCH $passed_id BODY[HEADER]",
420 true, $a, $b);
421
a07cd1a4 422 echo '<BR>' .
1fca12b5 423 '<TABLE WIDTH="100%" CELLPADDING="2" CELLSPACING="0" BORDER="0"'.
424 ' ALIGN="CENTER">' . "\n" .
425 " <TR><TD BGCOLOR=\"$color[9]\" WIDTH=\"100%\" ALIGN=\"CENTER\"><B>".
426 _("Viewing Full Header") . '</B> - '.
427 '<a href="' . $base_uri . 'src/read_body.php?mailbox='.
428 urlencode($mailbox);
a07cd1a4 429 if (isset($where) && isset($what)) {
430 // Got here from a search
1fca12b5 431 echo "&amp;passed_id=$passed_id&amp;where=".urlencode($where).
432 "&amp;what=".urlencode($what).'">';
a07cd1a4 433 } else {
1fca12b5 434 echo "&amp;passed_id=$passed_id&amp;startMessage=$startMessage".
435 "&amp;show_more=$show_more\">";
a07cd1a4 436 }
1fca12b5 437 echo _("View message") . "</a></b></td></tr></table>\n".
438 "<table width='99%' cellpadding='2' cellspacing='0' border='0'".
439 "align=center>\n".
440 '<tr><td>';
441
a07cd1a4 442 $cnum = 0;
443 for ($i=1; $i < count($read); $i++) {
444 $line = htmlspecialchars($read[$i]);
445 if (eregi("^&gt;", $line)) {
446 $second[$i] = $line;
447 $first[$i] = '&nbsp;';
448 $cnum++;
449 } else if (eregi("^[ |\t]", $line)) {
450 $second[$i] = $line;
451 $first[$i] = '';
452 } else if (eregi("^([^:]+):(.+)", $line, $regs)) {
453 $first[$i] = $regs[1] . ':';
454 $second[$i] = $regs[2];
455 $cnum++;
0606ca1f 456 } else {
a07cd1a4 457 $second[$i] = trim($line);
458 $first[$i] = '';
10f0ce72 459 }
a07cd1a4 460 }
461 for ($i=0; $i < count($second); $i = $j) {
462 if (isset($first[$i])) {
463 $f = $first[$i];
0606ca1f 464 }
a07cd1a4 465 if (isset($second[$i])) {
466 $s = nl2br($second[$i]);
467 }
468 $j = $i + 1;
469 while (($first[$j] == '') && ($j < count($first))) {
470 $s .= '&nbsp;&nbsp;&nbsp;&nbsp;' . nl2br($second[$j]);
471 $j++;
0606ca1f 472 }
4b07f746 473 if(strtolower($f) != 'message-id:') {
474 parseEmail($s); /* Find and linkify emailaddresses except msgid */
475 }
1190197c 476 if (isset($f)) {
7e235a1a 477 echo "<nobr><tt><b>$f</b>$s</tt></nobr>";
1190197c 478 }
10f0ce72 479 }
57257333 480 echo "</td></tr></table>\n" .
1fca12b5 481 '</body></html>';
a07cd1a4 482 sqimap_logout($imapConnection);
483 exit;
484}
485
486if (isset($msgs)) {
487 $currentArrayIndex = $passed_id;
488} else {
489 $currentArrayIndex = -1;
490}
491
492for ($i = 0; $i < count($msgs); $i++) {
493 if ($msgs[$i]['ID'] == $passed_id) {
494 $msgs[$i]['FLAG_SEEN'] = true;
10f0ce72 495 }
a07cd1a4 496}
497
1fca12b5 498/**
499 * $message contains all information about the message
500 * including header and body
501 */
a07cd1a4 502$message = sqimap_get_message($imapConnection, $passed_id, $mailbox);
503
504/** translate the subject and mailbox into url-able text **/
505$url_subj = urlencode(trim($message->header->subject));
506$urlMailbox = urlencode($mailbox);
507$url_replyto = '';
508if (isset($message->header->replyto)) {
509 $url_replyto = urlencode($message->header->replyto);
510}
511
1fca12b5 512$url_replytoall = $url_replyto;
a07cd1a4 513
1fca12b5 514/**
515 * If we are replying to all, then find all other addresses and
516 * add them to the list. Remove duplicates.
517 * This is somewhat messy, so I'll explain:
518 * 1) Take all addresses (from, to, cc) (avoid nasty join errors here)
519 */
a07cd1a4 520$url_replytoall_extra_addrs = array_merge(
1fca12b5 521 array($message->header->from),
522 $message->header->to,
523 $message->header->cc
524 );
a07cd1a4 525
1fca12b5 526/**
527 * 2) Make one big string out of them
528 */
a07cd1a4 529$url_replytoall_extra_addrs = join(';', $url_replytoall_extra_addrs);
530
1fca12b5 531/**
532 * 3) Parse that into an array of addresses
533 */
a07cd1a4 534$url_replytoall_extra_addrs = parseAddrs($url_replytoall_extra_addrs);
535
1fca12b5 536/**
537 * 4) Make them unique -- weed out duplicates
538 * (Coded for PHP 4.0.0)
539 */
a07cd1a4 540$url_replytoall_extra_addrs =
541 array_keys(array_flip($url_replytoall_extra_addrs));
542
1fca12b5 543/**
544 * 5) Remove the addresses we'll be sending the message 'to'
545 */
a07cd1a4 546$url_replytoall_avoid_addrs = '';
547if (isset($message->header->replyto)) {
548 $url_replytoall_avoid_addrs = $message->header->replyto;
549}
550
551$url_replytoall_avoid_addrs = parseAddrs($url_replytoall_avoid_addrs);
552foreach ($url_replytoall_avoid_addrs as $addr) {
553 RemoveAddress($url_replytoall_extra_addrs, $addr);
554}
555
1fca12b5 556/**
557 * 6) Remove our identities from the CC list (they still can be in the
558 * TO list) only if $include_self_reply_all is turned off
559 */
a07cd1a4 560if (!$include_self_reply_all) {
561 RemoveAddress($url_replytoall_extra_addrs,
1fca12b5 562 getPref($data_dir, $username, 'email_address'));
a07cd1a4 563 $idents = getPref($data_dir, $username, 'identities');
564 if ($idents != '' && $idents > 1) {
565 for ($i = 1; $i < $idents; $i ++) {
1fca12b5 566 $cur_email_address = getPref($data_dir, $username,
567 'email_address' . $i);
a07cd1a4 568 RemoveAddress($url_replytoall_extra_addrs, $cur_email_address);
10f0ce72 569 }
692155b7 570 }
a07cd1a4 571}
1108e8bb 572
1fca12b5 573/**
574 * 7) Smoosh back into one nice line
575 */
a07cd1a4 576$url_replytoallcc = getLineOfAddrs($url_replytoall_extra_addrs);
692155b7 577
1fca12b5 578/**
579 * 8) urlencode() it
580 */
a07cd1a4 581$url_replytoallcc = urlencode($url_replytoallcc);
be69e508 582
a07cd1a4 583$dateString = getLongDateString($message->header->date);
5bc39e3f 584
1fca12b5 585/**
586 * What do we reply to -- text only, if possible
587 */
e5fdc771 588
589$body = '';
590
591/* experimental */
592/*
593if ($message->header->type0 == 'multipart' && $message->header->type1 == 'digest') {
594 listEntities($message);
595 for ($i = 0; $i < count($message->entities); $i++) {
596
597 $msg = $message->entities[$i];
598 $body .= $msg->header->type0 .'/'.$msg->header->type1 .'<BR>';
599
600 $msg->header->type0 = 'message';
601 $msg->header->type1 = 'rfc822';
602 $ent_ar = findDisplayEntity($msg, false);
603 for ($i = 0; $i < count($ent_ar); $i++) {
604 $body .= formatBody($imapConnection, $msg, $color, $wrap_at, $ent_ar[$i]);
605 }
606 $i++;
607 }
608} else {
609*/
610 $ent_ar = findDisplayEntity($message, false);
611 $i = 0;
612 for ($i = 0; $i < count($ent_ar); $i++) {
613 $body .= formatBody($imapConnection, $message, $color, $wrap_at, $ent_ar[$i]);
614 }
615/*
616}
617*/
618
32c661f4 619/* first step in displaying multiple entities */
e5fdc771 620$ent_ar = findDisplayEntity($message,true);
5bc39e3f 621
f557f53e 622$ent_num = $ent_ar[0];
e5fdc771 623for ($i = 1 ; $i < count($ent_ar); $i++) {
f557f53e 624 $ent_num .= '_'.$ent_ar[$i];
e5fdc771 625}
a07cd1a4 626/** TEXT STRINGS DEFINITIONS **/
627$echo_more = _("more");
628$echo_less = _("less");
629
57257333 630if (!isset($show_more_cc)) {
631 $show_more_cc = FALSE;
632}
10f0ce72 633
4d0cd98b 634if (!isset($show_more_bcc)) {
635 $show_more_bcc = FALSE;
a07cd1a4 636}
4d0cd98b 637
638/** FORMAT THE TO STRING **/
639$to = formatRecipientString($message->header->to, "to");
640$to_string = $to['str'];
641$url_to_string = $to['url_str'];
dfd93ee7 642
a07cd1a4 643
644/** FORMAT THE CC STRING **/
10f0ce72 645
4d0cd98b 646$cc = formatRecipientString($message->header->cc, "cc");
647$cc_string = $cc['str'];
648$url_cc_string = $cc['url_str'];
a07cd1a4 649
650/** FORMAT THE BCC STRING **/
10f0ce72 651
4d0cd98b 652$bcc = formatRecipientString($message->header->bcc, "bcc");
653$bcc_string = $bcc['str'];
654$url_bcc_string = $bcc['url_str'];
10f0ce72 655
a07cd1a4 656if ($default_use_priority) {
a7818e8e 657 $priority_level = substr($message->header->priority,0,1);
658
659 switch($priority_level) {
09278ebf 660 /* check for a higher then normal priority. */
661 case '1':
5be9f195 662 case '2':
663 $priority_string = _("High");
09278ebf 664 break;
665
666 /* check for a lower then normal priority. */
667 case '4':
5be9f195 668 case '5':
669 $priority_string = _("Low");
09278ebf 670 break;
5be9f195 671
09278ebf 672 /* check for a normal priority. */
5be9f195 673 case '3':
09278ebf 674 default:
675 $priority_level = '3';
5be9f195 676 $priority_string = _("Normal");
09278ebf 677 break;
5be9f195 678
10f0ce72 679 }
a07cd1a4 680}
681
682/** make sure everything will display in HTML format **/
683$from_name = decodeHeader(htmlspecialchars($message->header->from));
684$subject = decodeHeader(htmlspecialchars($message->header->subject));
fa77d354 685$identity = '';
686$idents = getPref($data_dir, $username, 'identities');
687if (!empty($idents) && $idents > 1) {
688 for ($i = 1; $i < $idents; $i++) {
1fca12b5 689 $enc_from_name = '"'.
690 encodeHeader(getPref($data_dir,
691 $username,
692 'full_name' . $i)) .
693 '" <' . getPref($data_dir, $username,
694 'email_address' . $i) . '>';
695 if (htmlspecialchars($enc_from_name) == $from_name) {
fa77d354 696 $identity = $i;
697 break;
698 }
699 }
700}
a07cd1a4 701
702do_hook('read_body_top');
703echo '<BR>' .
57257333 704 '<TABLE CELLSPACING="0" WIDTH="100%" BORDER="0" ALIGN="CENTER" CELLPADDING="0">' .
705 '<TR><TD BGCOLOR="' . $color[9] . '" WIDTH="100%">' .
706 '<TABLE WIDTH="100%" CELLSPACING="0" BORDER="0" CELLPADDING="3">' .
707 '<TR>' .
708 '<TD ALIGN="LEFT" WIDTH="33%">' .
709 '<SMALL>' .
710 '<A HREF="' . $base_uri . 'src/';
a07cd1a4 711
712if ($where && $what) {
c52c873e 713 if ($pos == '') {
714 $pos=0;
10f0ce72 715 }
c52c873e 716 echo "search.php?where=".urlencode($where)."&amp;pos=$pos&amp;what=".urlencode($what)."&amp;mailbox=$urlMailbox\">";
a07cd1a4 717} else {
3d570ba0 718 echo "right_main.php?sort=$sort&amp;startMessage=$startMessage&amp;mailbox=$urlMailbox\">";
a07cd1a4 719}
720echo _("Message List") .
721 '</A>&nbsp;|&nbsp;' .
3d570ba0 722 '<A HREF="' . $base_uri . "src/delete_message.php?mailbox=$urlMailbox&amp;message=$passed_id&amp;";
a07cd1a4 723if ($where && $what) {
3d570ba0 724 echo 'where=' . urlencode($where) . '&amp;what=' . urlencode($what) . '">';
a07cd1a4 725} else {
3d570ba0 726 echo "sort=$sort&amp;startMessage=$startMessage\">";
a07cd1a4 727}
728echo _("Delete") . '</A>&nbsp;';
729if (($mailbox == $draft_folder) && ($save_as_draft)) {
d7f8e6e6 730 $comp_uri = $base_uri . "src/compose.php?mailbox=$mailbox&amp;".
731 "identity=$identity&amp;send_to=$url_to_string&amp;".
732 "send_to_cc=$url_cc_string&amp;send_to_bcc=$url_bcc_string&amp;".
733 "subject=$url_subj&amp;mailprio=$priority_level&amp;".
d748c12b 734 "draft_id=$passed_id&amp;ent_num=$ent_num";
d7f8e6e6 735
9c3e6cd4 736 if ($compose_new_win == '1') {
d7f8e6e6 737 echo "<a href=\"javascript:void(0)\" onclick=\"comp_in_new(false,'$comp_uri')\"";
738 } else {
739 echo '|&nbsp;<A HREF="' . $comp_uri .'"';
9c3e6cd4 740 }
741 echo '>'.
a07cd1a4 742 _("Resume Draft") . '</a>';
743}
fa77d354 744if ($mailbox == $sent_folder) {
d7f8e6e6 745 $comp_uri = $base_uri . "src/compose.php?mailbox=$mailbox&amp;".
746 "identity=$identity&amp;send_to=$url_to_string&amp;".
747 "send_to_cc=$url_cc_string&amp;send_to_bcc=$url_bcc_string&amp;".
748 "subject=$url_subj&amp;mailprio=$priority_level&amp;".
749 "ent_num=$ent_num&amp;passed_id=$passed_id&amp;edit_as_new=1";
750
fa77d354 751 if ($compose_new_win == '1') {
d7f8e6e6 752 echo "<a href=\"javascript:void(0)\" onclick=\"comp_in_new(false,'$comp_uri')\"";
753 } else {
754 echo '|&nbsp;<A HREF="' . $comp_uri .'"';
fa77d354 755 }
756 echo '>'.
757 _("Edit Message as New") . '</a>';
758}
a07cd1a4 759
760echo '&nbsp;&nbsp;' .
57257333 761 '</SMALL>' .
762 '</TD>' .
763 '<TD WIDTH="33%" ALIGN="CENTER">' .
764 '<SMALL>';
a07cd1a4 765
766if ( !($where && $what) ) {
a07cd1a4 767 if ($currentArrayIndex == -1) {
768 echo 'Previous&nbsp;|&nbsp;Next';
10f0ce72 769 } else {
a07cd1a4 770 $prev = findPreviousMessage();
771 $next = findNextMessage();
10f0ce72 772
a07cd1a4 773 if ($prev != -1) {
3d570ba0 774 echo '<a href="' . $base_uri . "src/read_body.php?passed_id=$prev&amp;mailbox=$urlMailbox&amp;sort=$sort&amp;startMessage=$startMessage&amp;show_more=0\">" . _("Previous") . "</A>&nbsp;|&nbsp;";
10f0ce72 775 } else {
a07cd1a4 776 echo _("Previous") . '&nbsp;|&nbsp;';
10f0ce72 777 }
7baf86a9 778
a07cd1a4 779 if ($next != -1) {
3d570ba0 780 echo '<a href="' . $base_uri . "src/read_body.php?passed_id=$next&amp;mailbox=$urlMailbox&amp;sort=$sort&amp;startMessage=$startMessage&amp;show_more=0\">" . _("Next") . "</A>";
a07cd1a4 781 } else {
782 echo _("Next");
783 }
10f0ce72 784 }
a07cd1a4 785}
786
57257333 787echo '</SMALL>' .
788 '</TD><TD WIDTH="33%" ALIGN="RIGHT">' .
d7f8e6e6 789 '<SMALL>' ;
790
791$comp_uri = $base_uri . "src/compose.php?forward_id=$passed_id&amp;".
792 "forward_subj=$url_subj&amp;".
793 ($default_use_priority?"mailprio=$priority_level&amp;":'').
794 "mailbox=$urlMailbox&amp;ent_num=$ent_num";
795
796if ($compose_new_win == '1') {
797 echo "<a href=\"javascript:void(0)\" onclick=\"comp_in_new(false,'$comp_uri')\"";
798} else {
799 echo '|&nbsp;<A HREF="' . $comp_uri .'"';
800}
801
9c3e6cd4 802 echo '>'.
a07cd1a4 803 _("Forward") .
d7f8e6e6 804 '</A>&nbsp;|&nbsp;';
805
806$comp_uri = $base_uri . "src/compose.php?send_to=$url_replyto&amp;".
807 "reply_subj=$url_subj&amp;".
808 ($default_use_priority?"mailprio=$priority_level&amp;":'').
809 "reply_id=$passed_id&amp;mailbox=$urlMailbox&amp;ent_num=$ent_num";
810
811if ($compose_new_win == '1') {
812 echo "<a href=\"javascript:void(0)\" onclick=\"comp_in_new(false,'$comp_uri')\"";
813} else {
814 echo '|&nbsp;<A HREF="' . $comp_uri .'"';
815}
816
9c3e6cd4 817 echo '>'.
a07cd1a4 818 _("Reply") .
d7f8e6e6 819 '</A>&nbsp;|&nbsp;';
820
821$comp_uri = $base_uri . "src/compose.php?send_to=$url_replytoall&amp;".
822 "send_to_cc=$url_replytoallcc&amp;reply_subj=$url_subj&amp;".
823 ($default_use_priority?"mailprio=$priority_level&amp;":'').
824 "reply_id=$passed_id&amp;mailbox=$urlMailbox&amp;ent_num=$ent_num";
825
826if ($compose_new_win == '1') {
827 echo "<a href=\"javascript:void(0)\" onclick=\"comp_in_new(false,'$comp_uri')\"";
828} else {
829 echo '|&nbsp;<A HREF="' . $comp_uri .'"';
830}
831
9c3e6cd4 832 echo '>'.
a07cd1a4 833 _("Reply All") .
834 '</A>&nbsp;&nbsp;' .
57257333 835 '</SMALL>' .
836 '</TD>' .
837 '</TR>' .
838 '</TABLE>' .
839 '</TD></TR>' .
3d570ba0 840 '<TR><TD WIDTH="100%">' .
57257333 841 '<TABLE WIDTH="100%" BORDER="0" CELLSPACING="0" CELLPADDING="3">' . "\n" .
842 '<TR>' . "\n";
a07cd1a4 843
844/** subject **/
57257333 845echo "<TD BGCOLOR=\"$color[0]\" WIDTH=\"10%\" ALIGN=\"right\" VALIGN=\"top\">\n" .
a07cd1a4 846 _("Subject:") .
57257333 847 "</TD><TD BGCOLOR=\"$color[0]\" WIDTH=\"80%\" VALIGN=\"top\">\n" .
848 "<B>$subject</B>&nbsp;\n" .
849 "</TD>\n" .
850 '<TD ROWSPAN="4" width="10%" BGCOLOR="' . $color[0] .
a07cd1a4 851 '" ALIGN=right VALIGN=top NOWRAP><small>'.
3d570ba0 852 '<A HREF="' . $base_uri . "src/read_body.php?mailbox=$urlMailbox&amp;passed_id=$passed_id&amp;";
a07cd1a4 853
854/* From a search... */
855if ($where && $what) {
3d570ba0 856 echo 'where=' . urlencode($where) . '&amp;what=' . urlencode($what) .
857 "&amp;view_hdr=1\">" . _("View Full Header") . "</A>\n";
a07cd1a4 858} else {
3d570ba0 859 echo "startMessage=$startMessage&amp;show_more=$show_more&amp;view_hdr=1\">" .
a07cd1a4 860 _("View Full Header") . "</A>\n";
861}
862
863/* Output the printer friendly link if we are in subtle mode. */
864if ($pf_subtle_link) {
865 echo printer_friendly_link(true);
866}
867
868do_hook("read_body_header_right");
57257333 869echo '</small></TD>' .
870 ' </TR>';
a07cd1a4 871
872/** from **/
57257333 873echo '<TR>' .
874 '<TD BGCOLOR="' . $color[0] . '" ALIGN="RIGHT">' .
a07cd1a4 875 _("From:") .
57257333 876 '</TD><TD BGCOLOR="' . $color[0] . '">' .
47268e2c 877 "<B>$from_name</B>&nbsp;\n";
878 do_hook("read_body_after_from");
879echo '</TD>' .
57257333 880 '</TR>';
a07cd1a4 881/** date **/
57257333 882echo '<TR>' . "\n" .
883 '<TD BGCOLOR="' . $color[0] . '" ALIGN="RIGHT">' . "\n" .
a07cd1a4 884 _("Date:") .
57257333 885 "</TD><TD BGCOLOR=\"$color[0]\">\n" .
886 "<B>$dateString</B>&nbsp;\n" .
887 '</TD>' . "\n" .
888 '</TR>' . "\n";
a07cd1a4 889
890/** to **/
57257333 891echo "<TR>\n" .
892 "<TD BGCOLOR=\"$color[0]\" ALIGN=RIGHT VALIGN=TOP>\n" .
a07cd1a4 893 _("To:") .
57257333 894 '</TD><TD BGCOLOR="' . $color[0] . '" VALIGN="TOP">' . "\n" .
895 "<B>$to_string</B>&nbsp;\n" .
896 '</TD>' . "\n" .
897 '</TR>' . "\n";
a07cd1a4 898/** cc **/
9e9ad58b 899if (isset($cc_string) && $cc_string <> '') {
57257333 900 echo '<TR>' .
901 "<TD BGCOLOR=\"$color[0]\" ALIGN=RIGHT VALIGN=TOP>" .
902 'Cc:' .
903 "</TD><TD BGCOLOR=\"$color[0]\" VALIGN=TOP colspan=2>" .
904 "<B>$cc_string</B>&nbsp;" .
905 '</TD>' .
906 '</TR>' . "\n";
a07cd1a4 907}
908
909/** bcc **/
9e9ad58b 910if (isset($bcc_string) && $bcc_string <> '') {
57257333 911 echo '<TR>'.
912 "<TD BGCOLOR=\"$color[0]\" ALIGN=RIGHT VALIGN=TOP>" .
913 'Bcc:' .
914 "</TD><TD BGCOLOR=\"$color[0]\" VALIGN=TOP colspan=2>" .
915 "<B>$bcc_string</B>&nbsp;" .
916 '</TD>' .
917 '</TR>' . "\n";
a07cd1a4 918}
9e9ad58b 919if ($default_use_priority && isset($priority_string) && $priority_string <> '' ) {
920 echo '<TR>' .
921 "<TD BGCOLOR=\"$color[0]\" ALIGN=RIGHT VALIGN=TOP>" .
922 _("Priority") . ': '.
923 "</TD><TD BGCOLOR=\"$color[0]\" VALIGN=TOP colspan=2>" .
924 "<B>$priority_string</B>&nbsp;" .
925 '</TD>' .
926 "</TR>" . "\n";
a07cd1a4 927}
928
929if ($show_xmailer_default) {
451a5790 930 $read = sqimap_run_command ($imapConnection, "FETCH $passed_id BODY.PEEK[HEADER.FIELDS (X-Mailer User-Agent)]", true,
a07cd1a4 931 $response, $readmessage);
932 $mailer = substr($read[1], strpos($read[1], " "));
933 if (trim($mailer)) {
57257333 934 echo '<TR>' .
935 "<TD BGCOLOR=\"$color[0]\" ALIGN=RIGHT VALIGN=TOP>" .
936 _("Mailer") . ': '.
937 "</TD><TD BGCOLOR=\"$color[0]\" VALIGN=TOP colspan=2>" .
938 "<B>$mailer</B>&nbsp;" .
939 '</TD>' .
940 "</TR>" . "\n";
10f0ce72 941 }
a07cd1a4 942}
943
944/* Output the printer friendly link if we are not in subtle mode. */
945if (!$pf_subtle_link) {
946 echo printer_friendly_link(true);
947}
948
57257333 949if ($default_use_mdn) {
950 if ($mdn_user_support) {
951
952 // debug gives you the capability to remove mdn-flags
1190197c 953 // $MDNDebug = false;
57257333 954 $read = sqimap_run_command ($imapConnection, "FETCH $passed_id BODY.PEEK[HEADER.FIELDS (Disposition-Notification-To)]", true,
955 $response, $readmessage);
956 $MDN_to = substr($read[1], strpos($read[1], ' '));
957 $MDN_flag_present = false;
958
959 $read = sqimap_run_command ($imapConnection, "FETCH $passed_id FLAGS", true,
960 $response, $readmessage);
77b88425 961 $MDN_flag_present = preg_match( '/.*\$MDNSent/i', $read[0]);
962
57257333 963 if (trim($MDN_to) &&
964 (!isset( $sendreceipt ) || $sendreceipt == '' ) ) {
965
966 if ( $MDN_flag_present && $supportMDN) {
77b88425 967 $sendreceipt = 'removeMDN';
3d570ba0 968 $url = "\"read_body.php?mailbox=$mailbox&amp;passed_id=$passed_id&amp;startMessage=$startMessage&amp;show_more=$show_more&amp;sendreceipt=$sendreceipt\"";
1190197c 969 $sendreceipt='';
970 /*
650be221 971 if ($MDNDebug ) {
57257333 972 echo '<TR>' .
973 "<TD BGCOLOR=\"$color[9]\" ALIGN=RIGHT VALIGN=TOP>" .
974 _("Read receipt") . ': ' .
975 "</TD><TD BGCOLOR=\"$color[9]\" VALIGN=TOP colspan=2>" .
976 '<B>' .
977 _("send") .
978 "</B> <a href=$url>[" . _("Remove MDN flag") . '] </a>' .
979 '</TD>' .
980 '</TR>' . "\n";
981 } else {
1190197c 982 */
983 echo '<TR>' .
984 "<TD BGCOLOR=\"$color[9]\" ALIGN=RIGHT VALIGN=TOP>" .
985 _("Read receipt") . ': ' .
986 "</TD><TD BGCOLOR=\"$color[9]\" VALIGN=TOP colspan=2>" .
987 '<B>'._("send").'</B>'.
988 '</TD>' .
989 '</TR>' . "\n";
990 /*
57257333 991 }
1190197c 992 */
57257333 993
994 } // when deleted or draft flag is set don't offer to send a MDN response
f69feefe 995 else if ( ereg('\\Draft',$read[0] || ereg('\\Deleted',$read[0])) ) {
57257333 996 echo '<TR>' .
997 "<TD BGCOLOR=\"$color[9]\" ALIGN=RIGHT VALIGN=TOP>" .
998 _("Read receipt") . ': '.
999 "</TD><TD BGCOLOR=\"$color[9]\" VALIGN=TOP colspan=2>" .
1000 '<B>' . _("requested") . "</B>" .
1001 '</TD>' .
1002 '</TR>' . "\n";
1003 }
1004 // if no MDNsupport don't use the annoying popup messages
1005 else if ( !$FirstTimeSee ) {
1006 $sendreceipt = 'send';
3b1410d9 1007 $url = "\"read_body.php?mailbox=$mailbox&passed_id=$passed_id&startMessage=$startMessage&show_more=$show_more&sendreceipt=$sendreceipt\"";
57257333 1008 echo '<TR>' .
1009 "<TD BGCOLOR=\"$color[9]\" ALIGN=RIGHT VALIGN=TOP>" .
1010 _("Read receipt") . ': ' .
1011 "</TD><TD BGCOLOR=\"$color[9]\" VALIGN=TOP colspan=2>" .
1012 '<B>' . _("requested") .
2c64e145 1013 "</B> &nbsp; <a href=$url>[" . _("Send read receipt now") . "]</a>" .
57257333 1014 '</TD>' .
1015 '</TR>' . "\n";
1016 $sendreceipt='';
1017 }
1018 else {
1019 $sendreceipt = 'send';
3b1410d9 1020 $url = "\"read_body.php?mailbox=$mailbox&passed_id=$passed_id&startMessage=$startMessage&show_more=$show_more&sendreceipt=$sendreceipt\"";
57257333 1021 if ($javascript_on) {
3d570ba0 1022 echo "<script language=\"javascript\" type=\"text/javascript\"> \n" .
57257333 1023 '<!-- ' . "\n" .
1024 " if (window.confirm(\"" .
1025 _("The message sender has requested a response to indicate that you have read this message. Would you like to send a receipt?") .
1026 "\")) { \n" .
34a6b7c2 1027 ' window.open('.$url.',"right");' . "\n" .
57257333 1028 ' }' . "\n" .
1029 '// -->' . "\n" .
1030 '</script>' . "\n";
1031 }
1032 echo '<TR>' .
1033 "<TD BGCOLOR=\"$color[9]\" ALIGN=RIGHT VALIGN=TOP>" .
1034 _("Read receipt") . ': ' .
1035 "</TD><TD BGCOLOR=\"$color[9]\" VALIGN=TOP colspan=2>" .
1036 '<B>' . _("requested") . "&nbsp&nbsp</B><a href=$url>" . '[' .
1037 _("Send read receipt now") . '] </a>' ." \n" .
1038 '</TD>' .
1039 '</TR>' . "\n";
1040 $sendreceipt = '';
1041 }
1042 }
1043
77b88425 1044 if ( !isset( $sendreceipt ) || $sendreceipt == '' ) {
57257333 1045 } else if ( $sendreceipt == 'send' ) {
1046 if ( !$MDN_flag_present) {
1047 if (isset($identity) ) {
77b88425 1048 $final_recipient = getPref($data_dir, $username, 'email_address' . '0', '' );
1049 } else {
1050 $final_recipient = getPref($data_dir, $username, 'email_address', '' );
1051 }
57257333 1052
1053 $final_recipient = trim($final_recipient);
1054 if ($final_recipient == '' ) {
77b88425 1055 $final_recipient = getPref($data_dir, $username, 'email_address', '' );
57257333 1056 }
1057
77b88425 1058 if ( SendMDN( $MDN_to, $final_recipient ) > 0 && $supportMDN ) {
1059 ToggleMDNflag( true);
57257333 1060 }
34a6b7c2 1061 ClearAttachments();
57257333 1062 }
1063 $sendreceipt = 'removeMDN';
3d570ba0 1064 $url = "\"read_body.php?mailbox=$mailbox&amp;passed_id=$passed_id&amp;startMessage=$startMessage&amp;show_more=$show_more&amp;sendreceipt=$sendreceipt\"";
1190197c 1065 $sendreceipt='';
7e235a1a 1066 /*
650be221 1067 if ($MDNDebug && $supportMDN) {
57257333 1068 echo " <TR>\n" .
1069 " <TD BGCOLOR=\"$color[9]\" ALIGN=RIGHT VALIGN=TOP>\n" .
1070 " "._("Read receipt").": \n".
1071 " </TD><TD BGCOLOR=\"$color[9]\" VALIGN=TOP colspan=2>\n" .
1072 ' <B>'._("send").'</B>'." <a href=$url>" . '[' . _("Remove MDN flag") . '] </a>' . "\n" .
1073 ' </TD>' . "\n" .
1074 ' </TR>' . "\n";
1075 } else {
1190197c 1076 */
57257333 1077 echo " <TR>\n" .
1078 " <TD BGCOLOR=\"$color[9]\" ALIGN=RIGHT VALIGN=TOP>\n" .
1079 " "._("Read receipt").": \n".
1080 " </TD><TD BGCOLOR=\"$color[9]\" VALIGN=TOP colspan=2>\n" .
1081 ' <B>'._("send").'</B>'. "\n" .
1082 ' </TD>' . "\n" .
1083 ' </TR>' . "\n";
1190197c 1084 /*
57257333 1085 }
1190197c 1086 */
57257333 1087 }
1088 elseif ($sendreceipt == 'removeMDN' ) {
1089 ToggleMDNflag ( false );
1090
1091 $sendreceipt = 'send';
3d570ba0 1092 $url = "\"read_body.php?mailbox=$mailbox&amp;passed_id=$passed_id&amp;startMessage=$startMessage&amp;show_more=$show_more&amp;sendreceipt=$sendreceipt\"";
57257333 1093 echo '<TR>'.
1094 "<TD BGCOLOR=\"$color[9]\" ALIGN=RIGHT VALIGN=TOP>" .
1095 _("Read receipt") . ': ' .
1096 "</TD><TD BGCOLOR=\"$color[9]\" VALIGN=TOP colspan=2>" .
1097 '<B>' . _("requested") .
1098 "</B> &nbsp; <a href=$url>[" . _("Send read receipt now") . "]</a>" .
1099 '</TD>' .
1100 '</TR>' . "\n";
1101 $sendreceipt = '';
1102
1103 }
1104 }
1105}
1106
5be9f195 1107do_hook('read_body_header');
57257333 1108
a07cd1a4 1109echo '</TABLE>' .
1110 ' </TD></TR>' .
1111 '</TABLE>';
1112flush();
1113echo "<TABLE CELLSPACING=0 WIDTH=\"97%\" BORDER=0 ALIGN=CENTER CELLPADDING=0>\n" .
1114 " <TR><TD BGCOLOR=\"$color[4]\" WIDTH=\"100%\">\n" .
e5fdc771 1115 '<BR>';
1116echo $body;
1117
1118echo '</TD></TR></TABLE>' .
a07cd1a4 1119 '<TABLE CELLSPACING="0" WIDTH="100%" BORDER="0" ALIGN="CENTER" CELLPADDING="0">' . "\n" .
1120 " <TR><TD BGCOLOR=\"$color[9]\">&nbsp;</TD></TR>" .
1121 '</TABLE>' . "\n";
1122
1123/* show attached images inline -- if pref'fed so */
5be9f195 1124if (($attachment_common_show_images) &&
a07cd1a4 1125 is_array($attachment_common_show_images_list)) {
5be9f195 1126
a07cd1a4 1127 foreach ($attachment_common_show_images_list as $img) {
5be9f195 1128 $imgurl = '../src/download.php' .
57257333 1129 '?' .
cd7b8833 1130 'passed_id=' . urlencode($img['passed_id']) .
3d570ba0 1131 '&amp;mailbox=' . urlencode($mailbox) .
1132 '&amp;passed_ent_id=' . urlencode($img['ent_id']) .
1133 '&amp;absolute_dl=true';
5be9f195 1134
a07cd1a4 1135 echo "<TABLE BORDER=0 CELLSPACING=0 CELLPADDING=2 ALIGN=CENTER>\n" .
57257333 1136 '<TR>' .
1137 '<TD>' .
1138 "<img src=\"$imgurl\">\n" .
1139 "</TD>\n" .
1140 "</TR>\n" .
a07cd1a4 1141 "</TABLE>\n";
5be9f195 1142
10f0ce72 1143 }
a07cd1a4 1144}
1145
5be9f195 1146
a07cd1a4 1147do_hook('read_body_bottom');
1148do_hook('html_bottom');
1149sqimap_logout($imapConnection);
1150?>
1151</body>
a7818e8e 1152</html>