X-Git-Url: https://vcs.fsf.org/?p=squirrelmail.git;a=blobdiff_plain;f=src%2Fread_body.php;h=165b6429bb0d9cc4ca2db10537c07c3b8a00abbd;hp=9e315719889f1ddc2725b42a73595b8f638a7f70;hb=9c3e6cd4518d9e0d072a146fd6d19acd4daac243;hpb=15e6162eacc97158393bc75aed3afeb7b19c24a6
diff --git a/src/read_body.php b/src/read_body.php
index 9e315719..165b6429 100644
--- a/src/read_body.php
+++ b/src/read_body.php
@@ -10,649 +10,998 @@
* the resulting emails in the right frame.
*
* $Id$
- /
-
-/*****************************************************************/
-/*** THIS FILE NEEDS TO HAVE ITS FORMATTING FIXED!!! ***/
-/*** PLEASE DO SO AND REMOVE THIS COMMENT SECTION. ***/
-/*** + Base level indent should begin at left margin, as ***/
-/*** the require_once below looks. ***/
-/*** + All identation should consist of four space blocks ***/
-/*** + Tab characters are evil. ***/
-/*** + all comments should use "slash-star ... star-slash" ***/
-/*** style -- no pound characters, no slash-slash style ***/
-/*** + FLOW CONTROL STATEMENTS (if, while, etc) SHOULD ***/
-/*** ALWAYS USE { AND } CHARACTERS!!! ***/
-/*** + Please use ' instead of ", when possible. Note " ***/
-/*** should always be used in _( ) function calls. ***/
-/*** Thank you for your help making the SM code more readable. ***/
-/*****************************************************************/
+ */
require_once('../src/validate.php');
require_once('../functions/imap.php');
require_once('../functions/mime.php');
require_once('../functions/date.php');
require_once('../functions/url_parser.php');
-
- /**
- * Given an IMAP message id number, this will look it up in the cached
- * and sorted msgs array and return the index. Used for finding the next
- * and previous messages.
- *
- * returns the index of the next valid message from the array
- */
- function findNextMessage() {
- global $msort, $currentArrayIndex, $msgs, $sort;
- $result = -1;
-
- if ($sort == 6) {
- if ($currentArrayIndex != 1) {
- $result = $currentArrayIndex - 1;
- }
- } else {
- for (reset($msort); ($key = key($msort)), (isset($key)); next($msort)) {
- if ($currentArrayIndex == $msgs[$key]['ID']) {
- next($msort);
- $key = key($msort);
- if (isset($key))
- $result = $msgs[$key]['ID'];
- break;
- }
+require_once('../functions/smtp.php');
+
+/**
+* Given an IMAP message id number, this will look it up in the cached
+* and sorted msgs array and return the index. Used for finding the next
+* and previous messages.
+*
+* returns the index of the next valid message from the array
+*/
+function findNextMessage() {
+ global $msort, $currentArrayIndex, $msgs, $sort;
+ $result = -1;
+
+ if ($sort == 6) {
+ if ($currentArrayIndex != 1) {
+ $result = $currentArrayIndex - 1;
+ }
+ } else {
+ for (reset($msort); ($key = key($msort)), (isset($key)); next($msort)) {
+ if ($currentArrayIndex == $msgs[$key]['ID']) {
+ next($msort);
+ $key = key($msort);
+ if (isset($key))
+ $result = $msgs[$key]['ID'];
+ break;
}
}
- return ($result);
}
+ return ($result);
+}
+
+/** Removes just one address from the list of addresses. */
+function RemoveAddress(&$addr_list, $addr) {
+ if ($addr != '') {
+ foreach (array_keys($addr_list, $addr) as $key_to_delete) {
+ unset($addr_list[$key_to_delete]);
+ }
+ }
+}
- /** Removes just one address from the list of addresses. */
- function RemoveAddress(&$addr_list, $addr) {
- if ($addr != '') {
- foreach (array_keys($addr_list, $addr) as $key_to_delete) {
- unset($addr_list[$key_to_delete]);
- }
+/** returns the index of the previous message from the array. */
+function findPreviousMessage() {
+ global $msort, $currentArrayIndex, $sort, $msgs, $imapConnection,
+ $mailbox, $data_dir, $username;
+
+ $result = -1;
+
+ if ($sort == 6) {
+ $numMessages = sqimap_get_num_messages($imapConnection, $mailbox);
+ if ($currentArrayIndex != $numMessages) {
+ $result = $currentArrayIndex + 1;
}
- }
-
- /** returns the index of the previous message from the array. */
- function findPreviousMessage() {
- global $msort, $currentArrayIndex, $sort, $msgs, $imapConnection;
- global $mailbox, $data_dir, $username;
- $result = -1;
-
- if ($sort == 6) {
- $numMessages = sqimap_get_num_messages($imapConnection, $mailbox);
- if ($currentArrayIndex != $numMessages) {
- $result = $currentArrayIndex + 1;
- }
- } else {
- for (reset($msort); ($key = key($msort)), (isset($key)); next($msort)) {
- if ($currentArrayIndex == $msgs[$key]['ID']) {
- prev($msort);
- $key = key($msort);
- if (isset($key)) {
- $result = $msgs[$key]['ID'];
- break;
- }
+ } else {
+ for (reset($msort); ($key = key($msort)), (isset($key)); next($msort)) {
+ if ($currentArrayIndex == $msgs[$key]['ID']) {
+ prev($msort);
+ $key = key($msort);
+ if (isset($key)) {
+ $result = $msgs[$key]['ID'];
+ break;
}
}
- }
- return ($result);
+ }
}
+ return ($result);
+}
- /**
- * Displays a link to a page where the message is displayed more
- * "printer friendly".
- */
- function printer_friendly_link() {
- global $passed_id, $mailbox, $ent_num, $color;
- global $pf_subtle_link;
- global $javascript_on;
+/**
+* Displays a link to a page where the message is displayed more
+* "printer friendly".
+*/
+function printer_friendly_link() {
+ global $passed_id, $mailbox, $ent_num, $color,
+ $pf_subtle_link,
+ $javascript_on;
+
+ if (strlen(trim($mailbox)) < 1) {
+ $mailbox = 'INBOX';
+ }
- if (strlen(trim($mailbox)) < 1) {
- $mailbox = 'INBOX';
- }
+ $params = '?passed_ent_id=' . $ent_num .
+ '&mailbox=' . urlencode($mailbox) .
+ '&passed_id=' . $passed_id;
- $params = '?passed_ent_id=' . $ent_num;
- $params .= '&mailbox=' . urlencode($mailbox);
- $params .= '&passed_id=' . $passed_id;
+ $print_text = _("View Printable Version");
- $print_text = _("View Printable Version");
+ if (!$pf_subtle_link) {
+ /* The link is large, on the bottom of the header panel. */
+ $result = '
' .
+ '' .
+ ' ' .
+ ' | '."\n";
+ } else {
+ /* The link is subtle, below "view full header". */
+ $result = " \n";
+ }
- if (!$pf_subtle_link) {
- /* The link is large, on the bottom of the header panel. */
- $result = ' |
' . "\n" .
- ' ' . "\n" .
- ' ' . "\n" .
- ' | '."\n";
- } else {
- /* The link is subtle, below "view full header". */
- $result = " \n";
- }
+ /* Output the link. */
+ if ($javascript_on) {
+ $result .= '\n" .
+ "$print_text\n";
+ } else {
+ $result .= '$print_text\n";
+ }
- /* Output the link. */
- if ($javascript_on) {
- $result .= '\n" .
- "$print_text\n";
- } else {
- $result .= '$print_text\n";
- }
+ if (!$pf_subtle_link) {
+ /* The link is large, on the bottom of the header panel. */
+ $result .= ' |
' . "\n";
+ }
- if (!$pf_subtle_link) {
- /* The link is large, on the bottom of the header panel. */
- $result .= ' ' . "\n" .
- ' ' . "\n";
+ return ($result);
+}
+
+function ServerMDNSupport( $read ) {
+
+ $num = 0;
+ $resp = '';
+ while ($num < count($read) ) {
+ $resp .= $read[$num];
+ $num++;
+ }
+ $read[] = split(' * ', $resp);
+ $num = 0;
+ $ret = FALSE;
+ while ( !$ret && $num < count($read) ) {
+ $ret = preg_match( '/.*PERMANENTFLAGS.*(MDNSent|\\\*).*/i', $read[$num] );
+ /*
+ if ( ereg('PERMANENTFLAGS', $read[$num] ) ) {
+ $ret = ( ereg('mdnsent',strtolower($read[$num]) ) || ereg("\\\*", $read[$num] ) );
}
+ */
+ $num++;
+ }
+ return ( $ret );
+}
+
+function SendMDN ( $recipient , $sender) {
+ global $imapConnection, $mailbox, $username, $attachment_dir, $SERVER_NAME,
+ $version, $attachments, $identity, $data_dir, $passed_id;
- return ($result);
+ $header = sqimap_get_message_header($imapConnection, $passed_id, $mailbox);
+ $hashed_attachment_dir = getHashedDir($username, $attachment_dir);
+
+ // part 1 (RFC2298)
+
+ $senton = getLongDateString( $header->date );
+ $to_array = $header->to;
+ $to = '';
+ foreach ($to_array as $line) {
+ $to .= " $line ";
}
- /*****************************/
- /*** Main of read_boby.php ***/
- /*****************************/
+ $subject = $header->subject;
+ $now = getLongDateString( time() );
+
+ $body = _("Your message") . "\r\n\r\n" .
+ "\t" . _("To:") . ' ' . $to . "\r\n" .
+ "\t" . _("Subject:") . ' ' . $subject . "\r\n" .
+ "\t" . _("Sent:") . ' ' . $senton . "\r\n" .
+ "\r\n" .
+ sprintf( _("Was displayed on %s"), $now );
+/*
+ $body = sprintf( _("This message sent on %s to %s with subject \"%s\" has been displayed on %s."),
+ $senton, $to, $subject, $now ) .
+ "\r\n" .
+ _("This is no guarantee that the message has been read or understood.") . "\r\n";
+*/
+ // part2 (RFC2298)
+
+ $original_recipient = $to;
+ $original_message_id = $header->message_id;
+
+ $part2 = "Reporting-UA : $SERVER_NAME ; SquirrelMail (version $version) \r\n";
+ if ($original_recipient != '') {
+ $part2 .= "Original-Recipient : $original_recipient\r\n";
+ }
+ $final_recipient = $sender;
+ $part2 .= "Final-Recipient: rfc822; $final_recipient\r\n" .
+ "Original-Message-ID : $original_message_id\r\n" .
+ "Disposition: manual-action/MDN-sent-manually; displayed\r\n";
+
+
+ $localfilename = GenerateRandomString(32, 'FILE', 7);
+ $full_localfilename = "$hashed_attachment_dir/$localfilename";
- $imapConnection = sqimap_login($username, $key, $imapServerAddress, $imapPort, 0);
+ $fp = fopen( $full_localfilename, 'w');
+ fwrite ($fp, $part2);
+ fclose($fp);
+
+ $newAttachment = array();
+ $newAttachment['localfilename'] = $localfilename;
+ $newAttachment['type'] = "message/disposition-notification";
+
+ $attachments[] = $newAttachment;
+ $MDN_to = trim($recipient);
+ $reply_id = 0;
+
+ return (SendMessage($MDN_to,'','', _("Read:") . ' ' . $subject, $body,$reply_id, True, 3) );
+}
+
+
+function ToggleMDNflag ( $set ) {
+
+ global $imapConnection, $passed_id, $mailbox;
+
+ if ( $set ) {
+ $sg = '+';
+
+ } else {
+ $sg = '-';
+ }
+
+ $cmd = 'STORE ' . $passed_id . ' ' . $sg . 'FLAGS ($MDNSent)';
sqimap_mailbox_select($imapConnection, $mailbox);
- do_hook('html_top');
- displayPageHeader($color, $mailbox);
-
- if (isset($view_hdr)) {
- fputs ($imapConnection, sqimap_session_id() . " FETCH $passed_id BODY[HEADER]\r\n");
- $read = sqimap_read_data ($imapConnection, sqimap_session_id(), true, $a, $b);
-
- echo '
' .
- '' . "\n" .
- " " . _("Viewing Full Header") . ' - ';
- if (isset($where) && isset($what)) {
- // Got here from a search
- echo "';
+ $read = sqimap_run_command ($imapConnection, $cmd, true, $response, $readmessage);
+
+}
+
+function ClearAttachments() {
+ global $username, $attachments, $attachment_dir;
+
+ $hashed_attachment_dir = getHashedDir($username, $attachment_dir);
+
+ foreach ($attachments as $info) {
+ $attached_file = "$hashed_attachment_dir/$info[localfilename]";
+ if (file_exists($attached_file)) {
+ unlink($attached_file);
+ }
+ }
+
+ $attachments = array();
+}
+
+
+/*
+ * Main of read_boby.php --------------------------------------------------
+ */
+
+/*
+ Urled vars
+ ----------
+ $passed_id
+*/
+
+$imapConnection = sqimap_login($username, $key, $imapServerAddress, $imapPort, 0);
+$read = sqimap_mailbox_select($imapConnection, $mailbox);
+
+do_hook('html_top');
+
+/*
+ * The following code sets necesarry stuff for the MDN thing
+ */
+if( $default_use_mdn &&
+ ( $mdn_user_support = getPref($data_dir, $username, 'mdn_user_support', $default_use_mdn) ) ) {
+
+ $supportMDN = ServerMDNSupport($read);
+ $flags = sqimap_get_flags ($imapConnection, $passed_id);
+ $FirstTimeSee = !(in_array( 'Seen', $flags ));
+}
+
+displayPageHeader($color, $mailbox);
+
+
+/*
+ * The following code shows the header of the message and then exit
+ */
+if (isset($view_hdr)) {
+ $read = sqimap_run_command ($imapConnection, "FETCH $passed_id BODY[HEADER]", true, $a, $b);
+
+ echo ' ' .
+ '\n" .
+ "\n" .
+ '';
+
+ $cnum = 0;
+ for ($i=1; $i < count($read); $i++) {
+ $line = htmlspecialchars($read[$i]);
+ if (eregi("^>", $line)) {
+ $second[$i] = $line;
+ $first[$i] = ' ';
+ $cnum++;
+ } else if (eregi("^[ |\t]", $line)) {
+ $second[$i] = $line;
+ $first[$i] = '';
+ } else if (eregi("^([^:]+):(.+)", $line, $regs)) {
+ $first[$i] = $regs[1] . ':';
+ $second[$i] = $regs[2];
+ $cnum++;
} else {
- echo "";
+ $second[$i] = trim($line);
+ $first[$i] = '';
}
- echo ''._("View message") . " | \n" .
- "\n" .
- '';
-
- $cnum = 0;
- for ($i=1; $i < count($read); $i++) {
- $line = htmlspecialchars($read[$i]);
- if (eregi("^>", $line)) {
- $second[$i] = $line;
- $first[$i] = ' ';
- $cnum++;
- } else if (eregi("^[ |\t]", $line)) {
- $second[$i] = $line;
- $first[$i] = '';
- } else if (eregi("^([^:]+):(.+)", $line, $regs)) {
- $first[$i] = $regs[1] . ':';
- $second[$i] = $regs[2];
- $cnum++;
- } else {
- $second[$i] = trim($line);
- $first[$i] = '';
- }
+ }
+ for ($i=0; $i < count($second); $i = $j) {
+ if (isset($first[$i])) {
+ $f = $first[$i];
}
- for ($i=0; $i < count($second); $i = $j) {
- if (isset($first[$i])) {
- $f = $first[$i];
- }
- if (isset($second[$i])) {
- $s = nl2br($second[$i]);
- }
- $j = $i + 1;
- while (($first[$j] == '') && ($j < count($first))) {
- $s .= ' ' . nl2br($second[$j]);
- $j++;
- }
- parseEmail($s);
- if (isset($f)) echo "$f$s";
+ if (isset($second[$i])) {
+ $s = nl2br($second[$i]);
+ }
+ $j = $i + 1;
+ while (($first[$j] == '') && ($j < count($first))) {
+ $s .= ' ' . nl2br($second[$j]);
+ $j++;
}
- echo " | \n";
- echo ' |