+ $s = '<TABLE WIDTH="100%" CELLPADDING="0" CELLSPACING="2" BORDER="0"';
+ $s .= ' ALIGN="center" BGCOLOR="'.$color[0].'">';
+ foreach ($env as $key => $val) {
+ if ($val) {
+ $s .= '<TR>';
+ $s .= html_tag('TD', '<B>' . $key . ': </B>', 'RIGHT', '', 'VALIGN="TOP" WIDTH="20%"') . "\n";
+ $s .= html_tag('TD', $val, 'left', '', 'VALIGN="TOP" WIDTH="80%"') . "\n";
+ $s .= '</TR>';
+ }
+ }
+ echo '<TABLE BGCOLOR="'.$color[9].'" WIDTH="100%" CELLPADDING="1"'.
+ ' CELLSPACING="0" BORDER="0" ALIIGN="center">'."\n";
+ echo '<TR><TD HEIGHT="5" COLSPAN="2" BGCOLOR="'.
+ $color[4].'"></TD></TR><TR><TD align=center>'."\n";
+ echo $s;
+ do_hook("read_body_header");
+ formatToolbar($mailbox, $passed_id, $passed_ent_id, $message, $color);
+ echo '</TABLE>';
+ echo '</TD></TR><TR><TD HEIGHT="5" COLSPAN="2" BGCOLOR="'.$color[4].'"></TD></TR>'."\n";
+ echo '</TABLE>';
+}
+
+function formatMenubar($mailbox, $passed_id, $passed_ent_id, $message, $mbx_response) {
+ global $base_uri, $draft_folder, $where, $what, $color, $sort,
+ $startMessage, $compose_new_win, $PHP_SELF, $save_as_draft,
+ $enable_forward_as_attachment;
+
+ $topbar_delimiter = ' | ';
+ $urlMailbox = urlencode($mailbox);
+ $s = '<table width="100%" cellpadding="3" cellspacing="0" align="center"'.
+ ' border="0" bgcolor="'.$color[9].'"><tr><td align="left" width="33%"><small>';
+
+ $msgs_url = $base_uri . 'src/';
+ if (isset($where) && isset($what)) {
+ $msgs_url .= 'search.php?where=' . urlencode($where) .
+ '&what=' . urlencode($what) . '&mailbox=' . $urlMailbox;
+ $msgs_str = _("Search results");
+ } else {
+ $msgs_url .= 'right_main.php?sort=' . $sort . '&startMessage=' .
+ $startMessage . '&mailbox=' . $urlMailbox;
+ $msgs_str = _("Message List");
+ }
+ $s .= '<a href="' . $msgs_url . '">' . $msgs_str . '</a>';
+
+ $delete_url = $base_uri . 'src/delete_message.php?mailbox=' . $urlMailbox .
+ '&message=' . $passed_id . '&';
+ if (!(isset($passed_ent_id) && $passed_ent_id)) {
+ if ($where && $what) {
+ $delete_url .= 'where=' . urlencode($where) . '&what=' . urlencode($what);
+ } else {
+ $delete_url .= 'sort=' . $sort . '&startMessage=' . $startMessage;
+ }
+ $s .= $topbar_delimiter;
+ $s .= '<a href="' . $delete_url . '">' . _("Delete") . '</a>';
+ }
+
+ $comp_uri = $base_uri . 'src/compose.php' .
+ '?passed_id=' . $passed_id .
+ '&mailbox=' . $urlMailbox .
+ (isset($passed_ent_id)?'&passed_ent_id='.$passed_ent_id:'');
+
+ if ($compose_new_win == '1') {
+ $link_open = '<a href="javascript:void(0)" onclick="comp_in_new(\'';
+ $link_close = '\')">';
+ } else {
+ $link_open = '<a href="';
+ $link_close = '">';
+ }
+ if (($mailbox == $draft_folder) && ($save_as_draft)) {
+ $comp_alt_uri = $comp_uri . '&action=draft';
+ $comp_alt_string = _("Resume Draft");
+ } else if (handleAsSent($mailbox)) {
+ $comp_alt_uri = $comp_uri . '&action=edit_as_new';
+ $comp_alt_string = _("Edit Message as New");
+ }
+ if (isset($comp_alt_uri)) {
+ $s .= $topbar_delimiter;
+ $s .= $link_open . $comp_alt_uri . $link_close . $comp_alt_string . '</a>';
+ }
+
+ $s .= '</small></td><td align="center" width="33%"><small>';
+
+ if (!(isset($where) && isset($what)) && !$passed_ent_id) {
+ $prev = findPreviousMessage($mbx_response['EXISTS'], $passed_id);
+ $next = findNextMessage($passed_id);
+ if ($prev != -1) {
+ $uri = $base_uri . 'src/read_body.php?passed_id='.$prev.
+ '&mailbox='.$urlMailbox.'&sort='.$sort.
+ '&startMessage='.$startMessage.'&show_more=0';
+ $s .= '<a href="'.$uri.'">'._("Previous").'</a>';
+ } else {
+ $s .= _("Previous");
+ }
+ $s .= $topbar_delimiter;
+ if ($next != -1) {
+ $uri = $base_uri . 'src/read_body.php?passed_id='.$next.
+ '&mailbox='.$urlMailbox.'&sort='.$sort.
+ '&startMessage='.$startMessage.'&show_more=0';
+ $s .= '<a href="'.$uri.'">'._("Next").'</a>';
+ } else {
+ $s .= _("Next");
+ }
+ } else if (isset($passed_ent_id) && $passed_ent_id) {
+ /* code for navigating through attached message/rfc822 messages */
+ $url = set_url_var($PHP_SELF, 'passed_ent_id',0);
+ $s .= '<a href="'.$url.'">'._("View Message").'</a>';
+ $entities = array();
+ $entity_count = array();
+ $c = 0;
+
+ foreach($message->parent->entities as $ent) {
+ if ($ent->type0 == 'message' && $ent->type1 == 'rfc822') {
+ $c++;
+ $entity_count[$c] = $ent->entity_id;
+ $entities[$ent->entity_id] = $c;
+ }
+ }
+ $prev_link = _("Previous");
+ $next_link = _("Next");
+ if($entities[$passed_ent_id] > 1) {
+ $prev_ent_id = $entity_count[$entities[$passed_ent_id] - 1];
+ $prev_link = '<a href="'
+ . set_url_var($PHP_SELF, 'passed_ent_id', $prev_ent_id)
+ . '">' . $prev_link . '</a>';
+ }
+ if($entities[$passed_ent_id] < $c) {
+ $next_ent_id = $entity_count[$entities[$passed_ent_id] + 1];
+ $next_link = '<a href="'
+ . set_url_var($PHP_SELF, 'passed_ent_id', $next_ent_id)
+ . '">' . $next_link . '</a>';
+ }
+ $s .= $topbar_delimiter . $prev_link;
+ $par_ent_id = $message->parent->entity_id;
+ if ($par_ent_id) {
+ $par_ent_id = substr($par_ent_id,0,-2);
+ $s .= $topbar_delimiter;
+ $url = set_url_var($PHP_SELF, 'passed_ent_id',$par_ent_id);
+ $s .= '<a href="'.$url.'">'._("Up").'</a>';
+ }
+ $s .= $topbar_delimiter . $next_link;
+ }
+
+ $s .= '</small></td>' . "\n" . '<td align="right" width="33%" nowrap><small>';
+ $comp_action_uri = $comp_uri . '&action=forward';
+ $s .= $link_open . $comp_action_uri . $link_close . _("Forward") . '</a>';
+
+ if ($enable_forward_as_attachment) {
+ $comp_action_uri = $comp_uri . '&action=forward_as_attachment';
+ $s .= $topbar_delimiter;
+ $s .= $link_open . $comp_action_uri . $link_close . _("Forward as Attachment") . '</a>';
+ }
+
+ $comp_action_uri = decodeHeader($comp_uri . '&action=reply');
+ $s .= $topbar_delimiter;
+ $s .= $link_open . $comp_action_uri . $link_close . _("Reply") . '</a>';
+
+ $comp_action_uri = $comp_uri . '&action=reply_all';
+ $s .= $topbar_delimiter;
+ $s .= $link_open . $comp_action_uri . $link_close . _("Reply All") . '</a>';
+ $s .= '</small></td></tr></table>';
+ do_hook("read_body_menu_top");
+ echo $s;
+ do_hook("read_body_menu_bottom");
+}
+
+function formatToolbar($mailbox, $passed_id, $passed_ent_id, $message, $color) {
+ global $base_uri;
+
+ $urlMailbox = urlencode($mailbox);
+ $url = $base_uri.'src/view_header.php?'.$_SERVER['QUERY_STRING'];
+
+ $s = "<TR>\n" .
+ '<TD VALIGN="MIDDLE" ALIGN="RIGHT" WIDTH="20%"><B>' . _("Options") . ": </B></TD>\n" .
+ '<TD VALIGN="MIDDLE" ALIGN="LEFT" WIDTH="80%"><SMALL>' .
+ '<a href="'.$url.'">'._("View Full Header").'</a>';
+
+ /* Output the printer friendly link if we are in subtle mode. */
+ $s .= ' | ' .
+ printer_friendly_link($mailbox, $passed_id, $passed_ent_id, $color);
+ echo $s;
+ do_hook("read_body_header_right");
+ $s = "</SMALL></TD>\n" .
+ "</TR>\n";
+ echo $s;
+
+}
+
+/***************************/
+/* Main of read_body.php */
+/***************************/
+
+/* get the globals we may need */
+
+$username = $_SESSION['username'];
+$key = $_COOKIE['key'];
+$onetimepad = $_SESSION['onetimepad'];
+$msgs = $_SESSION['msgs'];
+$base_uri = $_SESSION['base_uri'];
+$delimiter = $_SESSION['delimiter'];
+
+if (isset($_GET['passed_id'])) {
+ $passed_id = (int) $_GET['passed_id'];
+}
+elseif (isset($_POST['passed_id'])) {
+ $passed_id = (int) $_POST['passed_id'];
+}
+
+if (isset($_GET['passed_ent_id'])) {
+ $passed_ent_id = $_GET['passed_ent_id'];
+}
+elseif (isset($_POST['passed_ent_id'])) {
+ $passed_ent_id = $_POST['passed_ent_id'];
+}
+
+if (isset($_GET['sendreceipt'])) {
+ $sendreceipt = $_GET['sendreceipt'];
+}
+
+if (isset($_GET['sort'])) {
+ $sort = (int) $_GET['sort'];
+}
+elseif (isset($_POST['sort'])) {
+ $sort = (int) $_POST['sort'];
+}
+if (isset($_GET['startMessage'])) {
+ $startMessage = (int) $_GET['startMessage'];
+}
+elseif (isset($_POST['startMessage'])) {
+ $startMessage = (int) $_POST['startMessage'];
+}
+if (isset($_GET['show_more'])) {
+ $show_more = (int) $_GET['show_more'];
+}
+if (isset($_GET['show_more_cc'])) {
+ $show_more_cc = (int) $_GET['show_more_cc'];
+}
+if (isset($_GET['show_more_bcc'])) {
+ $show_more_bcc = (int) $_GET['show_more_bcc'];
+}
+if (isset($_GET['mailbox'])) {
+ $mailbox = $_GET['mailbox'];
+}
+elseif (isset($_POST['mailbox'])) {
+ $mailbox = $_POST['mailbox'];
+}
+if (isset($_GET['where'])) {
+ $where = $_GET['where'];
+}
+if (isset($_GET['what'])) {
+ $what = $_GET['what'];
+}
+if (isset($_GET['view_hdr'])) {
+ $view_hdr = (int) $_GET['view_hdr'];
+}
+if (isset($_SESSION['server_sort_array'])) {
+ $server_sort_array = $_SESSION['server_sort_array'];
+}
+if (isset($_SESSION['msgs'])) {
+ $msgs = $_SESSION['msgs'];
+}
+if (isset($_SESSION['msort'])) {
+ $msort = $_SESSION['msort'];
+}
+if (isset($_POST['move_id'])) {
+ $move_id = $_POST['move_id'];
+}
+if (isset($_SESSION['lastTargetMailbox'])) {
+ $lastTargetMailbox = $_SESSION['lastTargetMailbox'];
+}
+if (isset($_SESSION['messages'])) {
+ $messages = $_SESSION['messages'];
+} else {
+ $messages = array();
+}
+
+
+
+/* end of get globals */
+global $uid_support, $sqimap_capabilities;
+
+if (isset($mailbox)) {
+ $mailbox = urldecode( $mailbox );
+}
+
+$imapConnection = sqimap_login($username, $key, $imapServerAddress, $imapPort, 0);
+$mbx_response = sqimap_mailbox_select($imapConnection, $mailbox, false, false, true);
+
+
+/**
+ * $message contains all information about the message
+ * including header and body
+ */
+
+$uidvalidity = $mbx_response['UIDVALIDITY'];
+
+if (!isset($messages[$uidvalidity])) {
+ $messages[$uidvalidity] = array();
+}
+if (!isset($messages[$uidvalidity][$passed_id]) || !$uid_support) {
+ $message = sqimap_get_message($imapConnection, $passed_id, $mailbox);
+ $FirstTimeSee = !$message->is_seen;
+ $message->is_seen = true;
+ $messages[$uidvalidity][$passed_id] = $message;
+} else {
+// $message = sqimap_get_message($imapConnection, $passed_id, $mailbox);
+ $message = $messages[$uidvalidity][$passed_id];
+ $FirstTimeSee = !$message->is_seen;
+}
+
+if (isset($passed_ent_id) && $passed_ent_id) {
+ $message = $message->getEntity($passed_ent_id);
+ if ($message->type0 != 'message' && $message->type1 != 'rfc822') {
+ $message = $message->parent;