X-Git-Url: https://vcs.fsf.org/?p=squirrelmail.git;a=blobdiff_plain;f=src%2Fdownload.php;h=655aa76ee770ea4199b86c12cafa474e66c0dd64;hp=a90e97bec851143ef370f58eaecf690d90327cc2;hb=bbb2bab55dbfb58735b8aa3eab53c052410753fa;hpb=e4baf0ee0d63b4552db2964089bdf5e573afddfe diff --git a/src/download.php b/src/download.php index a90e97be..655aa76e 100644 --- a/src/download.php +++ b/src/download.php @@ -6,12 +6,15 @@ * Handles attachment downloads to the users computer. * Also allows displaying of attachments when possible. * - * @copyright © 1999-2006 The SquirrelMail Project Team + * @copyright © 1999-2009 The SquirrelMail Project Team * @license http://opensource.org/licenses/gpl-license.php GNU Public License * @version $Id$ * @package squirrelmail */ +/** This is the download page */ +define('PAGE_NAME', 'download'); + /** * Include the SquirrelMail initialization file. */ @@ -22,21 +25,30 @@ require(SM_PATH . 'functions/imap_general.php'); require(SM_PATH . 'functions/mailbox_display.php'); require(SM_PATH . 'functions/mime.php'); +/** + * If a message is viewed from the search page, $aMailbox[$passed_id]['MESSAGE_OBJECT'] + * is not initialized, which makes this page error out on line 65 with an + * undefined function. We need to include some additional files in case the + * object has not been initialized. + * + * TODO: Determine why the object in question is not initialized when coming from + * a search page and correct. Once that is done, we can remove these + * includes. + */ +require(SM_PATH . 'functions/imap_messages.php'); +require(SM_PATH . 'functions/date.php'); + header('Pragma: '); header('Cache-Control: cache'); /* globals */ -sqgetGlobalVar('key', $key, SQ_COOKIE); -sqgetGlobalVar('username', $username, SQ_SESSION); -sqgetGlobalVar('onetimepad', $onetimepad, SQ_SESSION); sqgetGlobalVar('mailbox_cache',$mailbox_cache,SQ_SESSION); sqgetGlobalVar('messages', $messages, SQ_SESSION); sqgetGlobalVar('mailbox', $mailbox, SQ_GET); sqgetGlobalVar('ent_id', $ent_id, SQ_GET); sqgetGlobalVar('absolute_dl',$absolute_dl, SQ_GET); -if ( sqgetGlobalVar('passed_id', $temp, SQ_GET) ) { - $passed_id = (int) $temp; -} +sqgetGlobalVar('force_crlf', $force_crlf, SQ_GET); +sqgetGlobalVar('passed_id', $passed_id, SQ_GET, NULL, SQ_TYPE_BIGINT); if (!sqgetGlobalVar('account', $account, SQ_GET) ) { $account = 0; } @@ -46,23 +58,17 @@ set_my_charset(); /* end globals */ -$imapConnection = sqimap_login($username, $key, $imapServerAddress, $imapPort, 0); +$imapConnection = sqimap_login($username, false, $imapServerAddress, $imapPort, 0); $aMailbox = sqm_api_mailbox_select($imapConnection, $account, $mailbox,array(),array()); if (isset($aMailbox['MSG_HEADERS'][$passed_id]['MESSAGE_OBJECT']) && is_object($aMailbox['MSG_HEADERS'][$passed_id]['MESSAGE_OBJECT']) ) { $message = $aMailbox['MSG_HEADERS'][$passed_id]['MESSAGE_OBJECT']; } else { - $message = sqimap_get_message($imapConnection, $passed_id, $mailbox); - $aMailbox['MSG_HEADERS'][$passed_id]['MESSAGE_OBJECT'] = $message; + $message = sqimap_get_message($imapConnection, $passed_id, $mailbox); + $aMailbox['MSG_HEADERS'][$passed_id]['MESSAGE_OBJECT'] = $message; } -//$mbx_response = sqimap_mailbox_select($imapConnection, $mailbox); - -//$message = &$messages[$mbx_response['UIDVALIDITY']]["$passed_id"]; -//if (!is_object($message)) { -// $message = sqimap_get_message($imapConnection,$passed_id, $mailbox); -//} $subject = $message->rfc822_header->subject; if ($ent_id) { // replace message with message part, if message part is requested. @@ -81,7 +87,7 @@ if ($ent_id) { /* raw message */ $type0 = 'message'; $type1 = 'rfc822'; - $encoding = 'US-ASCII'; + $encoding = '7bit'; $header = $message->header; } @@ -124,7 +130,7 @@ if (strlen($filename) < 1) { else if ($type1 == 'postscript' && $type0 == 'application') $suffix = 'ps'; else if ($type1 == 'rfc822' && $type0 == 'message') - $suffix = 'msg'; + $suffix = 'eml'; else $suffix = $type1; @@ -167,6 +173,5 @@ if (isset($absolute_dl) && $absolute_dl) { } /* 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); +mime_print_body_lines ($imapConnection, $passed_id, $ent_id, $encoding, 'php://stdout', $force_crlf); -?> \ No newline at end of file