- Partially fixed "empty body" issue by showing raw body of malformed message (#1486166)

release-0.6
alecpl 15 years ago
parent a9bfe21ba6
commit 4f69328132

@ -1,6 +1,7 @@
CHANGELOG RoundCube Webmail CHANGELOG RoundCube Webmail
=========================== ===========================
- Partially fixed "empty body" issue by showing raw body of malformed message (#1486166)
- Fix importing/sending to email address with whitespace (#1486214) - Fix importing/sending to email address with whitespace (#1486214)
- Added XIMSS (CommuniGate) driver for Password plugin - Added XIMSS (CommuniGate) driver for Password plugin
- Fix newly attached files are not saved in drafts w/o editing any text (#1486202) - Fix newly attached files are not saved in drafts w/o editing any text (#1486202)

@ -1226,17 +1226,15 @@ class rcube_imap
else else
$this->struct_charset = $this->_structure_charset($structure); $this->struct_charset = $this->_structure_charset($structure);
/* // Here we can recognize malformed BODYSTRUCTURE and
@TODO: here we can recognize malformed BODYSTRUCTURE and parse // 1. [@TODO] parse the message in other way to create our own message structure
the message in other way to create our own message structure. // 2. or just show the raw message body.
Example of structure for malformed MIME message: // Example of structure for malformed MIME message:
("text" "plain" ("charset" "us-ascii") NIL NIL "7bit" 2154 70 NIL NIL NIL) // ("text" "plain" ("charset" "us-ascii") NIL NIL "7bit" 2154 70 NIL NIL NIL)
if ($headers->ctype && $headers->ctype != 'text/plain'
if ($headers->ctype != 'text/plain' && $structure[0] == 'text' && $structure[1] == 'plain') {
&& !is_array($structure[0]) && $structure[0] == 'text' return false;
&& !is_array($structure[1]) && $structure[1] == 'plain') }
{ }
*/
$struct = &$this->_structure_part($structure); $struct = &$this->_structure_part($structure);
$struct->headers = get_object_vars($headers); $struct->headers = get_object_vars($headers);

@ -785,64 +785,76 @@ function rcmail_print_body($part, $p = array())
unset($data['body']); unset($data['body']);
// plaintext postprocessing // plaintext postprocessing
if ($part->ctype_secondary == 'plain') { if ($part->ctype_secondary == 'plain')
// make links and email-addresses clickable $body = rcmail_plain_body($body);
$replacements = new rcube_string_replacer;
// search for patterns like links and e-mail addresses
$body = preg_replace_callback($replacements->link_pattern, array($replacements, 'link_callback'), $body);
$body = preg_replace_callback($replacements->mailto_pattern, array($replacements, 'mailto_callback'), $body);
// split body into single lines
$a_lines = preg_split('/\r?\n/', $body);
$q_lines = array();
$quote_level = 0;
// find/mark quoted lines...
for ($n=0, $cnt=count($a_lines); $n < $cnt; $n++) {
$q = 0;
if ($a_lines[$n][0] == '>' && preg_match('/^(>+\s*)+/', $a_lines[$n], $regs)) {
$q = strlen(preg_replace('/\s/', '', $regs[0]));
$a_lines[$n] = substr($a_lines[$n], strlen($regs[0]));
if ($q > $quote_level)
$q_lines[$n]['quote'] = $q - $quote_level;
else if ($q < $quote_level)
$q_lines[$n]['endquote'] = $quote_level - $q;
}
else if ($quote_level > 0)
$q_lines[$n]['endquote'] = $quote_level;
$quote_level = $q; // allow post-processing of the message body
} $data = $RCMAIL->plugins->exec_hook('message_part_after', array('type' => $part->ctype_secondary, 'body' => $body) + $data);
// quote plain text
$body = Q(join("\n", $a_lines), 'replace', false);
// colorize signature return $data['type'] == 'html' ? $data['body'] : html::tag('pre', array(), $data['body']);
if (($sp = strrpos($body, '-- ')) !== false) }
if (($sp == 0 || $body[$sp-1] == "\n") && $body[$sp+3] == "\n") {
$body = substr($body, 0, max(0, $sp))
.'<span class="sig">'.substr($body, $sp).'</span>';
}
// colorize quoted lines /**
$a_lines = preg_split('/\n/', $body); * Handle links and citation marks in plain text message
foreach ($q_lines as $i => $q) *
if ($q['quote']) * @param string Plain text string
$a_lines[$i] = str_repeat('<blockquote>', $q['quote']) . $a_lines[$i]; * @return string Formatted HTML string
else if ($q['endquote']) */
$a_lines[$i] = str_repeat('</blockquote>', $q['endquote']) . $a_lines[$i]; function rcmail_plain_body($body)
{
// make links and email-addresses clickable
$replacements = new rcube_string_replacer;
// search for patterns like links and e-mail addresses
$body = preg_replace_callback($replacements->link_pattern, array($replacements, 'link_callback'), $body);
$body = preg_replace_callback($replacements->mailto_pattern, array($replacements, 'mailto_callback'), $body);
// split body into single lines
$a_lines = preg_split('/\r?\n/', $body);
$q_lines = array();
$quote_level = 0;
// find/mark quoted lines...
for ($n=0, $cnt=count($a_lines); $n < $cnt; $n++) {
$q = 0;
if ($a_lines[$n][0] == '>' && preg_match('/^(>+\s*)+/', $a_lines[$n], $regs)) {
$q = strlen(preg_replace('/\s/', '', $regs[0]));
$a_lines[$n] = substr($a_lines[$n], strlen($regs[0]));
if ($q > $quote_level)
$q_lines[$n]['quote'] = $q - $quote_level;
else if ($q < $quote_level)
$q_lines[$n]['endquote'] = $quote_level - $q;
}
else if ($quote_level > 0)
$q_lines[$n]['endquote'] = $quote_level;
// insert the links for urls and mailtos $quote_level = $q;
$body = $replacements->resolve(join("\n", $a_lines));
} }
// allow post-processing of the message body // quote plain text
$data = $RCMAIL->plugins->exec_hook('message_part_after', array('type' => $part->ctype_secondary, 'body' => $body) + $data); $body = Q(join("\n", $a_lines), 'replace', false);
return $data['type'] == 'html' ? $data['body'] : html::tag('pre', array(), $data['body']); // colorize signature
if (($sp = strrpos($body, '-- ')) !== false)
if (($sp == 0 || $body[$sp-1] == "\n") && $body[$sp+3] == "\n") {
$body = substr($body, 0, max(0, $sp))
.'<span class="sig">'.substr($body, $sp).'</span>';
}
// colorize quoted lines
$a_lines = preg_split('/\n/', $body);
foreach ($q_lines as $i => $q)
if ($q['quote'])
$a_lines[$i] = str_repeat('<blockquote>', $q['quote']) . $a_lines[$i];
else if ($q['endquote'])
$a_lines[$i] = str_repeat('</blockquote>', $q['endquote']) . $a_lines[$i];
// insert the links for urls and mailtos
$body = $replacements->resolve(join("\n", $a_lines));
return $body;
} }
@ -1027,7 +1039,8 @@ function rcmail_message_body($attrib)
} }
} }
else else
$out .= html::div('message-part', html::tag('pre', array(), Q($MESSAGE->body))); $out .= html::div('message-part', html::tag('pre', array(),
rcmail_plain_body(Q($MESSAGE->body, 'strict', false))));
$ctype_primary = strtolower($MESSAGE->structure->ctype_primary); $ctype_primary = strtolower($MESSAGE->structure->ctype_primary);
$ctype_secondary = strtolower($MESSAGE->structure->ctype_secondary); $ctype_secondary = strtolower($MESSAGE->structure->ctype_secondary);

Loading…
Cancel
Save