X-Git-Url: https://vcs.fsf.org/?p=squirrelmail.git;a=blobdiff_plain;f=src%2Fdownload.php;h=655aa76ee770ea4199b86c12cafa474e66c0dd64;hp=e7c2dc3611755e1ab912f152879365cd452aeb7d;hb=a820ac9dc88f67eed1a9d9bac551e91d1c6b7d96;hpb=202bcbcc2b67c7c153db1b09b608b62beeba0496 diff --git a/src/download.php b/src/download.php index e7c2dc36..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; @@ -133,6 +139,18 @@ if (strlen($filename) < 1) { $filename = $filename . '.' . $suffix; } +/** + * Update mailbox_cache and close session in order to prevent + * script locking on larger downloads. SendDownloadHeaders() and + * mime_print_body_lines() don't write information to session. + * mime_print_body_lines() call duration depends on size of + * attachment and script can cause interface lockups, if session + * is not closed. + */ +$mailbox_cache[$aMailbox['NAME']] = $aMailbox; +sqsession_register($mailbox_cache,'mailbox_cache'); +session_write_close(); + /* * Note: * The following sections display the attachment in different @@ -155,8 +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); -$mailbox_cache[$aMailbox['NAME']] = $aMailbox; -sqsession_register($mailbox_cache,'mailbox_cache'); +mime_print_body_lines ($imapConnection, $passed_id, $ent_id, $encoding, 'php://stdout', $force_crlf); -?> \ No newline at end of file