X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=program%2Fsteps%2Fmail%2Fviewsource.inc;h=62992cbb7a3812d532aac49f9893c93cc6fef3a0;hb=a2dd2e41259a5e90016efcd7d083020b95e25527;hp=79de995160bd2201bd224067fed6bd9d755743e8;hpb=48e8459231a1efa3e97284d07a328776a5b7485b;p=roundcube.git diff --git a/program/steps/mail/viewsource.inc b/program/steps/mail/viewsource.inc index 79de995..62992cb 100644 --- a/program/steps/mail/viewsource.inc +++ b/program/steps/mail/viewsource.inc @@ -4,8 +4,8 @@ +-----------------------------------------------------------------------+ | program/steps/mail/viewsource.inc | | | - | This file is part of the RoundCube Webmail client | - | Copyright (C) 2005-2008, RoundCube Dev. - Switzerland | + | This file is part of the Roundcube Webmail client | + | Copyright (C) 2005-2009, The Roundcube Dev Team | | Licensed under the GNU GPL | | | | PURPOSE: | @@ -15,17 +15,34 @@ | Author: Thomas Bruederli | +-----------------------------------------------------------------------+ - $Id: viewsource.inc 1195 2008-03-21 11:45:46Z thomasb $ + $Id: viewsource.inc 4410 2011-01-12 18:25:02Z thomasb $ */ +ob_end_clean(); // similar code as in program/steps/mail/get.inc if ($uid = get_input_value('_uid', RCUBE_INPUT_GET)) { $headers = $IMAP->get_headers($uid); - $charset = $headers->charset ? $headers->charset : $IMAP->default_charset; + $charset = $headers->charset ? $headers->charset : $CONFIG['default_charset']; header("Content-Type: text/plain; charset={$charset}"); + + if (!empty($_GET['_save'])) { + $filename = ($headers->subject ? $IMAP->decode_header($headers->subject) : 'roundcube') . '.eml'; + $browser = $RCMAIL->output->browser; + + if ($browser->ie && $browser->ver < 7) + $filename = rawurlencode(abbreviate_string($filename, 55)); + else if ($browser->ie) + $filename = rawurlencode($filename); + else + $filename = addcslashes($filename, '"'); + + header("Content-Length: {$headers->size}"); + header("Content-Disposition: attachment; filename=\"$filename\""); + } + $IMAP->print_raw_body($uid); } else @@ -33,10 +50,10 @@ else raise_error(array( 'code' => 500, 'type' => 'php', + 'file' => __FILE__, 'line' => __LINE__, 'message' => 'Message UID '.$uid.' not found'), - true, - true); + true, true); } exit; -?> +