PopImapSyncAdapterService.java revision 0dffe3afd7a2fdfb394573aa0d8d06dd90e9fe12
15c523858385176c33a7456bb84035de78552d22dMarc Blank/*
25c523858385176c33a7456bb84035de78552d22dMarc Blank * Copyright (C) 2010 The Android Open Source Project
35c523858385176c33a7456bb84035de78552d22dMarc Blank *
45c523858385176c33a7456bb84035de78552d22dMarc Blank * Licensed under the Apache License, Version 2.0 (the "License");
55c523858385176c33a7456bb84035de78552d22dMarc Blank * you may not use this file except in compliance with the License.
65c523858385176c33a7456bb84035de78552d22dMarc Blank * You may obtain a copy of the License at
75c523858385176c33a7456bb84035de78552d22dMarc Blank *
85c523858385176c33a7456bb84035de78552d22dMarc Blank *      http://www.apache.org/licenses/LICENSE-2.0
95c523858385176c33a7456bb84035de78552d22dMarc Blank *
105c523858385176c33a7456bb84035de78552d22dMarc Blank * Unless required by applicable law or agreed to in writing, software
115c523858385176c33a7456bb84035de78552d22dMarc Blank * distributed under the License is distributed on an "AS IS" BASIS,
125c523858385176c33a7456bb84035de78552d22dMarc Blank * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
135c523858385176c33a7456bb84035de78552d22dMarc Blank * See the License for the specific language governing permissions and
145c523858385176c33a7456bb84035de78552d22dMarc Blank * limitations under the License.
155c523858385176c33a7456bb84035de78552d22dMarc Blank */
165c523858385176c33a7456bb84035de78552d22dMarc Blank
175c523858385176c33a7456bb84035de78552d22dMarc Blankpackage com.android.email.service;
185c523858385176c33a7456bb84035de78552d22dMarc Blank
195c523858385176c33a7456bb84035de78552d22dMarc Blankimport android.app.Service;
205c523858385176c33a7456bb84035de78552d22dMarc Blankimport android.content.AbstractThreadedSyncAdapter;
215c523858385176c33a7456bb84035de78552d22dMarc Blankimport android.content.ContentProviderClient;
225c523858385176c33a7456bb84035de78552d22dMarc Blankimport android.content.ContentResolver;
235c523858385176c33a7456bb84035de78552d22dMarc Blankimport android.content.ContentUris;
245c523858385176c33a7456bb84035de78552d22dMarc Blankimport android.content.ContentValues;
255c523858385176c33a7456bb84035de78552d22dMarc Blankimport android.content.Context;
265c523858385176c33a7456bb84035de78552d22dMarc Blankimport android.content.Intent;
275c523858385176c33a7456bb84035de78552d22dMarc Blankimport android.content.SyncResult;
285c523858385176c33a7456bb84035de78552d22dMarc Blankimport android.database.Cursor;
295c523858385176c33a7456bb84035de78552d22dMarc Blankimport android.net.Uri;
305c523858385176c33a7456bb84035de78552d22dMarc Blankimport android.os.Bundle;
315c523858385176c33a7456bb84035de78552d22dMarc Blankimport android.os.IBinder;
325c523858385176c33a7456bb84035de78552d22dMarc Blank
335c523858385176c33a7456bb84035de78552d22dMarc Blankimport com.android.email.R;
345c523858385176c33a7456bb84035de78552d22dMarc Blankimport com.android.emailcommon.TempDirectory;
355c523858385176c33a7456bb84035de78552d22dMarc Blankimport com.android.emailcommon.mail.MessagingException;
365c523858385176c33a7456bb84035de78552d22dMarc Blankimport com.android.emailcommon.provider.Account;
375c523858385176c33a7456bb84035de78552d22dMarc Blankimport com.android.emailcommon.provider.EmailContent;
385c523858385176c33a7456bb84035de78552d22dMarc Blankimport com.android.emailcommon.provider.EmailContent.AccountColumns;
395c523858385176c33a7456bb84035de78552d22dMarc Blankimport com.android.emailcommon.provider.EmailContent.Message;
405c523858385176c33a7456bb84035de78552d22dMarc Blankimport com.android.emailcommon.provider.Mailbox;
415c523858385176c33a7456bb84035de78552d22dMarc Blankimport com.android.emailcommon.service.EmailServiceProxy;
422075c97f608a853923980865b72147a5c8ef71f0Yu Ping Huimport com.android.emailcommon.service.EmailServiceStatus;
438c989772dfba08438650575f1ac2bb952bd56158Alon Albertimport com.android.mail.providers.UIProvider;
44560bfadc3151f7a06f3b06e9a6c92cfa534c63ecScott Kennedyimport com.android.mail.utils.LogUtils;
455c523858385176c33a7456bb84035de78552d22dMarc Blank
465c523858385176c33a7456bb84035de78552d22dMarc Blankimport java.util.ArrayList;
475c523858385176c33a7456bb84035de78552d22dMarc Blank
485c523858385176c33a7456bb84035de78552d22dMarc Blankpublic class PopImapSyncAdapterService extends Service {
49d1a87bc02d65dde9e635848531e09aadc79ff538Paul Westbrook    private static final String TAG = "PopImapSyncService";
501484c6663db7b194eea9341ec8ecab6b44985c7cYu Ping Hu    private SyncAdapterImpl mSyncAdapter = null;
515c523858385176c33a7456bb84035de78552d22dMarc Blank
525c523858385176c33a7456bb84035de78552d22dMarc Blank    public PopImapSyncAdapterService() {
535c523858385176c33a7456bb84035de78552d22dMarc Blank        super();
545c523858385176c33a7456bb84035de78552d22dMarc Blank    }
555c523858385176c33a7456bb84035de78552d22dMarc Blank
565c523858385176c33a7456bb84035de78552d22dMarc Blank    private static class SyncAdapterImpl extends AbstractThreadedSyncAdapter {
575c523858385176c33a7456bb84035de78552d22dMarc Blank        public SyncAdapterImpl(Context context) {
585c523858385176c33a7456bb84035de78552d22dMarc Blank            super(context, true /* autoInitialize */);
595c523858385176c33a7456bb84035de78552d22dMarc Blank        }
605c523858385176c33a7456bb84035de78552d22dMarc Blank
615c523858385176c33a7456bb84035de78552d22dMarc Blank        @Override
625c523858385176c33a7456bb84035de78552d22dMarc Blank        public void onPerformSync(android.accounts.Account account, Bundle extras,
635c523858385176c33a7456bb84035de78552d22dMarc Blank                String authority, ContentProviderClient provider, SyncResult syncResult) {
641b8e0fa23f6e9957f0b8753dd3f5b95d3f5d98eaScott Kennedy            PopImapSyncAdapterService.performSync(getContext(), account, extras, provider,
651b8e0fa23f6e9957f0b8753dd3f5b95d3f5d98eaScott Kennedy                    syncResult);
665c523858385176c33a7456bb84035de78552d22dMarc Blank        }
675c523858385176c33a7456bb84035de78552d22dMarc Blank    }
685c523858385176c33a7456bb84035de78552d22dMarc Blank
695c523858385176c33a7456bb84035de78552d22dMarc Blank    @Override
705c523858385176c33a7456bb84035de78552d22dMarc Blank    public void onCreate() {
715c523858385176c33a7456bb84035de78552d22dMarc Blank        super.onCreate();
721484c6663db7b194eea9341ec8ecab6b44985c7cYu Ping Hu        mSyncAdapter = new SyncAdapterImpl(getApplicationContext());
735c523858385176c33a7456bb84035de78552d22dMarc Blank    }
745c523858385176c33a7456bb84035de78552d22dMarc Blank
755c523858385176c33a7456bb84035de78552d22dMarc Blank    @Override
765c523858385176c33a7456bb84035de78552d22dMarc Blank    public IBinder onBind(Intent intent) {
771484c6663db7b194eea9341ec8ecab6b44985c7cYu Ping Hu        return mSyncAdapter.getSyncAdapterBinder();
785c523858385176c33a7456bb84035de78552d22dMarc Blank    }
795c523858385176c33a7456bb84035de78552d22dMarc Blank
805c523858385176c33a7456bb84035de78552d22dMarc Blank    /**
815c523858385176c33a7456bb84035de78552d22dMarc Blank     * @return whether or not this mailbox retrieves its data from the server (as opposed to just
825c523858385176c33a7456bb84035de78552d22dMarc Blank     *     a local mailbox that is never synced).
835c523858385176c33a7456bb84035de78552d22dMarc Blank     */
845c523858385176c33a7456bb84035de78552d22dMarc Blank    private static boolean loadsFromServer(Context context, Mailbox m, String protocol) {
855c523858385176c33a7456bb84035de78552d22dMarc Blank        String legacyImapProtocol = context.getString(R.string.protocol_legacy_imap);
8654347010fbbdd3ae1dea5b0e282514c640e16a5fMarc Blank        String pop3Protocol = context.getString(R.string.protocol_pop3);
875c523858385176c33a7456bb84035de78552d22dMarc Blank        if (legacyImapProtocol.equals(protocol)) {
885c523858385176c33a7456bb84035de78552d22dMarc Blank            // TODO: actually use a sync flag when creating the mailboxes. Right now we use an
895c523858385176c33a7456bb84035de78552d22dMarc Blank            // approximation for IMAP.
905c523858385176c33a7456bb84035de78552d22dMarc Blank            return m.mType != Mailbox.TYPE_DRAFTS
915c523858385176c33a7456bb84035de78552d22dMarc Blank                    && m.mType != Mailbox.TYPE_OUTBOX
925c523858385176c33a7456bb84035de78552d22dMarc Blank                    && m.mType != Mailbox.TYPE_SEARCH;
935c523858385176c33a7456bb84035de78552d22dMarc Blank
9454347010fbbdd3ae1dea5b0e282514c640e16a5fMarc Blank        } else if (pop3Protocol.equals(protocol)) {
955c523858385176c33a7456bb84035de78552d22dMarc Blank            return Mailbox.TYPE_INBOX == m.mType;
965c523858385176c33a7456bb84035de78552d22dMarc Blank        }
975c523858385176c33a7456bb84035de78552d22dMarc Blank
985c523858385176c33a7456bb84035de78552d22dMarc Blank        return false;
995c523858385176c33a7456bb84035de78552d22dMarc Blank    }
1005c523858385176c33a7456bb84035de78552d22dMarc Blank
1012075c97f608a853923980865b72147a5c8ef71f0Yu Ping Hu    private static void sync(final Context context, final long mailboxId,
1022075c97f608a853923980865b72147a5c8ef71f0Yu Ping Hu            final Bundle extras, final SyncResult syncResult, final boolean uiRefresh,
1032075c97f608a853923980865b72147a5c8ef71f0Yu Ping Hu            final int deltaMessageCount) {
1045c523858385176c33a7456bb84035de78552d22dMarc Blank        TempDirectory.setTempDirectory(context);
1055c523858385176c33a7456bb84035de78552d22dMarc Blank        Mailbox mailbox = Mailbox.restoreMailboxWithId(context, mailboxId);
1065c523858385176c33a7456bb84035de78552d22dMarc Blank        if (mailbox == null) return;
1075c523858385176c33a7456bb84035de78552d22dMarc Blank        Account account = Account.restoreAccountWithId(context, mailbox.mAccountKey);
1085c523858385176c33a7456bb84035de78552d22dMarc Blank        if (account == null) return;
1095c523858385176c33a7456bb84035de78552d22dMarc Blank        ContentResolver resolver = context.getContentResolver();
1105c523858385176c33a7456bb84035de78552d22dMarc Blank        String protocol = account.getProtocol(context);
1115c523858385176c33a7456bb84035de78552d22dMarc Blank        if ((mailbox.mType != Mailbox.TYPE_OUTBOX) &&
1125c523858385176c33a7456bb84035de78552d22dMarc Blank                !loadsFromServer(context, mailbox, protocol)) {
1135c523858385176c33a7456bb84035de78552d22dMarc Blank            // This is an update to a message in a non-syncing mailbox; delete this from the
1145c523858385176c33a7456bb84035de78552d22dMarc Blank            // updates table and return
1155c523858385176c33a7456bb84035de78552d22dMarc Blank            resolver.delete(Message.UPDATED_CONTENT_URI, Message.MAILBOX_KEY + "=?",
1165c523858385176c33a7456bb84035de78552d22dMarc Blank                    new String[] {Long.toString(mailbox.mId)});
1175c523858385176c33a7456bb84035de78552d22dMarc Blank            return;
1185c523858385176c33a7456bb84035de78552d22dMarc Blank        }
11937b539063d30e6b59cbbbdda470de81d41025e51Martin Hibdon        LogUtils.d(TAG, "About to sync mailbox: " + mailbox.mDisplayName);
1205c523858385176c33a7456bb84035de78552d22dMarc Blank
1215c523858385176c33a7456bb84035de78552d22dMarc Blank        Uri mailboxUri = ContentUris.withAppendedId(Mailbox.CONTENT_URI, mailboxId);
1225c523858385176c33a7456bb84035de78552d22dMarc Blank        ContentValues values = new ContentValues();
1235c523858385176c33a7456bb84035de78552d22dMarc Blank        // Set mailbox sync state
1245c523858385176c33a7456bb84035de78552d22dMarc Blank        values.put(Mailbox.UI_SYNC_STATUS,
1255c523858385176c33a7456bb84035de78552d22dMarc Blank                uiRefresh ? EmailContent.SYNC_STATUS_USER : EmailContent.SYNC_STATUS_BACKGROUND);
1265c523858385176c33a7456bb84035de78552d22dMarc Blank        resolver.update(mailboxUri, values, null, null);
1275c523858385176c33a7456bb84035de78552d22dMarc Blank        try {
1285c523858385176c33a7456bb84035de78552d22dMarc Blank            try {
1295c523858385176c33a7456bb84035de78552d22dMarc Blank                String legacyImapProtocol = context.getString(R.string.protocol_legacy_imap);
1305c523858385176c33a7456bb84035de78552d22dMarc Blank                if (mailbox.mType == Mailbox.TYPE_OUTBOX) {
1315c523858385176c33a7456bb84035de78552d22dMarc Blank                    EmailServiceStub.sendMailImpl(context, account.mId);
1325c523858385176c33a7456bb84035de78552d22dMarc Blank                } else {
1332075c97f608a853923980865b72147a5c8ef71f0Yu Ping Hu                    EmailServiceStatus.syncMailboxStatus(resolver, extras, mailboxId,
1348c989772dfba08438650575f1ac2bb952bd56158Alon Albert                            EmailServiceStatus.IN_PROGRESS, 0, UIProvider.LastSyncResult.SUCCESS);
1352075c97f608a853923980865b72147a5c8ef71f0Yu Ping Hu                    final int status;
1362075c97f608a853923980865b72147a5c8ef71f0Yu Ping Hu                    if (protocol.equals(legacyImapProtocol)) {
1372075c97f608a853923980865b72147a5c8ef71f0Yu Ping Hu                        status = ImapService.synchronizeMailboxSynchronous(context, account,
138c75f5880ab70d9f4938727587696b864bb4ea02aMartin Hibdon                                mailbox, deltaMessageCount != 0, uiRefresh);
1392075c97f608a853923980865b72147a5c8ef71f0Yu Ping Hu                    } else {
1402075c97f608a853923980865b72147a5c8ef71f0Yu Ping Hu                        status = Pop3Service.synchronizeMailboxSynchronous(context, account,
1412075c97f608a853923980865b72147a5c8ef71f0Yu Ping Hu                                mailbox, deltaMessageCount);
1422075c97f608a853923980865b72147a5c8ef71f0Yu Ping Hu                    }
1438c989772dfba08438650575f1ac2bb952bd56158Alon Albert                    EmailServiceStatus.syncMailboxStatus(resolver, extras, mailboxId, status, 0,
1448c989772dfba08438650575f1ac2bb952bd56158Alon Albert                            UIProvider.LastSyncResult.SUCCESS);
1455c523858385176c33a7456bb84035de78552d22dMarc Blank                }
1465c523858385176c33a7456bb84035de78552d22dMarc Blank            } catch (MessagingException e) {
1470dffe3afd7a2fdfb394573aa0d8d06dd90e9fe12James Lemieux                final int type = e.getExceptionType();
1480dffe3afd7a2fdfb394573aa0d8d06dd90e9fe12James Lemieux                // type must be translated into the domain of values used by EmailServiceStatus
1490dffe3afd7a2fdfb394573aa0d8d06dd90e9fe12James Lemieux                switch(type) {
1505c523858385176c33a7456bb84035de78552d22dMarc Blank                    case MessagingException.IOERROR:
1510dffe3afd7a2fdfb394573aa0d8d06dd90e9fe12James Lemieux                        EmailServiceStatus.syncMailboxStatus(resolver, extras, mailboxId, type, 0,
1528c989772dfba08438650575f1ac2bb952bd56158Alon Albert                                UIProvider.LastSyncResult.CONNECTION_ERROR);
1535c523858385176c33a7456bb84035de78552d22dMarc Blank                        syncResult.stats.numIoExceptions++;
1545c523858385176c33a7456bb84035de78552d22dMarc Blank                        break;
1555c523858385176c33a7456bb84035de78552d22dMarc Blank                    case MessagingException.AUTHENTICATION_FAILED:
1560dffe3afd7a2fdfb394573aa0d8d06dd90e9fe12James Lemieux                        EmailServiceStatus.syncMailboxStatus(resolver, extras, mailboxId, type, 0,
1578c989772dfba08438650575f1ac2bb952bd56158Alon Albert                                UIProvider.LastSyncResult.AUTH_ERROR);
1585c523858385176c33a7456bb84035de78552d22dMarc Blank                        syncResult.stats.numAuthExceptions++;
1595c523858385176c33a7456bb84035de78552d22dMarc Blank                        break;
1600dffe3afd7a2fdfb394573aa0d8d06dd90e9fe12James Lemieux                    case MessagingException.SERVER_ERROR:
1610dffe3afd7a2fdfb394573aa0d8d06dd90e9fe12James Lemieux                        EmailServiceStatus.syncMailboxStatus(resolver, extras, mailboxId, type, 0,
1620dffe3afd7a2fdfb394573aa0d8d06dd90e9fe12James Lemieux                                UIProvider.LastSyncResult.SERVER_ERROR);
1630dffe3afd7a2fdfb394573aa0d8d06dd90e9fe12James Lemieux                        break;
1648c989772dfba08438650575f1ac2bb952bd56158Alon Albert
1658c989772dfba08438650575f1ac2bb952bd56158Alon Albert                    default:
1660dffe3afd7a2fdfb394573aa0d8d06dd90e9fe12James Lemieux                        EmailServiceStatus.syncMailboxStatus(resolver, extras, mailboxId, type, 0,
1670dffe3afd7a2fdfb394573aa0d8d06dd90e9fe12James Lemieux                                UIProvider.LastSyncResult.INTERNAL_ERROR);
1685c523858385176c33a7456bb84035de78552d22dMarc Blank                }
1695c523858385176c33a7456bb84035de78552d22dMarc Blank            }
1705c523858385176c33a7456bb84035de78552d22dMarc Blank        } finally {
17117d5bbf768c27ac7782b155e2ab25bcd480f5dcfYu Ping Hu            // Always clear our sync state and update sync time.
1725c523858385176c33a7456bb84035de78552d22dMarc Blank            values.put(Mailbox.UI_SYNC_STATUS, EmailContent.SYNC_STATUS_NONE);
17317d5bbf768c27ac7782b155e2ab25bcd480f5dcfYu Ping Hu            values.put(Mailbox.SYNC_TIME, System.currentTimeMillis());
1745c523858385176c33a7456bb84035de78552d22dMarc Blank            resolver.update(mailboxUri, values, null, null);
1755c523858385176c33a7456bb84035de78552d22dMarc Blank        }
1765c523858385176c33a7456bb84035de78552d22dMarc Blank    }
1775c523858385176c33a7456bb84035de78552d22dMarc Blank
1785c523858385176c33a7456bb84035de78552d22dMarc Blank    /**
1795c523858385176c33a7456bb84035de78552d22dMarc Blank     * Partial integration with system SyncManager; we initiate manual syncs upon request
1805c523858385176c33a7456bb84035de78552d22dMarc Blank     */
1815c523858385176c33a7456bb84035de78552d22dMarc Blank    private static void performSync(Context context, android.accounts.Account account,
1821b8e0fa23f6e9957f0b8753dd3f5b95d3f5d98eaScott Kennedy            Bundle extras, ContentProviderClient provider, SyncResult syncResult) {
1835c523858385176c33a7456bb84035de78552d22dMarc Blank        // Find an EmailProvider account with the Account's email address
1845c523858385176c33a7456bb84035de78552d22dMarc Blank        Cursor c = null;
1855c523858385176c33a7456bb84035de78552d22dMarc Blank        try {
1865c523858385176c33a7456bb84035de78552d22dMarc Blank            c = provider.query(com.android.emailcommon.provider.Account.CONTENT_URI,
1875c523858385176c33a7456bb84035de78552d22dMarc Blank                    Account.CONTENT_PROJECTION, AccountColumns.EMAIL_ADDRESS + "=?",
1885c523858385176c33a7456bb84035de78552d22dMarc Blank                    new String[] {account.name}, null);
1895c523858385176c33a7456bb84035de78552d22dMarc Blank            if (c != null && c.moveToNext()) {
1905c523858385176c33a7456bb84035de78552d22dMarc Blank                Account acct = new Account();
1915c523858385176c33a7456bb84035de78552d22dMarc Blank                acct.restore(c);
1925c523858385176c33a7456bb84035de78552d22dMarc Blank                if (extras.getBoolean(ContentResolver.SYNC_EXTRAS_UPLOAD)) {
193560bfadc3151f7a06f3b06e9a6c92cfa534c63ecScott Kennedy                    LogUtils.d(TAG, "Upload sync request for " + acct.mDisplayName);
1945c523858385176c33a7456bb84035de78552d22dMarc Blank                    // See if any boxes have mail...
1955c523858385176c33a7456bb84035de78552d22dMarc Blank                    ArrayList<Long> mailboxesToUpdate;
1965c523858385176c33a7456bb84035de78552d22dMarc Blank                    Cursor updatesCursor = provider.query(Message.UPDATED_CONTENT_URI,
1975c523858385176c33a7456bb84035de78552d22dMarc Blank                            new String[] {Message.MAILBOX_KEY},
1985c523858385176c33a7456bb84035de78552d22dMarc Blank                            Message.ACCOUNT_KEY + "=?",
1995c523858385176c33a7456bb84035de78552d22dMarc Blank                            new String[] {Long.toString(acct.mId)},
2005c523858385176c33a7456bb84035de78552d22dMarc Blank                            null);
2015c523858385176c33a7456bb84035de78552d22dMarc Blank                    try {
2025c523858385176c33a7456bb84035de78552d22dMarc Blank                        if ((updatesCursor == null) || (updatesCursor.getCount() == 0)) return;
2035c523858385176c33a7456bb84035de78552d22dMarc Blank                        mailboxesToUpdate = new ArrayList<Long>();
2045c523858385176c33a7456bb84035de78552d22dMarc Blank                        while (updatesCursor.moveToNext()) {
2055c523858385176c33a7456bb84035de78552d22dMarc Blank                            Long mailboxId = updatesCursor.getLong(0);
2065c523858385176c33a7456bb84035de78552d22dMarc Blank                            if (!mailboxesToUpdate.contains(mailboxId)) {
2075c523858385176c33a7456bb84035de78552d22dMarc Blank                                mailboxesToUpdate.add(mailboxId);
2085c523858385176c33a7456bb84035de78552d22dMarc Blank                            }
2095c523858385176c33a7456bb84035de78552d22dMarc Blank                        }
2105c523858385176c33a7456bb84035de78552d22dMarc Blank                    } finally {
2115c523858385176c33a7456bb84035de78552d22dMarc Blank                        if (updatesCursor != null) {
2125c523858385176c33a7456bb84035de78552d22dMarc Blank                            updatesCursor.close();
2135c523858385176c33a7456bb84035de78552d22dMarc Blank                        }
2145c523858385176c33a7456bb84035de78552d22dMarc Blank                    }
2155c523858385176c33a7456bb84035de78552d22dMarc Blank                    for (long mailboxId: mailboxesToUpdate) {
2162075c97f608a853923980865b72147a5c8ef71f0Yu Ping Hu                        sync(context, mailboxId, extras, syncResult, false, 0);
2175c523858385176c33a7456bb84035de78552d22dMarc Blank                    }
2185c523858385176c33a7456bb84035de78552d22dMarc Blank                } else {
219560bfadc3151f7a06f3b06e9a6c92cfa534c63ecScott Kennedy                    LogUtils.d(TAG, "Sync request for " + acct.mDisplayName);
220560bfadc3151f7a06f3b06e9a6c92cfa534c63ecScott Kennedy                    LogUtils.d(TAG, extras.toString());
2211a7838eed7558a8f5caa23128518cae09d8a034fMartin Hibdon
2221a7838eed7558a8f5caa23128518cae09d8a034fMartin Hibdon                    // We update our folder structure on every sync.
2231a7838eed7558a8f5caa23128518cae09d8a034fMartin Hibdon                    final EmailServiceProxy service =
2241a7838eed7558a8f5caa23128518cae09d8a034fMartin Hibdon                            EmailServiceUtils.getServiceForAccount(context, acct.mId);
2251a7838eed7558a8f5caa23128518cae09d8a034fMartin Hibdon                    service.updateFolderList(acct.mId);
2261a7838eed7558a8f5caa23128518cae09d8a034fMartin Hibdon
227c48670a5692144b293cea1c42b138e5228860da4Yu Ping Hu                    // Get the id for the mailbox we want to sync.
22856aba8d8436b083bfc1169dd8b988161d537f7e5Martin Hibdon                    long [] mailboxIds = Mailbox.getMailboxIdsFromBundle(extras);
22956aba8d8436b083bfc1169dd8b988161d537f7e5Martin Hibdon                    if (mailboxIds == null || mailboxIds.length == 0) {
23056aba8d8436b083bfc1169dd8b988161d537f7e5Martin Hibdon                        // No mailbox specified, just sync the inbox.
231c48670a5692144b293cea1c42b138e5228860da4Yu Ping Hu                        // TODO: IMAP may eventually want to allow multiple auto-sync mailboxes.
23256aba8d8436b083bfc1169dd8b988161d537f7e5Martin Hibdon                        final long inboxId = Mailbox.findMailboxOfType(context, acct.mId,
233c48670a5692144b293cea1c42b138e5228860da4Yu Ping Hu                                Mailbox.TYPE_INBOX);
23456aba8d8436b083bfc1169dd8b988161d537f7e5Martin Hibdon                        if (inboxId != Mailbox.NO_MAILBOX) {
23556aba8d8436b083bfc1169dd8b988161d537f7e5Martin Hibdon                            mailboxIds = new long[1];
23656aba8d8436b083bfc1169dd8b988161d537f7e5Martin Hibdon                            mailboxIds[0] = inboxId;
23756aba8d8436b083bfc1169dd8b988161d537f7e5Martin Hibdon                        }
238c48670a5692144b293cea1c42b138e5228860da4Yu Ping Hu                    }
23956aba8d8436b083bfc1169dd8b988161d537f7e5Martin Hibdon
24056aba8d8436b083bfc1169dd8b988161d537f7e5Martin Hibdon                    if (mailboxIds != null) {
24156aba8d8436b083bfc1169dd8b988161d537f7e5Martin Hibdon                        boolean uiRefresh =
2425c523858385176c33a7456bb84035de78552d22dMarc Blank                            extras.getBoolean(ContentResolver.SYNC_EXTRAS_EXPEDITED, false);
24356aba8d8436b083bfc1169dd8b988161d537f7e5Martin Hibdon                        int deltaMessageCount =
24456aba8d8436b083bfc1169dd8b988161d537f7e5Martin Hibdon                                extras.getInt(Mailbox.SYNC_EXTRA_DELTA_MESSAGE_COUNT, 0);
24556aba8d8436b083bfc1169dd8b988161d537f7e5Martin Hibdon                        for (long mailboxId : mailboxIds) {
24656aba8d8436b083bfc1169dd8b988161d537f7e5Martin Hibdon                            sync(context, mailboxId, extras, syncResult, uiRefresh, deltaMessageCount);
24756aba8d8436b083bfc1169dd8b988161d537f7e5Martin Hibdon                        }
24856aba8d8436b083bfc1169dd8b988161d537f7e5Martin Hibdon                    }
2495c523858385176c33a7456bb84035de78552d22dMarc Blank                }
2505c523858385176c33a7456bb84035de78552d22dMarc Blank            }
2515c523858385176c33a7456bb84035de78552d22dMarc Blank        } catch (Exception e) {
2525c523858385176c33a7456bb84035de78552d22dMarc Blank            e.printStackTrace();
2535c523858385176c33a7456bb84035de78552d22dMarc Blank        } finally {
2545c523858385176c33a7456bb84035de78552d22dMarc Blank            if (c != null) {
2555c523858385176c33a7456bb84035de78552d22dMarc Blank                c.close();
2565c523858385176c33a7456bb84035de78552d22dMarc Blank            }
2575c523858385176c33a7456bb84035de78552d22dMarc Blank        }
2585c523858385176c33a7456bb84035de78552d22dMarc Blank    }
2592075c97f608a853923980865b72147a5c8ef71f0Yu Ping Hu}
260