mirror of
https://github.com/moparisthebest/davmail
synced 2025-01-07 03:38:05 -05:00
IMAP: avoid full message download on OSX Lion flags request with content-class header
git-svn-id: http://svn.code.sf.net/p/davmail/code/trunk@1955 3d1905a2-6b24-0410-a738-b14d5a86fcbd
This commit is contained in:
parent
38476fe285
commit
fb6ceb24a2
@ -729,6 +729,8 @@ public abstract class ExchangeSession {
|
||||
IMAP_MESSAGE_ATTRIBUTES.add("deleted");
|
||||
IMAP_MESSAGE_ATTRIBUTES.add("date");
|
||||
IMAP_MESSAGE_ATTRIBUTES.add("lastmodified");
|
||||
// OSX IMAP requests content-class
|
||||
IMAP_MESSAGE_ATTRIBUTES.add("contentclass");
|
||||
}
|
||||
|
||||
protected static final Set<String> UID_MESSAGE_ATTRIBUTES = new HashSet<String>();
|
||||
@ -1632,6 +1634,10 @@ public abstract class ExchangeSession {
|
||||
* Message uid.
|
||||
*/
|
||||
public String uid;
|
||||
/**
|
||||
* Message content class.
|
||||
*/
|
||||
public String contentClass;
|
||||
/**
|
||||
* Message IMAP uid, unique in folder (x0e230003).
|
||||
*/
|
||||
|
@ -1996,6 +1996,7 @@ public class DavExchangeSession extends ExchangeSession {
|
||||
message.permanentUrl = getURLPropertyIfExists(properties, "permanenturl");
|
||||
message.size = getIntPropertyIfExists(properties, "messageSize");
|
||||
message.uid = getPropertyIfExists(properties, "uid");
|
||||
message.contentClass = getPropertyIfExists(properties, "contentclass");
|
||||
message.imapUid = getLongPropertyIfExists(properties, "imapUid");
|
||||
message.read = "1".equals(getPropertyIfExists(properties, "read"));
|
||||
message.junk = "1".equals(getPropertyIfExists(properties, "junk"));
|
||||
|
@ -568,6 +568,7 @@ public class EwsExchangeSession extends ExchangeSession {
|
||||
|
||||
message.size = response.getInt(Field.get("messageSize").getResponseName());
|
||||
message.uid = response.get(Field.get("uid").getResponseName());
|
||||
message.contentClass = response.get(Field.get("contentclass").getResponseName());
|
||||
message.imapUid = response.getLong(Field.get("imapUid").getResponseName());
|
||||
message.read = response.getBoolean(Field.get("read").getResponseName());
|
||||
message.junk = response.getBoolean(Field.get("junk").getResponseName());
|
||||
|
@ -418,7 +418,7 @@ public class ImapConnection extends AbstractConnection {
|
||||
session.moveMessage(message, targetName);
|
||||
}
|
||||
}
|
||||
sendClient(commandId + " OK "+command+" completed");
|
||||
sendClient(commandId + " OK " + command + " completed");
|
||||
}
|
||||
} catch (HttpException e) {
|
||||
sendClient(commandId + " NO " + e.getMessage());
|
||||
@ -753,8 +753,6 @@ public class ImapConnection extends AbstractConnection {
|
||||
InputStream partInputStream = null;
|
||||
OutputStream partOutputStream = null;
|
||||
|
||||
// load message
|
||||
MimeMessage mimeMessage = message.getMimeMessage();
|
||||
// try to parse message part index
|
||||
String partIndexString = StringUtil.getToken(param, "[", "]");
|
||||
if ("".equals(partIndexString) || partIndexString == null) {
|
||||
@ -764,24 +762,31 @@ public class ImapConnection extends AbstractConnection {
|
||||
} else if ("TEXT".equals(partIndexString)) {
|
||||
// write message without headers
|
||||
partOutputStream = new PartialOutputStream(baos, startIndex, maxSize);
|
||||
partInputStream = mimeMessage.getRawInputStream();
|
||||
partInputStream = message.getMimeMessage().getRawInputStream();
|
||||
} else if ("RFC822.HEADER".equals(param) || partIndexString.startsWith("HEADER")) {
|
||||
// Header requested fetch headers
|
||||
String[] requestedHeaders = getRequestedHeaders(partIndexString);
|
||||
if (requestedHeaders != null) {
|
||||
// OSX Lion special flags request
|
||||
if (requestedHeaders.length == 1 && "content-class".equals(requestedHeaders[0]) && message.contentClass != null) {
|
||||
baos.write(message.contentClass.getBytes("UTF-8"));
|
||||
baos.write(13);
|
||||
baos.write(10);
|
||||
} else {
|
||||
Enumeration headerEnumeration = message.getMimeMessage().getMatchingHeaderLines(requestedHeaders);
|
||||
while (headerEnumeration.hasMoreElements()) {
|
||||
baos.write(((String) headerEnumeration.nextElement()).getBytes("UTF-8"));
|
||||
baos.write(13);
|
||||
baos.write(10);
|
||||
}
|
||||
}
|
||||
} else {
|
||||
// write headers only
|
||||
partOutputStream = new PartOutputStream(baos, true, false, startIndex, maxSize);
|
||||
partInputStream = message.getRawInputStream();
|
||||
}
|
||||
} else {
|
||||
MimePart bodyPart = mimeMessage;
|
||||
MimePart bodyPart = message.getMimeMessage();
|
||||
String[] partIndexStrings = partIndexString.split("\\.");
|
||||
for (String subPartIndexString : partIndexStrings) {
|
||||
// ignore MIME subpart index, will return full part
|
||||
|
@ -363,5 +363,29 @@ public class TestImap extends AbstractImapTestCase {
|
||||
}
|
||||
|
||||
|
||||
public void testDraftMessageMessageId() throws IOException, InterruptedException, MessagingException {
|
||||
testCreateFolder();
|
||||
MimeMessage mimeMessage = new MimeMessage((Session) null);
|
||||
mimeMessage.addHeader("to", Settings.getProperty("davmail.to"));
|
||||
mimeMessage.setText("Test message");
|
||||
mimeMessage.setSubject("Test subject");
|
||||
ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
||||
mimeMessage.writeTo(baos);
|
||||
byte[] content = baos.toByteArray();
|
||||
writeLine(". APPEND testfolder (\\Seen \\Draft) {" + content.length + '}');
|
||||
assertEquals("+ send literal data", readLine());
|
||||
writeLine(new String(content));
|
||||
assertEquals(". OK APPEND completed", readFullAnswer("."));
|
||||
|
||||
writeLine(". UID SEARCH UNDELETED (HEADER Message-ID "+mimeMessage.getMessageID().substring(1, mimeMessage.getMessageID().length()-1)+")");
|
||||
assertEquals(". OK SEARCH completed", readFullAnswer("."));
|
||||
|
||||
testDeleteFolder();
|
||||
}
|
||||
|
||||
public void testFetchOSX() throws IOException {
|
||||
testSelectInbox();
|
||||
writeLine(". FETCH 1:* (FLAGS UID BODY.PEEK[HEADER.FIELDS (content-class)])");
|
||||
assertEquals(". OK FETCH completed", readFullAnswer("."));
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user