From 757d0e9c38cf65fef14be6c65877346ed5e871b5 Mon Sep 17 00:00:00 2001 From: Klaus Leithoff Date: Tue, 9 Sep 2014 14:06:24 +0000 Subject: [PATCH] fix for rare problem on toggle html2text resulting in empty content; preparation for REFERENCES and IN-REPLY-TO --- emailadmin/inc/class.emailadmin_imapbase.inc.php | 2 ++ mail/inc/class.mail_compose.inc.php | 14 ++++++++++---- 2 files changed, 12 insertions(+), 4 deletions(-) diff --git a/emailadmin/inc/class.emailadmin_imapbase.inc.php b/emailadmin/inc/class.emailadmin_imapbase.inc.php index feac4cd815..183342a23d 100644 --- a/emailadmin/inc/class.emailadmin_imapbase.inc.php +++ b/emailadmin/inc/class.emailadmin_imapbase.inc.php @@ -4624,6 +4624,8 @@ class emailadmin_imapbase 'SUBJECT' => ($decode ? self::decode_header($headers['SUBJECT']):$headers['SUBJECT']), 'MESSAGE_ID' => $headers['MESSAGE-ID'] ); + if (isset($headers['IN-REPLY-TO'])) $newData['IN-REPLY-TO'] = $headers['IN-REPLY-TO']; + if (isset($headers['REFERENCES'])) $newData['REFERENCES'] = $headers['REFERENCES']; //_debug_array($newData); $recepientList = array('FROM', 'TO', 'CC', 'BCC', 'SENDER', 'REPLY-TO'); foreach($recepientList as $recepientType) { diff --git a/mail/inc/class.mail_compose.inc.php b/mail/inc/class.mail_compose.inc.php index b88e21ddc4..0fb8fcb52b 100644 --- a/mail/inc/class.mail_compose.inc.php +++ b/mail/inc/class.mail_compose.inc.php @@ -479,11 +479,14 @@ class mail_compose if (stripos($content['mail_htmltext'],'
')!==false)
 			{
 				$contentArr = html::splithtmlByPRE($content['mail_htmltext']);
-				foreach ($contentArr as $k =>&$elem)
+				if (is_array($contentArr))
 				{
-					if (stripos($elem,'
')!==false) $elem = str_replace(array("\r\n","\n","\r"),array("
","
","
"),$elem); + foreach ($contentArr as $k =>&$elem) + { + if (stripos($elem,'
')!==false) $elem = str_replace(array("\r\n","\n","\r"),array("
","
","
"),$elem); + } + $content['mail_htmltext'] = implode('',$contentArr); } - $content['mail_htmltext'] = implode('',$contentArr); } $content['mail_htmltext'] = $this->_getCleanHTML($content['mail_htmltext'], false, false); $content['mail_htmltext'] = translation::convertHTMLToText($content['mail_htmltext'],$charset=false,$stripcrl=false,$stripalltags=true); @@ -1305,6 +1308,8 @@ class mail_compose $preserv['serverID'] = $content['serverID']; $preserv['lastDrafted'] = $content['lastDrafted']; $preserv['processedmail_id'] = $content['processedmail_id']; + $preserv['references'] = $content['references']; + $preserv['in-reply-to'] = $content['in-reply-to']; $preserv['mode'] = $content['mode']; // convert it back to checkbox expectations if($content['mimeType'] == 'html') { @@ -1945,7 +1950,8 @@ class mail_compose //$headers = $mail_bo->getMessageHeader($_uid, $_partID, true, true, $_folder); $this->sessionData['uid'] = $_uid; $this->sessionData['messageFolder'] = $_folder; - $this->sessionData['in-reply-to'] = $headers['MESSAGE_ID']; + $this->sessionData['in-reply-to'] = ($headers['IN-REPLY-TO']?$headers['IN-REPLY-TO']:$headers['MESSAGE_ID']); + $this->sessionData['references'] = ($headers['REFERENCES']?$headers['REFERENCES']:$headers['MESSAGE_ID']); //error_log(__METHOD__.__LINE__.' Mode:'.$_mode.':'.array2string($headers)); // check for Reply-To: header and use if available if(!empty($headers['REPLY-TO']) && ($headers['REPLY-TO'] != $headers['FROM'])) {