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:
Andy Stadler 2009-05-01 14:40:58 -07:00 committed by The Android Open Source Project
parent c5c2b96739
commit 9ba72bb00d
3 changed files with 55 additions and 7 deletions

View File

@ -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

View File

@ -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;

View File

@ -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;
}
}