X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=program%2Fsteps%2Fmail%2Fviewsource.inc;h=38c3f6516b5b8a7d6e09fbdd8e1a5b87446b4060;hb=b68022ca3782d5eb5a1a7ef6f8cf7abe1dc15bd6;hp=c22f80ace77cca52eefa6db8fd2144fac1644ba3;hpb=1213c6e65f2bab1e140369839a9d0f6db28a9492;p=roundcube.git diff --git a/program/steps/mail/viewsource.inc b/program/steps/mail/viewsource.inc index c22f80a..38c3f65 100644 --- a/program/steps/mail/viewsource.inc +++ b/program/steps/mail/viewsource.inc @@ -15,10 +15,11 @@ | Author: Thomas Bruederli | +-----------------------------------------------------------------------+ - $Id: viewsource.inc 2237 2009-01-17 01:55:39Z till $ + $Id: viewsource.inc 2613 2009-06-05 13:34:07Z alec $ */ +ob_end_clean(); // similar code as in program/steps/mail/get.inc if ($uid = get_input_value('_uid', RCUBE_INPUT_GET)) @@ -26,6 +27,22 @@ if ($uid = get_input_value('_uid', RCUBE_INPUT_GET)) $headers = $IMAP->get_headers($uid); $charset = $headers->charset ? $headers->charset : $IMAP->default_charset; header("Content-Type: text/plain; charset={$charset}"); + + if (!empty($_GET['_save'])) { + $filename = ($headers->subject ? $IMAP->decode_header($headers->subject) : 'roundcube') . '.eml'; + $browser = new rcube_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