-
- $charset = $header->charset;
- $type0 = $header->type0;
- $type1 = $header->type1;
- if (isset($override_type0))
- $type0 = $override_type0;
- if (isset($override_type1))
- $type1 = $override_type1;
- $filename = decodeHeader($header->filename);
- if (!$filename) {
- $filename = decodeHeader($header->name);
- }
-
- if (strlen($filename) < 1) {
- if ($type1 == "plain" && $type0 == "text") $suffix = "txt";
- else if ($type1 == "richtext" && $type0 == "text") $suffix = "rtf";
- else if ($type1 == "postscript" && $type0 == "application") $suffix = "ps";
- else if ($type1 == "message" && $type0 == "rfc822") $suffix = "msg";
- else $suffix = $type1;
-
- $filename = "untitled$passed_ent_id.$suffix";
- }
-
- // Note:
- // The following sections display the attachment in different
- // ways depending on how they choose. The first way will download
- // under any circumstance. This sets the Content-type to be
- // applicatin/octet-stream, which should be interpreted by the
- // browser as "download me".
- // The second method (view) is used for images or other formats
- // that should be able to be handled by the browser. It will
- // most likely display the attachment inline inside the browser.
- // And finally, the third one will be used by default. If it
- // is displayable (text or html), it will load them up in a text
- // viewer (built in to squirrelmail). Otherwise, it sets the
- // content-type as application/octet-stream
-
- if (isset($absolute_dl) && $absolute_dl == "true") {
- switch($type0) {
- case "text":
- DumpHeaders($type0, $type1, $filename, 1);
- $body = mime_fetch_body($imapConnection, $passed_id, $passed_ent_id);
- $body = decodeBody($body, $header->encoding);
- if ($type1 == "plain" && isset($showHeaders)) {
- echo _("Subject") . ": " . decodeHeader($top_header->subject) . "\n";
- echo " " . _("From") . ": " . decodeHeader($top_header->from) . "\n";
- echo " " . _("To") . ": " . decodeHeader(getLineOfAddrs($top_header->to)) . "\n";
- echo " " . _("Date") . ": " . getLongDateString($top_header->date) . "\n\n";
- }
- elseif ($type1 == "html" && isset($showHeaders)) {
- echo '<table><tr><th align=right>' . _("Subject");
- echo ':</th><td>' . decodeHeader($top_header->subject);
- echo "</td></tr>\n<tr><th align=right>" . _("From");
- echo ':</th><td>' . decodeHeader($top_header->from);
- echo "</td></tr>\n<tr><th align=right>" . _("To");
- echo ':</th><td>' . decodeHeader(getLineOfAddrs($top_header->to));
- echo "</td></tr>\n<tr><th align=right>" . _("Date");
- echo ':</th><td>' . getLongDateString($top_header->date);
- echo "</td></tr>\n</table>\n<hr>\n";
- }
- echo $body;
- break;
- default:
- DumpHeaders($type0, $type1, $filename, 1);
- mime_print_body_lines ($imapConnection, $passed_id, $passed_ent_id, $header->encoding);
- break;
- }
- } else {
- switch ($type0) {
- case "text":
- if ($type1 == "plain" || $type1 == "html") {
- $body = mime_fetch_body($imapConnection, $passed_id, $passed_ent_id);
- $body = decodeBody($body, $header->encoding);
- viewText($color, $body, $passed_id, $passed_ent_id, $mailbox, $type1, $wrap_at);
- } else {
- DumpHeaders($type0, $type1, $filename, 0);
- $body = mime_fetch_body($imapConnection, $passed_id, $passed_ent_id);
- $body = decodeBody($body, $header->encoding);
- echo $body;
- }
- break;
- case "message":
- $body = mime_fetch_body($imapConnection, $passed_id, $passed_ent_id);
- $body = decodeBody($body, $header->encoding);
- viewText($color, $body, $passed_id, $passed_ent_id, $mailbox, $type1, $wrap_at);
- break;
- default:
- DumpHeaders($type0, $type1, $filename, 0);
- mime_print_body_lines ($imapConnection, $passed_id, $passed_ent_id, $header->encoding);
- break;
- }
- }
-
-
- // This function is verified to work with Netscape and the *very latest*
- // version of IE. I don't know if it works with Opera, but it should now.
- function DumpHeaders($type0, $type1, $filename, $force)
- {
- global $HTTP_USER_AGENT;
-
- $isIE = 0;
- if (strstr($HTTP_USER_AGENT, 'compatible; MSIE ') !== false &&
- strstr($HTTP_USER_AGENT, 'Opera') === false) {
+ $charset = $header->getParameter('charset');
+}
+$type0 = $header->type0;
+$type1 = $header->type1;
+$encoding = strtolower($header->encoding);
+
+/*
+ * lets redefine message as this particular entity that we wish to display.
+ * it should hold only the header for this entity. We need to fetch the body
+ * yet before we can display anything.
+ */
+
+if (isset($override_type0)) {
+ $type0 = $override_type0;
+}
+if (isset($override_type1)) {
+ $type1 = $override_type1;
+}
+$filename = '';
+if (is_object($message->header->disposition)) {
+ $filename = decodeHeader($header->disposition->getProperty('filename'));
+ if (!$filename) {
+ $filename = decodeHeader($header->disposition->getProperty('name'));
+ }
+}
+if (strlen($filename) < 1) {
+ if ($type1 == 'plain' && $type0 == 'text') {
+ $suffix = 'txt';
+ $filename = $subject . '.txt';
+ } else if ($type1 == 'richtext' && $type0 == 'text') {
+ $suffix = 'rtf';
+ $filename = $subject . '.rtf';
+ } else if ($type1 == 'postscript' && $type0 == 'application') {
+ $suffix = 'ps';
+ $filename = $subject . '.ps';
+ } else if ($type1 == 'rfc822' && $type0 == 'message') {
+ $suffix = 'eml';
+ $filename = $subject . '.msg';
+ } else {
+ $suffix = $type1;
+ }
+
+ if (strlen($filename) < 1) {
+ $filename = 'untitled'.strip_tags($ent_id).$suffix;
+ } else {
+ $filename = "$filename.$suffix";
+ }
+}
+
+/*
+ * Note:
+ * The following sections display the attachment in different
+ * ways depending on how they choose. The first way will download
+ * under any circumstance. This sets the Content-type to be
+ * applicatin/octet-stream, which should be interpreted by the
+ * browser as "download me".
+ * The second method (view) is used for images or other formats
+ * that should be able to be handled by the browser. It will
+ * most likely display the attachment inline inside the browser.
+ * And finally, the third one will be used by default. If it
+ * is displayable (text or html), it will load them up in a text
+ * viewer (built in to squirrelmail). Otherwise, it sets the
+ * content-type as application/octet-stream
+ */
+if (isset($absolute_dl) && $absolute_dl) {
+ DumpHeaders($type0, $type1, $filename, 1);
+} else {
+ DumpHeaders($type0, $type1, $filename, 0);
+}
+/* be aware that any warning caused by download.php will corrupt the
+ * attachment in case of ERROR reporting = E_ALL and the output is the screen */
+mime_print_body_lines ($imapConnection, $passed_id, $ent_id, $encoding);
+
+/*
+ * This function is verified to work with Netscape and the *very latest*
+ * version of IE. I don't know if it works with Opera, but it should now.
+ */
+function DumpHeaders($type0, $type1, $filename, $force) {
+ global $_SERVER, $languages, $squirrelmail_language;
+ $isIE = $isIE6 = 0;
+
+ $HTTP_USER_AGENT = $_SERVER['HTTP_USER_AGENT'];
+
+ if (strstr($HTTP_USER_AGENT, 'compatible; MSIE ') !== false &&
+ strstr($HTTP_USER_AGENT, 'Opera') === false) {