summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorthomascube <thomas@roundcube.net>2009-08-27 08:08:27 +0000
committerthomascube <thomas@roundcube.net>2009-08-27 08:08:27 +0000
commit0816567dac1beb14bd5abc95a67f915583a99f33 (patch)
tree09266280b2a3dd284243b0f19e015217a2bffe60
parente0896df54040413d382100f68788469433baa5ae (diff)
Only allow images as 'inline' parts; list other parts as attachments if they have a valid mime type
-rw-r--r--program/include/rcube_message.php7
1 files changed, 4 insertions, 3 deletions
diff --git a/program/include/rcube_message.php b/program/include/rcube_message.php
index 0c469457c..7c2457e55 100644
--- a/program/include/rcube_message.php
+++ b/program/include/rcube_message.php
@@ -392,16 +392,17 @@ class rcube_message
// part belongs to a related message and is linked
if ($message_ctype_secondary == 'related'
- && ($mail_part->headers['content-id'] || $mail_part->headers['content-location'])) {
+ && preg_match('!^image/!', $mail_part->mimetype)
+ && ($mail_part->headers['content-id'] || $mail_part->headers['content-location'])) {
if ($mail_part->headers['content-id'])
$mail_part->content_id = preg_replace(array('/^</', '/>$/'), '', $mail_part->headers['content-id']);
if ($mail_part->headers['content-location'])
$mail_part->content_location = $mail_part->headers['content-base'] . $mail_part->headers['content-location'];
-
+
$this->inline_parts[] = $mail_part;
}
// is a regular attachment
- else {
+ else if (preg_match('!^[a-z]+/[a-z0-9-.]+$!i', $mail_part->mimetype)) {
if (!$mail_part->filename)
$mail_part->filename = 'Part '.$mail_part->mime_id;
$this->attachments[] = $mail_part;