From 0132856e673d5fd79a33b3bbc6fa8c06ffc679ea Mon Sep 17 00:00:00 2001 From: Anthony Lee Date: Wed, 26 Feb 2014 08:57:53 -0800 Subject: [PATCH] Changed the IEmailService interface to accept and accountId in the loadAttachment() call. This work was necessary to support the new EasService & EasOperation infrastructure. Change-Id: Idd507aec999596ccd4afa5f03ff2b3c2e38a9029 (cherry picked from commit efac8255ed75d22e60036e19e7a95f8407d18ad3) --- .../com/android/emailcommon/service/EmailServiceProxy.java | 7 ++++--- .../src/com/android/emailcommon/service/IEmailService.aidl | 3 ++- .../android/email/service/AttachmentDownloadService.java | 2 +- src/com/android/email/service/EmailServiceStub.java | 4 ++-- src/com/android/email/service/EmailServiceUtils.java | 4 ++-- src/com/android/email/service/Pop3Service.java | 4 ++-- 6 files changed, 13 insertions(+), 11 deletions(-) diff --git a/emailcommon/src/com/android/emailcommon/service/EmailServiceProxy.java b/emailcommon/src/com/android/emailcommon/service/EmailServiceProxy.java index c5442947d..a41f17d1e 100644 --- a/emailcommon/src/com/android/emailcommon/service/EmailServiceProxy.java +++ b/emailcommon/src/com/android/emailcommon/service/EmailServiceProxy.java @@ -108,19 +108,20 @@ public class EmailServiceProxy extends ServiceProxy implements IEmailService { * possible. * * @param cb The {@link IEmailServiceCallback} to use for this operation. + * @param accountId the id of the account in question * @param attachmentId the id of the attachment record * @param background whether or not this request corresponds to a background action (i.e. * prefetch) vs a foreground action (user request) */ @Override - public void loadAttachment(final IEmailServiceCallback cb, final long attachmentId, - final boolean background) + public void loadAttachment(final IEmailServiceCallback cb, final long accountId, + final long attachmentId, final boolean background) throws RemoteException { setTask(new ProxyTask() { @Override public void run() throws RemoteException { try { - mService.loadAttachment(cb, attachmentId, background); + mService.loadAttachment(cb, accountId, attachmentId, background); } catch (RemoteException e) { try { // Try to send a callback (if set) diff --git a/emailcommon/src/com/android/emailcommon/service/IEmailService.aidl b/emailcommon/src/com/android/emailcommon/service/IEmailService.aidl index 2e2ea46de..bb4041e13 100644 --- a/emailcommon/src/com/android/emailcommon/service/IEmailService.aidl +++ b/emailcommon/src/com/android/emailcommon/service/IEmailService.aidl @@ -27,7 +27,8 @@ interface IEmailService { // Core email operations. // TODO: is sendMail really necessary, or should we standardize on sync(outbox)? void sendMail(long accountId); - oneway void loadAttachment(IEmailServiceCallback cb, long attachmentId, boolean background); + oneway void loadAttachment(IEmailServiceCallback cb, long accountId, long attachmentId, + boolean background); oneway void updateFolderList(long accountId); // Push-related functionality. diff --git a/src/com/android/email/service/AttachmentDownloadService.java b/src/com/android/email/service/AttachmentDownloadService.java index 76bd11650..60f880b5f 100644 --- a/src/com/android/email/service/AttachmentDownloadService.java +++ b/src/com/android/email/service/AttachmentDownloadService.java @@ -537,7 +537,7 @@ public class AttachmentDownloadService extends Service implements Runnable { req.startTime = System.currentTimeMillis(); req.inProgress = true; mDownloadsInProgress.put(req.attachmentId, req); - service.loadAttachment(mServiceCallback, req.attachmentId, + service.loadAttachment(mServiceCallback, req.accountId, req.attachmentId, req.priority != PRIORITY_FOREGROUND); setWatchdogAlarm(); } diff --git a/src/com/android/email/service/EmailServiceStub.java b/src/com/android/email/service/EmailServiceStub.java index d5b29355d..bd278ed84 100644 --- a/src/com/android/email/service/EmailServiceStub.java +++ b/src/com/android/email/service/EmailServiceStub.java @@ -119,8 +119,8 @@ public abstract class EmailServiceStub extends IEmailService.Stub implements IEm } @Override - public void loadAttachment(final IEmailServiceCallback cb, final long attachmentId, - final boolean background) throws RemoteException { + public void loadAttachment(final IEmailServiceCallback cb, final long accountId, + final long attachmentId, final boolean background) throws RemoteException { Folder remoteFolder = null; try { //1. Check if the attachment is already here and return early in that case diff --git a/src/com/android/email/service/EmailServiceUtils.java b/src/com/android/email/service/EmailServiceUtils.java index 0996c9ebc..2d70a2a19 100644 --- a/src/com/android/email/service/EmailServiceUtils.java +++ b/src/com/android/email/service/EmailServiceUtils.java @@ -634,8 +634,8 @@ public class EmailServiceUtils { } @Override - public void loadAttachment(final IEmailServiceCallback cb, final long attachmentId, - final boolean background) throws RemoteException { + public void loadAttachment(final IEmailServiceCallback cb, final long accountId, + final long attachmentId, final boolean background) throws RemoteException { } @Override diff --git a/src/com/android/email/service/Pop3Service.java b/src/com/android/email/service/Pop3Service.java index 7bff8001b..d94146ed9 100644 --- a/src/com/android/email/service/Pop3Service.java +++ b/src/com/android/email/service/Pop3Service.java @@ -76,8 +76,8 @@ public class Pop3Service extends Service { */ private final EmailServiceStub mBinder = new EmailServiceStub() { @Override - public void loadAttachment(final IEmailServiceCallback callback, final long attachmentId, - final boolean background) throws RemoteException { + public void loadAttachment(final IEmailServiceCallback callback, final long accountId, + final long attachmentId, final boolean background) throws RemoteException { Attachment att = Attachment.restoreAttachmentWithId(mContext, attachmentId); if (att == null || att.mUiState != AttachmentState.DOWNLOADING) return; long inboxId = Mailbox.findMailboxOfType(mContext, att.mAccountKey, Mailbox.TYPE_INBOX);