From 29d7d09ffe8fb7a94fab0d00d9c5c2e762d8fcf7 Mon Sep 17 00:00:00 2001 From: Hadi Nategh Date: Mon, 14 May 2018 14:54:44 +0200 Subject: [PATCH] Make a bigger header size assumption (32k) in order to cover importing mails with big headers --- api/src/Mail.php | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/api/src/Mail.php b/api/src/Mail.php index 5fb306726f..2860d3cecb 100644 --- a/api/src/Mail.php +++ b/api/src/Mail.php @@ -7219,8 +7219,11 @@ class Mail //error_log(__METHOD__.__LINE__.':'.array2string($structure)); // unfortunately parseMessage does NOT return parsed headers (we assume header is shorter then 8k) - $start = is_string($message) ? substr($message, 0, 8192) : - (fseek($message, 0, SEEK_SET) == -1 ? '' : fread($message, 8192)); + // *** increase the header size limit to 32k to make sure most of the mails even with huge headers are + // covered. TODO: Not sure if we even need to cut of the header parts and not just passing the whole + // message to be parsed in order to get all headers, it needs more invetigation. + $start = is_string($message) ? substr($message, 0, 32768) : + (fseek($message, 0, SEEK_SET) == -1 ? '' : fread($message, 32768)); $length = strpos($start, Horde_Mime_Part::RFC_EOL.Horde_Mime_Part::RFC_EOL); if ($length===false) $length = strlen($start);