Merge pull request #1836 from k9mail/multipart-digest-content-type

Properly handle multipart/digest content type
This commit is contained in:
cketti 2016-12-09 00:18:59 +01:00 committed by GitHub
commit 87e13ef800
2 changed files with 76 additions and 1 deletions

View file

@ -4,6 +4,7 @@ package com.fsck.k9.mail.internet;
import com.fsck.k9.mail.Body; import com.fsck.k9.mail.Body;
import com.fsck.k9.mail.BodyPart; import com.fsck.k9.mail.BodyPart;
import com.fsck.k9.mail.MessagingException; import com.fsck.k9.mail.MessagingException;
import com.fsck.k9.mail.Multipart;
import java.io.BufferedWriter; import java.io.BufferedWriter;
import java.io.IOException; import java.io.IOException;
@ -93,7 +94,14 @@ public class MimeBodyPart extends BodyPart {
@Override @Override
public String getContentType() { public String getContentType() {
String contentType = getFirstHeader(MimeHeader.HEADER_CONTENT_TYPE); String contentType = getFirstHeader(MimeHeader.HEADER_CONTENT_TYPE);
return (contentType == null) ? "text/plain" : MimeUtility.unfoldAndDecode(contentType); if (contentType != null) {
return MimeUtility.unfoldAndDecode(contentType);
}
Multipart parent = getParent();
if (parent != null && "multipart/digest".equals(parent.getMimeType())) {
return "message/rfc822";
}
return "text/plain";
} }
@Override @Override

View file

@ -1,6 +1,7 @@
package com.fsck.k9.mailstore; package com.fsck.k9.mailstore;
import java.io.ByteArrayInputStream;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Date; import java.util.Date;
import java.util.List; import java.util.List;
@ -25,6 +26,7 @@ import com.fsck.k9.mail.internet.MimeMessageHelper;
import com.fsck.k9.mail.internet.MimeMultipart; import com.fsck.k9.mail.internet.MimeMultipart;
import com.fsck.k9.mail.internet.TextBody; import com.fsck.k9.mail.internet.TextBody;
import com.fsck.k9.mail.internet.Viewable; import com.fsck.k9.mail.internet.Viewable;
import com.fsck.k9.mail.internet.Viewable.MessageHeader;
import com.fsck.k9.mailstore.MessageViewInfoExtractor.ViewableExtractedText; import com.fsck.k9.mailstore.MessageViewInfoExtractor.ViewableExtractedText;
import org.junit.Before; import org.junit.Before;
import org.junit.Test; import org.junit.Test;
@ -266,6 +268,71 @@ public class MessageViewInfoExtractorTest {
assertEquals(expectedHtml, getHtmlBodyText(container.html)); assertEquals(expectedHtml, getHtmlBodyText(container.html));
} }
@Test
public void testMultipartDigestWithMessages() throws Exception {
String data = "Content-Type: multipart/digest; boundary=\"bndry\"\r\n" +
"\r\n" +
"--bndry\r\n" +
"\r\n" +
"Content-Type: text/plain\r\n" +
"\r\n" +
"text body of first message\r\n" +
"\r\n" +
"--bndry\r\n" +
"\r\n" +
"Subject: subject of second message\r\n" +
"Content-Type: multipart/alternative; boundary=\"bndry2\"\r\n" +
"\r\n" +
"--bndry2\r\n" +
"Content-Type: text/plain\r\n" +
"\r\n" +
"text part of second message\r\n" +
"\r\n" +
"--bndry2\r\n" +
"Content-Type: text/html\"\r\n" +
"\r\n" +
"html part of second message\r\n" +
"\r\n" +
"--bndry2--\r\n" +
"\r\n" +
"--bndry--\r\n";
MimeMessage message = MimeMessage.parseMimeMessage(new ByteArrayInputStream(data.getBytes()), false);
// Extract text
List<Part> outputNonViewableParts = new ArrayList<>();
ArrayList<Viewable> outputViewableParts = new ArrayList<>();
MessageExtractor.findViewablesAndAttachments(message, outputViewableParts, outputNonViewableParts);
String expectedExtractedText = "Subject: (No subject)\r\n" +
"\r\n" +
"text body of first message\r\n" +
"\r\n" +
"\r\n" +
"------------------------------------------------------------------------\r\n" +
"\r\n" +
"Subject: subject of second message\r\n" +
"\r\n" +
"text part of second message\r\n";
String expectedHtmlText = "<table style=\"border: 0\">" +
"<tr><th style=\"text-align: left; vertical-align: top;\">Subject:</th><td>(No subject)</td></tr>" +
"</table>" +
"<pre class=\"k9mail\">text body of first message<br /></pre>" +
"<p style=\"margin-top: 2.5em; margin-bottom: 1em; border-bottom: 1px solid #000\"></p>" +
"<table style=\"border: 0\">" +
"<tr><th style=\"text-align: left; vertical-align: top;\">Subject:</th><td>subject of second message</td></tr>" +
"</table>" +
"<pre class=\"k9mail\">text part of second message<br /></pre>";
assertEquals(4, outputViewableParts.size());
assertEquals("subject of second message", ((MessageHeader) outputViewableParts.get(2)).getMessage().getSubject());
ViewableExtractedText firstMessageExtractedText =
messageViewInfoExtractor.extractTextFromViewables(outputViewableParts);
assertEquals(expectedExtractedText, firstMessageExtractedText.text);
assertEquals(expectedHtmlText, getHtmlBodyText(firstMessageExtractedText.html));
}
private static String getHtmlBodyText(String htmlText) { private static String getHtmlBodyText(String htmlText) {
htmlText = htmlText.substring(htmlText.indexOf("<body>") +6); htmlText = htmlText.substring(htmlText.indexOf("<body>") +6);
htmlText = htmlText.substring(0, htmlText.indexOf("</body>")); htmlText = htmlText.substring(0, htmlText.indexOf("</body>"));