X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=src%2Fdownload.php;h=bdd2a23c3b45448b5bebc8d64ef4735eceb0715a;hb=23279352b07104549202a97e8d9f69c96dfbfc96;hp=6f5c4266e92c65d8facc787f2f2b614b311aec4f;hpb=7e343a7db5fd4347901ff8fcaf529933dbc29f1c;p=squirrelmail.git
diff --git a/src/download.php b/src/download.php
index 6f5c4266..bdd2a23c 100644
--- a/src/download.php
+++ b/src/download.php
@@ -1,135 +1,142 @@
rfc822_header->subject;
+if ($ent_id) {
+ $message = &$message->getEntity($ent_id);
+ $header = $message->header;
+
+ if ($message->rfc822_header) {
+ $subject = $message->rfc822_header->subject;
+ } else {
+ $header = $message->header;
+ }
+ $type0 = $header->type0;
+ $type1 = $header->type1;
+ $encoding = strtolower($header->encoding);
+} else {
+ /* raw message */
+ $type0 = 'message';
+ $type1 = 'rfc822';
+ $encoding = 'US-ASCII';
+ $header = $message->header;
+}
+
+/*
+ * 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 = $header->disposition->getProperty('filename');
+ if (!$filename) {
+ $filename = $header->disposition->getProperty('name');
+ }
+ if (!$filename) {
+ $filename = $header->getParameter('name');
+ }
+} else {
+ $filename = $header->getParameter('name');
+}
+
+//$filename = decodeHeader($filename, false, false); //Don't want html output nor utf8 because it will return html output
+$filename = decodeHeader($filename, true, false); //Don't want html output
+if (strlen($filename) < 1) {
+ //$filename = decodeHeader($subject, false, false); //Don't want html output nor utf8 because it will return html output
+ $filename = decodeHeader($subject, true, false); //Don't want html output
+ 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 == 'rfc822' && $type0 == 'message')
+ $suffix = 'msg';
+ else
+ $suffix = $type1;
+
+ if ($filename == '')
+ $filename = 'untitled' . strip_tags($ent_id);
+ $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) {
+ SendDownloadHeaders($type0, $type1, $filename, 1);
+} else {
+ SendDownloadHeaders($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);
- if (!isset($config_php))
- include("../config/config.php");
- if (!isset($strings_php))
- include("../functions/strings.php");
- if (!isset($page_header_php))
- include("../functions/page_header.php");
- if (!isset($imap_php))
- include("../functions/imap.php");
- if (!isset($mime_php))
- include("../functions/mime.php");
- if (!isset($date_php))
- include("../functions/date.php");
-
- include("../src/load_prefs.php");
-
- function viewText($color, $body, $id, $entid, $mailbox, $type1, $wrap_at) {
- displayPageHeader($color, "None");
-
- echo "
";
- echo " |
";
- $urlmailbox = urlencode($mailbox);
- echo " "; - if ($type1 == "html") - echo $body; - else - echo translateText($body, $wrap_at); - - echo " |