$value) { if ($passed_id == $value) { if ($key == $count) { break; } $result = $server_sort_array[$key + 1]; break; } } } else { if ($sort == 6) { if ($passed_id != 1) { $result = $passed_id - 1; } } else { if (is_array($msort)) { for (reset($msort); ($key = key($msort)), (isset($key)); next($msort)) { if ($passed_id == $msgs[$key]['ID']) { next($msort); $key = key($msort); if (isset($key)){ $result = $msgs[$key]['ID']; break; } } } } } } return $result; } /** returns the index of the previous message from the array. */ function findPreviousMessage($numMessages, $passed_id) { global $msort, $sort, $msgs, $thread_sort_messages, $allow_server_sort, $server_sort_array; $result = -1; if (!is_array($server_sort_array)) { $thread_sort_messages = 0; $allow_server_sort = FALSE; } if ($thread_sort_messages || $allow_server_sort ) { foreach($server_sort_array as $key=>$value) { if ($passed_id == $value) { if ($key == 0) { break; } $result = $server_sort_array[$key - 1]; break; } } } else { if ($sort == 6) { if ($passed_id != $numMessages) { $result = $passed_id + 1; } } else { if (is_array($msort)) { for (reset($msort); ($key = key($msort)), (isset($key)); next($msort)) { if ($passed_id == $msgs[$key]['ID']) { prev($msort); $key = key($msort); if (isset($key)) { //echo $msort[$key]; /* Why again were we echoing here? */ $result = $msgs[$key]['ID']; break; } } } } } } return $result; } /** * Displays a link to a page where the message is displayed more * "printer friendly". */ function printer_friendly_link($mailbox, $passed_id, $passed_ent_id, $color) { global $javascript_on; $params = '?passed_ent_id=' . $passed_ent_id . '&mailbox=' . urlencode($mailbox) . '&passed_id=' . $passed_id; $print_text = _("View Printable Version"); $result = ''; /* Output the link. */ if ($javascript_on) { $result .= '\n" . "$print_text\n"; } else { $result .= '$print_text\n"; } return $result; } function ServerMDNSupport($read) { /* escaping $ doesn't work -> \x36 */ $ret = preg_match('/(\x36MDNSent|\\\*)/i', $read); return $ret; } function SendMDN ( $mailbox, $passed_id, $sender, $message, $imapConnection) { global $username, $attachment_dir, $_SERVER, $version, $attachments, $squirrelmail_language, $default_charset, $languages, $useSendmail, $domain, $sent_folder, $popuser, $data_dir, $username; $SERVER_NAME = $_SERVER['SERVER_NAME']; $header = $message->rfc822_header; $hashed_attachment_dir = getHashedDir($username, $attachment_dir); $rfc822_header = new Rfc822Header(); $content_type = new ContentType('multipart/report'); $content_type->properties['report-type']='disposition-notification'; set_my_charset(); if ($default_charset) { $content_type->properties['charset']=$default_charset; } $rfc822_header->content_type = $content_type; $rfc822_header->to[] = $header->dnt; $rfc822_header->subject = _("Read:") . ' ' . $header->subject; $reply_to = ''; if (isset($identity) && $identity != 'default') { $from_mail = getPref($data_dir, $username, 'email_address' . $identity); $full_name = getPref($data_dir, $username, 'full_name' . $identity); $from_addr = '"'.$full_name.'" <'.$from_mail.'>'; $reply_to = getPref($data_dir, $username, 'reply_to' . $identity); } else { $from_mail = getPref($data_dir, $username, 'email_address'); $full_name = getPref($data_dir, $username, 'full_name'); $from_addr = '"'.$full_name.'" <'.$from_mail.'>'; $reply_to = getPref($data_dir, $username,'reply_to'); } if (!$from_addr) { $from_addr = "$popuser@$domain"; $from_mail = $from_addr; } $rfc822_header->from = $rfc822_header->parseAddress($from_addr,true); if ($reply_to) { $rfc822_header->reply_to = $rfc822_header->parseAddress($reply_to,true); } // part 1 (RFC2298) $senton = getLongDateString( $header->date ); $to_array = $header->to; $to = ''; foreach ($to_array as $line) { $to .= ' '.$line->getAddress(); } $now = getLongDateString( time() ); set_my_charset(); $body = _("Your message") . "\r\n\r\n" . "\t" . _("To:") . ' ' . $to . "\r\n" . "\t" . _("Subject:") . ' ' . $header->subject . "\r\n" . "\t" . _("Sent:") . ' ' . $senton . "\r\n" . "\r\n" . sprintf( _("Was displayed on %s"), $now ); $special_encoding = ''; if (isset($languages[$squirrelmail_language]['XTRA_CODE']) && function_exists($languages[$squirrelmail_language]['XTRA_CODE'])) { $body = $languages[$squirrelmail_language]['XTRA_CODE']('encode', $body); if (strtolower($default_charset) == 'iso-2022-jp') { if (mb_detect_encoding($body) == 'ASCII') { $special_encoding = '8bit'; } else { $body = mb_convert_encoding($body, 'JIS'); $special_encoding = '7bit'; } } } $part1 = new Message(); $part1->setBody($body); $mime_header = new MessageHeader; $mime_header->type0 = 'text'; $mime_header->type1 = 'plain'; if ($special_encoding) { $mime_header->encoding = $special_encoding; } else { $mime_header->encoding = 'us-ascii'; } if ($default_charset) { $mime_header->parameters['charset'] = $default_charset; } $part1->mime_header = $mime_header; // part2 (RFC2298) $original_recipient = $to; $original_message_id = $header->message_id; $report = "Reporting-UA : $SERVER_NAME ; SquirrelMail (version $version) \r\n"; if ($original_recipient != '') { $report .= "Original-Recipient : $original_recipient\r\n"; } $final_recipient = $sender; $report .= "Final-Recipient: rfc822; $final_recipient\r\n" . "Original-Message-ID : $original_message_id\r\n" . "Disposition: manual-action/MDN-sent-manually; displayed\r\n"; $part2 = new Message(); $part2->setBody($report); $mime_header = new MessageHeader; $mime_header->type0 = 'message'; $mime_header->type1 = 'disposition-notification'; $mime_header->encoding = 'us-ascii'; $part2->mime_header = $mime_header; $composeMessage = new Message(); $composeMessage->rfc822_header = $rfc822_header; $composeMessage->addEntity($part1); $composeMessage->addEntity($part2); if ($useSendmail) { require_once(SM_PATH . 'class/deliver/Deliver_SendMail.class.php'); global $sendmail_path; $deliver = new Deliver_SendMail(); $stream = $deliver->initStream($composeMessage,$sendmail_path); } else { require_once(SM_PATH . 'class/deliver/Deliver_SMTP.class.php'); $deliver = new Deliver_SMTP(); global $smtpServerAddress, $smtpPort, $use_authenticated_smtp, $pop_before_smtp; if ($use_authenticated_smtp) { global $key, $onetimepad; $user = $username; $pass = OneTimePadDecrypt($key, $onetimepad); } else { $user = ''; $pass = ''; } $authPop = (isset($pop_before_smtp) && $pop_before_smtp) ? true : false; $stream = $deliver->initStream($composeMessage,$domain,0, $smtpServerAddress, $smtpPort, $authPop); } $success = false; if ($stream) { $length = $deliver->mail($composeMessage, $stream); $success = $deliver->finalizeStream($stream); } if (!$success) { $msg = $deliver->dlv_msg . '
Server replied: '.$deliver->dlv_ret_nr; require_once(SM_PATH . 'functions/display_messages.php'); plain_error_message($msg, $color); } else { unset ($deliver); if (sqimap_mailbox_exists ($imapConnection, $sent_folder)) { sqimap_append ($imapConnection, $sent_folder, $length); require_once(SM_PATH . 'class/deliver/Deliver_IMAP.class.php'); $imap_deliver = new Deliver_IMAP(); $imap_deliver->mail($composeMessage, $imapConnection); sqimap_append_done ($imapConnection); unset ($imap_deliver); } } return $success; } function ToggleMDNflag ($set ,$imapConnection, $mailbox, $passed_id, $uid_support) { $sg = $set?'+':'-'; $cmd = 'STORE ' . $passed_id . ' ' . $sg . 'FLAGS ($MDNSent)'; $read = sqimap_run_command ($imapConnection, $cmd, true, $response, $readmessage, $uid_support); } function ClearAttachments() { global $username, $attachments, $attachment_dir; $hashed_attachment_dir = getHashedDir($username, $attachment_dir); $rem_attachments = array(); foreach ($attachments as $info) { if ($info['session'] == -1) { $attached_file = "$hashed_attachment_dir/$info[localfilename]"; if (file_exists($attached_file)) { unlink($attached_file); } } else { $rem_attachments[] = $info; } } $attachments = $rem_attachments; } function formatRecipientString($recipients, $item ) { global $show_more_cc, $show_more, $show_more_bcc, $PHP_SELF; $string = ''; if ((is_array($recipients)) && (isset($recipients[0]))) { $show = false; if ($item == 'to') { if ($show_more) { $show = true; $url = set_url_var($PHP_SELF, 'show_more',0); } else { $url = set_url_var($PHP_SELF, 'show_more',1); } } else if ($item == 'cc') { if ($show_more_cc) { $show = true; $url = set_url_var($PHP_SELF, 'show_more_cc',0); } else { $url = set_url_var($PHP_SELF, 'show_more_cc',1); } } else if ($item == 'bcc') { if ($show_more_bcc) { $show = true; $url = set_url_var($PHP_SELF, 'show_more_bcc',0); } else { $url = set_url_var($PHP_SELF, 'show_more_bcc',1); } } $cnt = count($recipients); foreach($recipients as $r) { $add = htmlspecialchars($r->getAddress()); if ($string) { $string .= '
' . $add; } else { $string = $add; if ($cnt > 1) { $string .= ' ('._("less").')'; } else { $string .= '">'._("more").')'; break; } } } } } return $string; } function formatEnvheader($mailbox, $passed_id, $passed_ent_id, $message, $color, $FirstTimeSee) { global $msn_user_support, $default_use_mdn, $draft_folder, $sent_folder, $default_use_priority, $show_xmailer_default, $mdn_user_support, $PHP_SELF, $javascript_on; $header = $message->rfc822_header; $env = array(); $env[_("Subject")] = htmlspecialchars(decodeHeader($header->subject)); $from_name = $header->getAddr_s('from'); if (!$from_name) { $from_name = $header->getAddr_s('sender'); if (!$from_name) { $from_name = _("Unknown sender"); } } $env[_("From")] = htmlspecialchars(decodeHeader($from_name)); $env[_("Date")] = getLongDateString($header->date); $env[_("To")] = formatRecipientString($header->to, "to"); $env[_("Cc")] = formatRecipientString($header->cc, "cc"); $env[_("Bcc")] = formatRecipientString($header->bcc, "bcc"); if ($default_use_priority) { $env[_("Priority")] = getPriorityStr($header->priority); } if ($show_xmailer_default) { $env[_("Mailer")] = decodeHeader($header->xmailer); } if ($default_use_mdn) { if ($mdn_user_support) { if ($header->dnt) { if ($message->is_mdnsent) { $env[_("Read receipt")] = _("send"); } else { $env[_("Read receipt")] = _("requested"); if (!($mailbox == $draft_folder || $mailbox == $sent_folder || $message->is_deleted || $passed_ent_id)) { $mdn_url = $PHP_SELF . '&sendreceipt=1'; if ($FirstTimeSee && $javascript_on) { $script = ''. "\n"; echo $script; } $env[_("Read receipt")] .= ' [' . _("Send read receipt now") . ']'; } } } } } $s = ''; foreach ($env as $key => $val) { if ($val) { $s .= ''; $s .= html_tag('TD', '' . $key . ':  ', 'RIGHT', '', 'VALIGN="TOP" WIDTH="20%"') . "\n"; $s .= html_tag('TD', $val, 'left', '', 'VALIGN="TOP" WIDTH="80%"') . "\n"; $s .= ''; } } echo $s; do_hook("read_body_header"); formatToolbar($mailbox, $passed_id, $passed_ent_id, $message, $color); echo '
'; } function formatMenubar($mailbox, $passed_id, $passed_ent_id, $message, $mbx_response) { global $base_uri, $sent_folder, $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 = '' . "\n" . '
'; $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 .= '' . $msgs_str . ''; $s .= $topbar_delimiter; $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 .= '' . _("Delete") . ''; } $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 = ''; } else { $link_open = ''; } if (($mailbox == $draft_folder) && ($save_as_draft)) { $comp_alt_uri = $comp_uri . '&action=draft'; $comp_alt_string = _("Resume Draft"); } else if ($mailbox == $sent_folder) { $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 . ''; } $s .= ''; 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 .= ''._("Previous").''; } 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 .= ''._("Next").''; } 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 .= ''._("View Message").''; $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 .= ''._("Up").''; } } $s .= ''; $comp_action_uri = $comp_uri . '&action=forward'; $s .= $link_open . $comp_action_uri . $link_close . _("Forward") . ''; $s .= $topbar_delimiter; if ($enable_forward_as_attachment) { $comp_action_uri = $comp_uri . '&action=forward_as_attachment'; $s .= $link_open . $comp_action_uri . $link_close . _("Forward as Attachment") . ''; $s .= $topbar_delimiter; } $comp_action_uri = decodeHeader($comp_uri . '&action=reply'); $s .= $link_open . $comp_action_uri . $link_close . _("Reply") . ''; $s .= $topbar_delimiter; $comp_action_uri = $comp_uri . '&action=reply_all'; $s .= $link_open . $comp_action_uri . $link_close . _("Reply All") . ''; $s .= '
'; 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 = "\n" . '' . _("Options") . ":  \n" . '' . ''._("View Full Header").''; /* 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 = "\n" . "\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 = $_GET['passed_id']; } elseif (isset($_POST['passed_id'])) { $passed_id = $_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 = $_GET['sort']; } elseif (isset($_POST['sort'])) { $sort = $_POST['sort']; } if (isset($_GET['startMessage'])) { $startMessage = $_GET['startMessage']; } elseif (isset($_POST['startMessage'])) { $startMessage = $_POST['startMessage']; } if (isset($_GET['show_more'])) { $show_more = $_GET['show_more']; } if (isset($_GET['show_more_cc'])) { $show_more_cc = $_GET['show_more_cc']; } if (isset($_GET['show_more_bcc'])) { $show_more_bcc = $_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 = $_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; } $read = sqimap_run_command ($imapConnection, "FETCH $passed_id BODY[$passed_ent_id.HEADER]", true, $response, $msg, $uid_support); $rfc822_header = new Rfc822Header(); $rfc822_header->parseHeader($read); $message->rfc822_header = $rfc822_header; } else { $passed_ent_id = 0; } $header = $message->header; do_hook('html_top'); /****************************************/ /* Block for handling incoming url vars */ /****************************************/ if (isset($sendreceipt)) { if ( !$message->is_mdnsent ) { if (isset($identity) ) { $final_recipient = getPref($data_dir, $username, 'email_address' . '0', '' ); } else { $final_recipient = getPref($data_dir, $username, 'email_address', '' ); } $final_recipient = trim($final_recipient); if ($final_recipient == '' ) { $final_recipient = getPref($data_dir, $username, 'email_address', '' ); } $supportMDN = ServerMDNSupport($mbx_response["PERMANENTFLAGS"]); if ( SendMDN( $mailbox, $passed_id, $final_recipient, $message, $imapConnection ) > 0 && $supportMDN ) { ToggleMDNflag( true, $imapConnection, $mailbox, $passed_id, $uid_support); $message->is_mdnsent = true; $messages[$uidvalidity][$passed_id]=$message; } ClearAttachments(); } } /***********************************************/ /* End of block for handling incoming url vars */ /***********************************************/ $msgs[$passed_id]['FLAG_SEEN'] = true; $messagebody = ''; do_hook('read_body_top'); if ($show_html_default == 1) { $ent_ar = $message->findDisplayEntity(array()); } else { $ent_ar = $message->findDisplayEntity(array(), array('text/plain')); } $cnt = count($ent_ar); for ($i = 0; $i < $cnt; $i++) { $messagebody .= formatBody($imapConnection, $message, $color, $wrap_at, $ent_ar[$i], $passed_id, $mailbox); if ($i != $cnt-1) { $messagebody .= '
'; } } displayPageHeader($color, $mailbox); formatMenuBar($mailbox, $passed_id, $passed_ent_id, $message, $mbx_response); formatEnvheader($mailbox, $passed_id, $passed_ent_id, $message, $color, $FirstTimeSee); echo ''; echo ' '; $attachmentsdisplay = formatAttachments($message,$ent_ar,$mailbox, $passed_id); if ($attachmentsdisplay) { echo ' '; echo '
'; echo ' '; echo ' '; echo '
'; echo ' '; echo ' '; echo '
'; echo ' '; echo ' '. html_tag( 'td', '
'. $messagebody."\n", 'left').''; echo '
'; echo '
'; echo '
'; echo ' '; echo ' '; echo '
'; echo ' '; echo ' '; echo '
'; echo ' ' . _("Attachments") . ':'; echo '
'; echo '
'; echo $attachmentsdisplay; echo '
'; echo '
'; echo ' '; } echo ''; /* show attached images inline -- if pref'fed so */ if (($attachment_common_show_images) && is_array($attachment_common_show_images_list)) { foreach ($attachment_common_show_images_list as $img) { $imgurl = SM_PATH . 'src/download.php' . '?' . 'passed_id=' . urlencode($img['passed_id']) . '&mailbox=' . urlencode($mailbox) . '&ent_id=' . urlencode($img['ent_id']) . '&absolute_dl=true'; echo html_tag( 'table', "\n" . html_tag( 'tr', "\n" . html_tag( 'td', '' ."\n", 'left' ) ) , 'center', '', 'cellspacing=0 border="0" cellpadding="2"'); } } do_hook('read_body_bottom'); do_hook('html_bottom'); sqimap_logout($imapConnection); /* sessions are written at the end of the script. it's better to register them at the end so we avoid double session_register calls */ sqsession_register($messages,'messages'); ?>