AI 148204: Encapsulate a requirement for some remote stores, that need to preload
message structures before fetching the message body. Code for IMAP & POP3 is unaffected, but remote stores can override requireStructurePrefetch() in order to trigger the new behavior. BUG=1807499 Automated import of CL 148204
This commit is contained in:
parent
c5c2b96739
commit
9ba72bb00d
@ -1232,15 +1232,42 @@ public class MessagingController implements Runnable {
|
||||
Folder remoteFolder = remoteStore.getFolder(folder);
|
||||
remoteFolder.open(OpenMode.READ_WRITE, localFolder.getPersistentCallbacks());
|
||||
|
||||
// Get the remote message and fully download it
|
||||
Message remoteMessage = remoteFolder.getMessage(uid);
|
||||
// Get the remote message and fully download it (and save into local store)
|
||||
|
||||
if (remoteStore.requireStructurePrefetch()) {
|
||||
// For remote stores that require it, prefetch the message structure.
|
||||
FetchProfile fp = new FetchProfile();
|
||||
fp.add(FetchProfile.Item.STRUCTURE);
|
||||
localFolder.fetch(new Message[] { message }, fp, null);
|
||||
|
||||
ArrayList<Part> viewables = new ArrayList<Part>();
|
||||
ArrayList<Part> attachments = new ArrayList<Part>();
|
||||
MimeUtility.collectParts(message, viewables, attachments);
|
||||
fp.clear();
|
||||
for (Part part : viewables) {
|
||||
fp.add(part);
|
||||
}
|
||||
|
||||
remoteFolder.fetch(new Message[] { message }, fp, null);
|
||||
|
||||
// Store the updated message locally
|
||||
localFolder.updateMessage((LocalMessage)message);
|
||||
|
||||
} else {
|
||||
// Most remote stores can directly obtain the message using only uid
|
||||
Message remoteMessage = remoteFolder.getMessage(uid);
|
||||
FetchProfile fp = new FetchProfile();
|
||||
fp.add(FetchProfile.Item.BODY);
|
||||
remoteFolder.fetch(new Message[] { remoteMessage }, fp, null);
|
||||
|
||||
// Store the message locally
|
||||
localFolder.appendMessages(new Message[] { remoteMessage });
|
||||
}
|
||||
|
||||
// Now obtain the local copy for further access & manipulation
|
||||
message = localFolder.getMessage(uid);
|
||||
FetchProfile fp = new FetchProfile();
|
||||
fp.add(FetchProfile.Item.BODY);
|
||||
remoteFolder.fetch(new Message[] { remoteMessage }, fp, null);
|
||||
|
||||
// Store the message locally and load the stored message into memory
|
||||
localFolder.appendMessages(new Message[] { remoteMessage });
|
||||
message = localFolder.getMessage(uid);
|
||||
localFolder.fetch(new Message[] { message }, fp, null);
|
||||
|
||||
// This is a view message request, so mark it read
|
||||
|
@ -200,6 +200,17 @@ public abstract class Store {
|
||||
return null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Some stores cannot download a message based only on the uid, and need the message structure
|
||||
* to be preloaded and provided to them. This method allows a remote store to signal this
|
||||
* requirement. Most stores do not need this and do not need to overload this method, which
|
||||
* simply returns "false" in the base class.
|
||||
* @return Return true if the remote store requires structure prefetch
|
||||
*/
|
||||
public boolean requireStructurePrefetch() {
|
||||
return false;
|
||||
}
|
||||
|
||||
public abstract Folder getFolder(String name) throws MessagingException;
|
||||
|
||||
public abstract Folder[] getPersonalNamespaces() throws MessagingException;
|
||||
|
@ -164,5 +164,15 @@ public class ExchangeStoreExample extends Store {
|
||||
public StoreSynchronizer getMessageSynchronizer() {
|
||||
return null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Inform MessagingController that this store requires message structures to be prefetched
|
||||
* before it can fetch message bodies (this is due to EAS protocol restrictions.)
|
||||
* @return always true for EAS
|
||||
*/
|
||||
@Override
|
||||
public boolean requireStructurePrefetch() {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user