2010-03-03 23:00:30 -05:00
|
|
|
|
|
|
|
package com.fsck.k9;
|
|
|
|
|
|
|
|
import android.content.Context;
|
|
|
|
import android.content.SharedPreferences;
|
2010-03-06 19:30:40 -05:00
|
|
|
import android.net.ConnectivityManager;
|
2010-03-03 23:00:30 -05:00
|
|
|
import android.net.Uri;
|
2010-04-16 10:33:54 -04:00
|
|
|
import android.util.Log;
|
|
|
|
|
2010-03-03 23:00:30 -05:00
|
|
|
import com.fsck.k9.mail.Address;
|
|
|
|
import com.fsck.k9.mail.Folder;
|
|
|
|
import com.fsck.k9.mail.MessagingException;
|
|
|
|
import com.fsck.k9.mail.Store;
|
|
|
|
import com.fsck.k9.mail.store.LocalStore;
|
|
|
|
import com.fsck.k9.mail.store.LocalStore.LocalFolder;
|
|
|
|
import java.util.ArrayList;
|
|
|
|
import java.util.Arrays;
|
|
|
|
import java.util.List;
|
2010-03-06 19:30:40 -05:00
|
|
|
import java.util.Map;
|
2010-04-29 00:59:14 -04:00
|
|
|
import java.util.Random;
|
2010-03-03 23:00:30 -05:00
|
|
|
import java.util.UUID;
|
2010-03-06 19:30:40 -05:00
|
|
|
import java.util.concurrent.ConcurrentHashMap;
|
2010-03-03 23:00:30 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Account stores all of the settings for a single account defined by the user. It is able to save
|
|
|
|
* and delete itself given a Preferences to work with. Each account is defined by a UUID.
|
|
|
|
*/
|
2010-04-16 23:32:17 -04:00
|
|
|
public class Account implements BaseAccount
|
2010-03-03 23:00:30 -05:00
|
|
|
{
|
|
|
|
public static final String EXPUNGE_IMMEDIATELY = "EXPUNGE_IMMEDIATELY";
|
|
|
|
public static final String EXPUNGE_MANUALLY = "EXPUNGE_MANUALLY";
|
|
|
|
public static final String EXPUNGE_ON_POLL = "EXPUNGE_ON_POLL";
|
|
|
|
|
|
|
|
public static final int DELETE_POLICY_NEVER = 0;
|
|
|
|
public static final int DELETE_POLICY_7DAYS = 1;
|
|
|
|
public static final int DELETE_POLICY_ON_DELETE = 2;
|
|
|
|
public static final int DELETE_POLICY_MARK_AS_READ = 3;
|
2010-04-29 00:59:14 -04:00
|
|
|
|
2010-03-06 19:30:40 -05:00
|
|
|
public static final String TYPE_WIFI = "WIFI";
|
|
|
|
public static final String TYPE_MOBILE = "MOBILE";
|
|
|
|
public static final String TYPE_OTHER = "OTHER";
|
|
|
|
private static String[] networkTypes = { TYPE_WIFI, TYPE_MOBILE, TYPE_OTHER };
|
2010-04-29 00:59:14 -04:00
|
|
|
|
|
|
|
|
2010-03-03 23:00:30 -05:00
|
|
|
/**
|
|
|
|
* <pre>
|
|
|
|
* 0 - Never (DELETE_POLICY_NEVER)
|
|
|
|
* 1 - After 7 days (DELETE_POLICY_7DAYS)
|
|
|
|
* 2 - When I delete from inbox (DELETE_POLICY_ON_DELETE)
|
|
|
|
* 3 - Mark as read (DELETE_POLICY_MARK_AS_READ)
|
|
|
|
* </pre>
|
|
|
|
*/
|
|
|
|
private int mDeletePolicy;
|
|
|
|
|
|
|
|
private String mUuid;
|
|
|
|
private String mStoreUri;
|
|
|
|
private String mLocalStoreUri;
|
|
|
|
private String mTransportUri;
|
|
|
|
private String mDescription;
|
|
|
|
private String mAlwaysBcc;
|
|
|
|
private int mAutomaticCheckIntervalMinutes;
|
|
|
|
private int mDisplayCount;
|
2010-04-29 00:59:14 -04:00
|
|
|
private int mChipColor;
|
2010-03-03 23:00:30 -05:00
|
|
|
private long mLastAutomaticCheckTime;
|
|
|
|
private boolean mNotifyNewMail;
|
|
|
|
private boolean mNotifySelfNewMail;
|
|
|
|
private String mDraftsFolderName;
|
|
|
|
private String mSentFolderName;
|
|
|
|
private String mTrashFolderName;
|
|
|
|
private String mOutboxFolderName;
|
|
|
|
private String mAutoExpandFolderName;
|
|
|
|
private FolderMode mFolderDisplayMode;
|
|
|
|
private FolderMode mFolderSyncMode;
|
|
|
|
private FolderMode mFolderPushMode;
|
|
|
|
private FolderMode mFolderTargetMode;
|
|
|
|
private int mAccountNumber;
|
|
|
|
private boolean mVibrate;
|
|
|
|
private boolean mRing;
|
2010-05-09 11:27:41 -04:00
|
|
|
private boolean mPushPollOnConnect;
|
2010-03-03 23:00:30 -05:00
|
|
|
private String mRingtoneUri;
|
|
|
|
private boolean mNotifySync;
|
|
|
|
private HideButtons mHideMessageViewButtons;
|
|
|
|
private boolean mIsSignatureBeforeQuotedText;
|
|
|
|
private String mExpungePolicy = EXPUNGE_IMMEDIATELY;
|
|
|
|
private int mMaxPushFolders;
|
2010-05-09 11:27:41 -04:00
|
|
|
private int mIdleRefreshMinutes;
|
2010-04-29 00:59:14 -04:00
|
|
|
private Map<String, Boolean> compressionMap = new ConcurrentHashMap<String, Boolean>();
|
2010-04-05 22:54:48 -04:00
|
|
|
private Searchable searchableFolders;
|
2010-03-29 22:58:21 -04:00
|
|
|
// Tracks if we have sent a notification for this account for
|
|
|
|
// current set of fetched messages
|
|
|
|
private boolean mRingNotified;
|
2010-03-03 23:00:30 -05:00
|
|
|
|
|
|
|
private List<Identity> identities;
|
|
|
|
|
|
|
|
public enum FolderMode
|
|
|
|
{
|
|
|
|
NONE, ALL, FIRST_CLASS, FIRST_AND_SECOND_CLASS, NOT_SECOND_CLASS;
|
|
|
|
}
|
|
|
|
|
|
|
|
public enum HideButtons
|
|
|
|
{
|
|
|
|
NEVER, ALWAYS, KEYBOARD_AVAILABLE;
|
2010-04-29 00:59:14 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
public enum Searchable
|
2010-04-05 22:54:48 -04:00
|
|
|
{
|
|
|
|
ALL, DISPLAYABLE, NONE
|
2010-03-03 23:00:30 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
protected Account(Context context)
|
|
|
|
{
|
|
|
|
// TODO Change local store path to something readable / recognizable
|
|
|
|
mUuid = UUID.randomUUID().toString();
|
|
|
|
mLocalStoreUri = "local://localhost/" + context.getDatabasePath(mUuid + ".db");
|
|
|
|
mAutomaticCheckIntervalMinutes = -1;
|
2010-05-09 11:27:41 -04:00
|
|
|
mIdleRefreshMinutes = 24;
|
|
|
|
mPushPollOnConnect = true;
|
2010-03-03 23:00:30 -05:00
|
|
|
mDisplayCount = -1;
|
|
|
|
mAccountNumber = -1;
|
|
|
|
mNotifyNewMail = true;
|
|
|
|
mNotifySync = true;
|
|
|
|
mVibrate = false;
|
|
|
|
mRing = true;
|
|
|
|
mNotifySelfNewMail = true;
|
|
|
|
mFolderDisplayMode = FolderMode.NOT_SECOND_CLASS;
|
|
|
|
mFolderSyncMode = FolderMode.FIRST_CLASS;
|
|
|
|
mFolderPushMode = FolderMode.FIRST_CLASS;
|
|
|
|
mFolderTargetMode = FolderMode.NOT_SECOND_CLASS;
|
|
|
|
mHideMessageViewButtons = HideButtons.NEVER;
|
|
|
|
mRingtoneUri = "content://settings/system/notification_sound";
|
|
|
|
mIsSignatureBeforeQuotedText = false;
|
|
|
|
mExpungePolicy = EXPUNGE_IMMEDIATELY;
|
|
|
|
mAutoExpandFolderName = "INBOX";
|
|
|
|
mMaxPushFolders = 10;
|
2010-04-29 00:59:14 -04:00
|
|
|
mChipColor = 0;
|
|
|
|
|
2010-04-05 22:54:48 -04:00
|
|
|
searchableFolders = Searchable.ALL;
|
2010-04-29 00:59:14 -04:00
|
|
|
|
2010-03-03 23:00:30 -05:00
|
|
|
identities = new ArrayList<Identity>();
|
|
|
|
|
|
|
|
Identity identity = new Identity();
|
|
|
|
identity.setSignatureUse(true);
|
|
|
|
identity.setSignature(context.getString(R.string.default_signature));
|
|
|
|
identity.setDescription(context.getString(R.string.default_identity_description));
|
|
|
|
identities.add(identity);
|
|
|
|
}
|
|
|
|
|
|
|
|
protected Account(Preferences preferences, String uuid)
|
|
|
|
{
|
|
|
|
this.mUuid = uuid;
|
|
|
|
loadAccount(preferences);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Load stored settings for this account.
|
|
|
|
*/
|
|
|
|
private synchronized void loadAccount(Preferences preferences)
|
|
|
|
{
|
|
|
|
mStoreUri = Utility.base64Decode(preferences.getPreferences().getString(mUuid
|
|
|
|
+ ".storeUri", null));
|
|
|
|
mLocalStoreUri = preferences.getPreferences().getString(mUuid + ".localStoreUri", null);
|
|
|
|
mTransportUri = Utility.base64Decode(preferences.getPreferences().getString(mUuid
|
|
|
|
+ ".transportUri", null));
|
|
|
|
mDescription = preferences.getPreferences().getString(mUuid + ".description", null);
|
|
|
|
mAlwaysBcc = preferences.getPreferences().getString(mUuid + ".alwaysBcc", mAlwaysBcc);
|
|
|
|
mAutomaticCheckIntervalMinutes = preferences.getPreferences().getInt(mUuid
|
|
|
|
+ ".automaticCheckIntervalMinutes", -1);
|
2010-05-09 11:27:41 -04:00
|
|
|
mIdleRefreshMinutes = preferences.getPreferences().getInt(mUuid
|
|
|
|
+ ".idleRefreshMinutes", 24);
|
|
|
|
mPushPollOnConnect = preferences.getPreferences().getBoolean(mUuid
|
|
|
|
+ ".pushPollOnConnect", true);
|
2010-03-03 23:00:30 -05:00
|
|
|
mDisplayCount = preferences.getPreferences().getInt(mUuid + ".displayCount", -1);
|
|
|
|
mLastAutomaticCheckTime = preferences.getPreferences().getLong(mUuid
|
|
|
|
+ ".lastAutomaticCheckTime", 0);
|
|
|
|
mNotifyNewMail = preferences.getPreferences().getBoolean(mUuid + ".notifyNewMail",
|
|
|
|
false);
|
|
|
|
mNotifySelfNewMail = preferences.getPreferences().getBoolean(mUuid + ".notifySelfNewMail",
|
|
|
|
true);
|
|
|
|
mNotifySync = preferences.getPreferences().getBoolean(mUuid + ".notifyMailCheck",
|
|
|
|
false);
|
|
|
|
mDeletePolicy = preferences.getPreferences().getInt(mUuid + ".deletePolicy", 0);
|
|
|
|
mDraftsFolderName = preferences.getPreferences().getString(mUuid + ".draftsFolderName",
|
|
|
|
"Drafts");
|
|
|
|
mSentFolderName = preferences.getPreferences().getString(mUuid + ".sentFolderName",
|
|
|
|
"Sent");
|
|
|
|
mTrashFolderName = preferences.getPreferences().getString(mUuid + ".trashFolderName",
|
|
|
|
"Trash");
|
|
|
|
mOutboxFolderName = preferences.getPreferences().getString(mUuid + ".outboxFolderName",
|
|
|
|
"Outbox");
|
|
|
|
mExpungePolicy = preferences.getPreferences().getString(mUuid + ".expungePolicy", EXPUNGE_IMMEDIATELY);
|
|
|
|
|
|
|
|
mMaxPushFolders = preferences.getPreferences().getInt(mUuid + ".maxPushFolders", 10);
|
2010-04-29 00:59:14 -04:00
|
|
|
|
2010-03-06 19:30:40 -05:00
|
|
|
for (String type : networkTypes)
|
|
|
|
{
|
|
|
|
Boolean useCompression = preferences.getPreferences().getBoolean(mUuid + ".useCompression." + type,
|
2010-04-29 00:59:14 -04:00
|
|
|
true);
|
2010-03-06 19:30:40 -05:00
|
|
|
compressionMap.put(type, useCompression);
|
|
|
|
}
|
2010-03-03 23:00:30 -05:00
|
|
|
|
|
|
|
// Between r418 and r431 (version 0.103), folder names were set empty if the Incoming settings were
|
|
|
|
// opened for non-IMAP accounts. 0.103 was never a market release, so perhaps this code
|
|
|
|
// should be deleted sometime soon
|
|
|
|
if (mDraftsFolderName == null || mDraftsFolderName.equals(""))
|
|
|
|
{
|
|
|
|
mDraftsFolderName = "Drafts";
|
|
|
|
}
|
|
|
|
if (mSentFolderName == null || mSentFolderName.equals(""))
|
|
|
|
{
|
|
|
|
mSentFolderName = "Sent";
|
|
|
|
}
|
|
|
|
if (mTrashFolderName == null || mTrashFolderName.equals(""))
|
|
|
|
{
|
|
|
|
mTrashFolderName = "Trash";
|
|
|
|
}
|
|
|
|
if (mOutboxFolderName == null || mOutboxFolderName.equals(""))
|
|
|
|
{
|
|
|
|
mOutboxFolderName = "Outbox";
|
|
|
|
}
|
|
|
|
// End of 0.103 repair
|
|
|
|
|
|
|
|
mAutoExpandFolderName = preferences.getPreferences().getString(mUuid + ".autoExpandFolderName",
|
|
|
|
"INBOX");
|
|
|
|
|
|
|
|
mAccountNumber = preferences.getPreferences().getInt(mUuid + ".accountNumber", 0);
|
2010-04-29 00:59:14 -04:00
|
|
|
|
|
|
|
Random random = new Random((long)mAccountNumber+4);
|
|
|
|
|
|
|
|
mChipColor = preferences.getPreferences().getInt(mUuid+".chipColor",
|
|
|
|
(random.nextInt(0x70)) +
|
|
|
|
(random.nextInt(0x70) * 0xff) +
|
|
|
|
(random.nextInt(0x70) * 0xffff) +
|
|
|
|
0xff000000);
|
|
|
|
|
2010-03-03 23:00:30 -05:00
|
|
|
mVibrate = preferences.getPreferences().getBoolean(mUuid + ".vibrate", false);
|
|
|
|
mRing = preferences.getPreferences().getBoolean(mUuid + ".ring", true);
|
|
|
|
|
|
|
|
try
|
|
|
|
{
|
|
|
|
mHideMessageViewButtons = HideButtons.valueOf(preferences.getPreferences().getString(mUuid + ".hideButtonsEnum",
|
|
|
|
HideButtons.NEVER.name()));
|
|
|
|
}
|
|
|
|
catch (Exception e)
|
|
|
|
{
|
|
|
|
mHideMessageViewButtons = HideButtons.NEVER;
|
|
|
|
}
|
|
|
|
|
|
|
|
mRingtoneUri = preferences.getPreferences().getString(mUuid + ".ringtone",
|
|
|
|
"content://settings/system/notification_sound");
|
|
|
|
try
|
|
|
|
{
|
|
|
|
mFolderDisplayMode = FolderMode.valueOf(preferences.getPreferences().getString(mUuid + ".folderDisplayMode",
|
|
|
|
FolderMode.NOT_SECOND_CLASS.name()));
|
|
|
|
}
|
|
|
|
catch (Exception e)
|
|
|
|
{
|
|
|
|
mFolderDisplayMode = FolderMode.NOT_SECOND_CLASS;
|
|
|
|
}
|
|
|
|
|
|
|
|
try
|
|
|
|
{
|
|
|
|
mFolderSyncMode = FolderMode.valueOf(preferences.getPreferences().getString(mUuid + ".folderSyncMode",
|
|
|
|
FolderMode.FIRST_CLASS.name()));
|
|
|
|
}
|
|
|
|
catch (Exception e)
|
|
|
|
{
|
|
|
|
mFolderSyncMode = FolderMode.FIRST_CLASS;
|
|
|
|
}
|
|
|
|
|
|
|
|
try
|
|
|
|
{
|
|
|
|
mFolderPushMode = FolderMode.valueOf(preferences.getPreferences().getString(mUuid + ".folderPushMode",
|
|
|
|
FolderMode.FIRST_CLASS.name()));
|
|
|
|
}
|
|
|
|
catch (Exception e)
|
|
|
|
{
|
|
|
|
mFolderPushMode = FolderMode.FIRST_CLASS;
|
|
|
|
}
|
|
|
|
|
|
|
|
try
|
|
|
|
{
|
|
|
|
mFolderTargetMode = FolderMode.valueOf(preferences.getPreferences().getString(mUuid + ".folderTargetMode",
|
|
|
|
FolderMode.NOT_SECOND_CLASS.name()));
|
|
|
|
}
|
|
|
|
catch (Exception e)
|
|
|
|
{
|
|
|
|
mFolderTargetMode = FolderMode.NOT_SECOND_CLASS;
|
|
|
|
}
|
2010-04-29 00:59:14 -04:00
|
|
|
|
2010-04-05 22:54:48 -04:00
|
|
|
try
|
|
|
|
{
|
|
|
|
searchableFolders = Searchable.valueOf(preferences.getPreferences().getString(mUuid + ".searchableFolders",
|
|
|
|
Searchable.ALL.name()));
|
|
|
|
}
|
|
|
|
catch (Exception e)
|
|
|
|
{
|
|
|
|
searchableFolders = Searchable.ALL;
|
|
|
|
}
|
2010-03-03 23:00:30 -05:00
|
|
|
|
|
|
|
mIsSignatureBeforeQuotedText = preferences.getPreferences().getBoolean(mUuid + ".signatureBeforeQuotedText", false);
|
|
|
|
identities = loadIdentities(preferences.getPreferences());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
protected synchronized void delete(Preferences preferences)
|
|
|
|
{
|
|
|
|
String[] uuids = preferences.getPreferences().getString("accountUuids", "").split(",");
|
|
|
|
StringBuffer sb = new StringBuffer();
|
|
|
|
for (int i = 0, length = uuids.length; i < length; i++)
|
|
|
|
{
|
|
|
|
if (!uuids[i].equals(mUuid))
|
|
|
|
{
|
|
|
|
if (sb.length() > 0)
|
|
|
|
{
|
|
|
|
sb.append(',');
|
|
|
|
}
|
|
|
|
sb.append(uuids[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
String accountUuids = sb.toString();
|
|
|
|
SharedPreferences.Editor editor = preferences.getPreferences().edit();
|
|
|
|
editor.putString("accountUuids", accountUuids);
|
|
|
|
|
|
|
|
editor.remove(mUuid + ".storeUri");
|
|
|
|
editor.remove(mUuid + ".localStoreUri");
|
|
|
|
editor.remove(mUuid + ".transportUri");
|
|
|
|
editor.remove(mUuid + ".description");
|
|
|
|
editor.remove(mUuid + ".name");
|
|
|
|
editor.remove(mUuid + ".email");
|
|
|
|
editor.remove(mUuid + ".alwaysBcc");
|
|
|
|
editor.remove(mUuid + ".automaticCheckIntervalMinutes");
|
2010-05-09 11:27:41 -04:00
|
|
|
editor.remove(mUuid + ".pushPollOnConnect");
|
|
|
|
editor.remove(mUuid + ".idleRefreshMinutes");
|
2010-03-03 23:00:30 -05:00
|
|
|
editor.remove(mUuid + ".lastAutomaticCheckTime");
|
|
|
|
editor.remove(mUuid + ".notifyNewMail");
|
|
|
|
editor.remove(mUuid + ".notifySelfNewMail");
|
|
|
|
editor.remove(mUuid + ".deletePolicy");
|
|
|
|
editor.remove(mUuid + ".draftsFolderName");
|
|
|
|
editor.remove(mUuid + ".sentFolderName");
|
|
|
|
editor.remove(mUuid + ".trashFolderName");
|
|
|
|
editor.remove(mUuid + ".outboxFolderName");
|
|
|
|
editor.remove(mUuid + ".autoExpandFolderName");
|
|
|
|
editor.remove(mUuid + ".accountNumber");
|
|
|
|
editor.remove(mUuid + ".vibrate");
|
|
|
|
editor.remove(mUuid + ".ring");
|
|
|
|
editor.remove(mUuid + ".ringtone");
|
|
|
|
editor.remove(mUuid + ".lastFullSync");
|
|
|
|
editor.remove(mUuid + ".folderDisplayMode");
|
|
|
|
editor.remove(mUuid + ".folderSyncMode");
|
|
|
|
editor.remove(mUuid + ".folderPushMode");
|
|
|
|
editor.remove(mUuid + ".folderTargetMode");
|
|
|
|
editor.remove(mUuid + ".hideButtonsEnum");
|
|
|
|
editor.remove(mUuid + ".signatureBeforeQuotedText");
|
|
|
|
editor.remove(mUuid + ".expungePolicy");
|
|
|
|
editor.remove(mUuid + ".maxPushFolders");
|
2010-04-05 22:54:48 -04:00
|
|
|
editor.remove(mUuid + ".searchableFolders");
|
2010-03-06 19:30:40 -05:00
|
|
|
for (String type : networkTypes)
|
|
|
|
{
|
|
|
|
editor.remove(mUuid + ".useCompression." + type);
|
|
|
|
}
|
2010-03-03 23:00:30 -05:00
|
|
|
deleteIdentities(preferences.getPreferences(), editor);
|
|
|
|
editor.commit();
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void save(Preferences preferences)
|
|
|
|
{
|
|
|
|
SharedPreferences.Editor editor = preferences.getPreferences().edit();
|
|
|
|
|
|
|
|
if (!preferences.getPreferences().getString("accountUuids", "").contains(mUuid))
|
|
|
|
{
|
|
|
|
/*
|
|
|
|
* When the account is first created we assign it a unique account number. The
|
|
|
|
* account number will be unique to that account for the lifetime of the account.
|
|
|
|
* So, we get all the existing account numbers, sort them ascending, loop through
|
|
|
|
* the list and check if the number is greater than 1 + the previous number. If so
|
|
|
|
* we use the previous number + 1 as the account number. This refills gaps.
|
|
|
|
* mAccountNumber starts as -1 on a newly created account. It must be -1 for this
|
|
|
|
* algorithm to work.
|
|
|
|
*
|
|
|
|
* I bet there is a much smarter way to do this. Anyone like to suggest it?
|
|
|
|
*/
|
|
|
|
Account[] accounts = preferences.getAccounts();
|
|
|
|
int[] accountNumbers = new int[accounts.length];
|
|
|
|
for (int i = 0; i < accounts.length; i++)
|
|
|
|
{
|
|
|
|
accountNumbers[i] = accounts[i].getAccountNumber();
|
|
|
|
}
|
|
|
|
Arrays.sort(accountNumbers);
|
|
|
|
for (int accountNumber : accountNumbers)
|
|
|
|
{
|
|
|
|
if (accountNumber > mAccountNumber + 1)
|
|
|
|
{
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
mAccountNumber = accountNumber;
|
|
|
|
}
|
|
|
|
mAccountNumber++;
|
|
|
|
|
|
|
|
String accountUuids = preferences.getPreferences().getString("accountUuids", "");
|
|
|
|
accountUuids += (accountUuids.length() != 0 ? "," : "") + mUuid;
|
|
|
|
editor.putString("accountUuids", accountUuids);
|
|
|
|
}
|
|
|
|
|
|
|
|
editor.putString(mUuid + ".storeUri", Utility.base64Encode(mStoreUri));
|
|
|
|
editor.putString(mUuid + ".localStoreUri", mLocalStoreUri);
|
|
|
|
editor.putString(mUuid + ".transportUri", Utility.base64Encode(mTransportUri));
|
|
|
|
editor.putString(mUuid + ".description", mDescription);
|
|
|
|
editor.putString(mUuid + ".alwaysBcc", mAlwaysBcc);
|
|
|
|
editor.putInt(mUuid + ".automaticCheckIntervalMinutes", mAutomaticCheckIntervalMinutes);
|
2010-05-09 11:27:41 -04:00
|
|
|
editor.putInt(mUuid + ".idleRefreshMinutes", mIdleRefreshMinutes);
|
|
|
|
editor.putBoolean(mUuid + ".pushPollOnConnect", mPushPollOnConnect);
|
2010-03-03 23:00:30 -05:00
|
|
|
editor.putInt(mUuid + ".displayCount", mDisplayCount);
|
|
|
|
editor.putLong(mUuid + ".lastAutomaticCheckTime", mLastAutomaticCheckTime);
|
|
|
|
editor.putBoolean(mUuid + ".notifyNewMail", mNotifyNewMail);
|
|
|
|
editor.putBoolean(mUuid + ".notifySelfNewMail", mNotifySelfNewMail);
|
|
|
|
editor.putBoolean(mUuid + ".notifyMailCheck", mNotifySync);
|
|
|
|
editor.putInt(mUuid + ".deletePolicy", mDeletePolicy);
|
|
|
|
editor.putString(mUuid + ".draftsFolderName", mDraftsFolderName);
|
|
|
|
editor.putString(mUuid + ".sentFolderName", mSentFolderName);
|
|
|
|
editor.putString(mUuid + ".trashFolderName", mTrashFolderName);
|
|
|
|
editor.putString(mUuid + ".outboxFolderName", mOutboxFolderName);
|
|
|
|
editor.putString(mUuid + ".autoExpandFolderName", mAutoExpandFolderName);
|
|
|
|
editor.putInt(mUuid + ".accountNumber", mAccountNumber);
|
|
|
|
editor.putBoolean(mUuid + ".vibrate", mVibrate);
|
|
|
|
editor.putBoolean(mUuid + ".ring", mRing);
|
|
|
|
editor.putString(mUuid + ".hideButtonsEnum", mHideMessageViewButtons.name());
|
|
|
|
editor.putString(mUuid + ".ringtone", mRingtoneUri);
|
|
|
|
editor.putString(mUuid + ".folderDisplayMode", mFolderDisplayMode.name());
|
|
|
|
editor.putString(mUuid + ".folderSyncMode", mFolderSyncMode.name());
|
|
|
|
editor.putString(mUuid + ".folderPushMode", mFolderPushMode.name());
|
|
|
|
editor.putString(mUuid + ".folderTargetMode", mFolderTargetMode.name());
|
|
|
|
editor.putBoolean(mUuid + ".signatureBeforeQuotedText", this.mIsSignatureBeforeQuotedText);
|
|
|
|
editor.putString(mUuid + ".expungePolicy", mExpungePolicy);
|
|
|
|
editor.putInt(mUuid + ".maxPushFolders", mMaxPushFolders);
|
2010-04-05 22:54:48 -04:00
|
|
|
editor.putString(mUuid + ".searchableFolders", searchableFolders.name());
|
2010-04-29 00:59:14 -04:00
|
|
|
editor.putInt(mUuid + ".chipColor", mChipColor);
|
|
|
|
|
2010-03-06 19:30:40 -05:00
|
|
|
for (String type : networkTypes)
|
|
|
|
{
|
|
|
|
Boolean useCompression = compressionMap.get(type);
|
|
|
|
if (useCompression != null)
|
|
|
|
{
|
|
|
|
editor.putBoolean(mUuid + ".useCompression." + type, useCompression);
|
|
|
|
}
|
|
|
|
}
|
2010-03-03 23:00:30 -05:00
|
|
|
saveIdentities(preferences.getPreferences(), editor);
|
|
|
|
|
|
|
|
editor.commit();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
//TODO: Shouldn't this live in MessagingController?
|
2010-04-05 22:54:48 -04:00
|
|
|
// Why should everything be in MessagingController? This is an Account-specific operation. --danapple0
|
2010-04-16 10:33:54 -04:00
|
|
|
public AccountStats getStats(Context context) throws MessagingException
|
2010-03-03 23:00:30 -05:00
|
|
|
{
|
2010-04-21 22:20:35 -04:00
|
|
|
long startTime = System.currentTimeMillis();
|
2010-04-16 10:33:54 -04:00
|
|
|
AccountStats stats = new AccountStats();
|
2010-03-03 23:00:30 -05:00
|
|
|
int unreadMessageCount = 0;
|
2010-04-16 10:33:54 -04:00
|
|
|
int flaggedMessageCount = 0;
|
2010-03-03 23:00:30 -05:00
|
|
|
LocalStore localStore = getLocalStore();
|
2010-04-18 22:55:02 -04:00
|
|
|
if (K9.measureAccounts())
|
|
|
|
{
|
|
|
|
stats.size = localStore.getSize();
|
|
|
|
}
|
2010-03-03 23:00:30 -05:00
|
|
|
Account.FolderMode aMode = getFolderDisplayMode();
|
|
|
|
Preferences prefs = Preferences.getPreferences(context);
|
2010-04-21 22:20:35 -04:00
|
|
|
long folderLoadStart = System.currentTimeMillis();
|
|
|
|
List<? extends Folder> folders = localStore.getPersonalNamespaces();
|
|
|
|
long folderLoadEnd = System.currentTimeMillis();
|
|
|
|
long folderEvalStart = folderLoadEnd;
|
|
|
|
for (Folder folder : folders)
|
2010-03-03 23:00:30 -05:00
|
|
|
{
|
2010-04-21 22:20:35 -04:00
|
|
|
LocalFolder localFolder = (LocalFolder)folder;
|
|
|
|
//folder.refresh(prefs);
|
|
|
|
Folder.FolderClass fMode = localFolder.getDisplayClass(prefs);
|
2010-03-03 23:00:30 -05:00
|
|
|
|
|
|
|
if (folder.getName().equals(getTrashFolderName()) == false &&
|
|
|
|
folder.getName().equals(getDraftsFolderName()) == false &&
|
|
|
|
folder.getName().equals(getOutboxFolderName()) == false &&
|
|
|
|
folder.getName().equals(getSentFolderName()) == false &&
|
|
|
|
folder.getName().equals(getErrorFolderName()) == false)
|
|
|
|
{
|
|
|
|
if (aMode == Account.FolderMode.NONE)
|
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if (aMode == Account.FolderMode.FIRST_CLASS &&
|
|
|
|
fMode != Folder.FolderClass.FIRST_CLASS)
|
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if (aMode == Account.FolderMode.FIRST_AND_SECOND_CLASS &&
|
|
|
|
fMode != Folder.FolderClass.FIRST_CLASS &&
|
|
|
|
fMode != Folder.FolderClass.SECOND_CLASS)
|
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if (aMode == Account.FolderMode.NOT_SECOND_CLASS &&
|
|
|
|
fMode == Folder.FolderClass.SECOND_CLASS)
|
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
unreadMessageCount += folder.getUnreadMessageCount();
|
2010-04-16 10:33:54 -04:00
|
|
|
flaggedMessageCount += folder.getFlaggedMessageCount();
|
2010-04-29 00:59:14 -04:00
|
|
|
|
2010-03-03 23:00:30 -05:00
|
|
|
}
|
|
|
|
}
|
2010-04-21 22:20:35 -04:00
|
|
|
long folderEvalEnd = System.currentTimeMillis();
|
2010-04-16 10:33:54 -04:00
|
|
|
stats.unreadMessageCount = unreadMessageCount;
|
|
|
|
stats.flaggedMessageCount = flaggedMessageCount;
|
2010-04-21 22:20:35 -04:00
|
|
|
long endTime = System.currentTimeMillis();
|
|
|
|
if (K9.DEBUG)
|
|
|
|
Log.d(K9.LOG_TAG, "Account.getStats() on " + getDescription() + " took " + (endTime - startTime) + " ms;"
|
2010-04-29 00:59:14 -04:00
|
|
|
+ " loading " + folders.size() + " took " + (folderLoadEnd - folderLoadStart) + " ms;"
|
|
|
|
+ " evaluating took " + (folderEvalEnd - folderEvalStart) + " ms");
|
2010-04-16 10:33:54 -04:00
|
|
|
return stats;
|
2010-03-03 23:00:30 -05:00
|
|
|
}
|
|
|
|
|
2010-04-29 00:59:14 -04:00
|
|
|
|
|
|
|
public void setChipColor(int color)
|
|
|
|
{
|
|
|
|
mChipColor = color;
|
|
|
|
}
|
|
|
|
|
|
|
|
public int getChipColor()
|
|
|
|
{
|
|
|
|
return mChipColor;
|
|
|
|
}
|
|
|
|
|
2010-03-03 23:00:30 -05:00
|
|
|
public String getUuid()
|
|
|
|
{
|
|
|
|
return mUuid;
|
|
|
|
}
|
|
|
|
|
|
|
|
public Uri getContentUri()
|
|
|
|
{
|
|
|
|
return Uri.parse("content://accounts/" + getUuid());
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized String getStoreUri()
|
|
|
|
{
|
|
|
|
return mStoreUri;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setStoreUri(String storeUri)
|
|
|
|
{
|
|
|
|
this.mStoreUri = storeUri;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized String getTransportUri()
|
|
|
|
{
|
|
|
|
return mTransportUri;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setTransportUri(String transportUri)
|
|
|
|
{
|
|
|
|
this.mTransportUri = transportUri;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized String getDescription()
|
|
|
|
{
|
|
|
|
return mDescription;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setDescription(String description)
|
|
|
|
{
|
|
|
|
this.mDescription = description;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized String getName()
|
|
|
|
{
|
|
|
|
return identities.get(0).getName();
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setName(String name)
|
|
|
|
{
|
|
|
|
identities.get(0).setName(name);
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized boolean getSignatureUse()
|
|
|
|
{
|
|
|
|
return identities.get(0).getSignatureUse();
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setSignatureUse(boolean signatureUse)
|
|
|
|
{
|
|
|
|
identities.get(0).setSignatureUse(signatureUse);
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized String getSignature()
|
|
|
|
{
|
|
|
|
return identities.get(0).getSignature();
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setSignature(String signature)
|
|
|
|
{
|
|
|
|
identities.get(0).setSignature(signature);
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized String getEmail()
|
|
|
|
{
|
|
|
|
return identities.get(0).getEmail();
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setEmail(String email)
|
|
|
|
{
|
|
|
|
identities.get(0).setEmail(email);
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized String getAlwaysBcc()
|
|
|
|
{
|
|
|
|
return mAlwaysBcc;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setAlwaysBcc(String alwaysBcc)
|
|
|
|
{
|
|
|
|
this.mAlwaysBcc = alwaysBcc;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized boolean isVibrate()
|
|
|
|
{
|
|
|
|
return mVibrate;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setVibrate(boolean vibrate)
|
|
|
|
{
|
|
|
|
mVibrate = vibrate;
|
|
|
|
}
|
|
|
|
|
2010-03-29 22:58:21 -04:00
|
|
|
|
|
|
|
|
2010-04-29 00:59:14 -04:00
|
|
|
/* Have we sent a new mail notification on this account */
|
|
|
|
public boolean isRingNotified()
|
|
|
|
{
|
|
|
|
return mRingNotified;
|
|
|
|
}
|
2010-03-29 22:58:21 -04:00
|
|
|
|
2010-04-29 00:59:14 -04:00
|
|
|
public void setRingNotified(boolean ringNotified)
|
|
|
|
{
|
|
|
|
mRingNotified = ringNotified;
|
|
|
|
}
|
2010-03-29 22:58:21 -04:00
|
|
|
|
2010-04-29 00:59:14 -04:00
|
|
|
public synchronized String getRingtone()
|
2010-03-03 23:00:30 -05:00
|
|
|
{
|
|
|
|
return mRingtoneUri;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setRingtone(String ringtoneUri)
|
|
|
|
{
|
|
|
|
mRingtoneUri = ringtoneUri;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized String getLocalStoreUri()
|
|
|
|
{
|
|
|
|
return mLocalStoreUri;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setLocalStoreUri(String localStoreUri)
|
|
|
|
{
|
|
|
|
this.mLocalStoreUri = localStoreUri;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns -1 for never.
|
|
|
|
*/
|
|
|
|
public synchronized int getAutomaticCheckIntervalMinutes()
|
|
|
|
{
|
|
|
|
return mAutomaticCheckIntervalMinutes;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param automaticCheckIntervalMinutes or -1 for never.
|
|
|
|
*/
|
|
|
|
public synchronized boolean setAutomaticCheckIntervalMinutes(int automaticCheckIntervalMinutes)
|
|
|
|
{
|
|
|
|
int oldInterval = this.mAutomaticCheckIntervalMinutes;
|
|
|
|
int newInterval = automaticCheckIntervalMinutes;
|
|
|
|
this.mAutomaticCheckIntervalMinutes = automaticCheckIntervalMinutes;
|
2010-04-29 00:59:14 -04:00
|
|
|
|
2010-03-03 23:00:30 -05:00
|
|
|
return (oldInterval != newInterval);
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized int getDisplayCount()
|
|
|
|
{
|
|
|
|
if (mDisplayCount == -1)
|
|
|
|
{
|
|
|
|
this.mDisplayCount = K9.DEFAULT_VISIBLE_LIMIT;
|
|
|
|
}
|
|
|
|
return mDisplayCount;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setDisplayCount(int displayCount)
|
|
|
|
{
|
|
|
|
if (displayCount != -1)
|
|
|
|
{
|
|
|
|
this.mDisplayCount = displayCount;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
this.mDisplayCount = K9.DEFAULT_VISIBLE_LIMIT;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized long getLastAutomaticCheckTime()
|
|
|
|
{
|
|
|
|
return mLastAutomaticCheckTime;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setLastAutomaticCheckTime(long lastAutomaticCheckTime)
|
|
|
|
{
|
|
|
|
this.mLastAutomaticCheckTime = lastAutomaticCheckTime;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized boolean isNotifyNewMail()
|
|
|
|
{
|
|
|
|
return mNotifyNewMail;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setNotifyNewMail(boolean notifyNewMail)
|
|
|
|
{
|
|
|
|
this.mNotifyNewMail = notifyNewMail;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized int getDeletePolicy()
|
|
|
|
{
|
|
|
|
return mDeletePolicy;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setDeletePolicy(int deletePolicy)
|
|
|
|
{
|
|
|
|
this.mDeletePolicy = deletePolicy;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized String getDraftsFolderName()
|
|
|
|
{
|
|
|
|
return mDraftsFolderName;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setDraftsFolderName(String draftsFolderName)
|
|
|
|
{
|
|
|
|
mDraftsFolderName = draftsFolderName;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized String getSentFolderName()
|
|
|
|
{
|
|
|
|
return mSentFolderName;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized String getErrorFolderName()
|
|
|
|
{
|
|
|
|
return K9.ERROR_FOLDER_NAME;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setSentFolderName(String sentFolderName)
|
|
|
|
{
|
|
|
|
mSentFolderName = sentFolderName;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized String getTrashFolderName()
|
|
|
|
{
|
|
|
|
return mTrashFolderName;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setTrashFolderName(String trashFolderName)
|
|
|
|
{
|
|
|
|
mTrashFolderName = trashFolderName;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized String getOutboxFolderName()
|
|
|
|
{
|
|
|
|
return mOutboxFolderName;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setOutboxFolderName(String outboxFolderName)
|
|
|
|
{
|
|
|
|
mOutboxFolderName = outboxFolderName;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized String getAutoExpandFolderName()
|
|
|
|
{
|
|
|
|
return mAutoExpandFolderName;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setAutoExpandFolderName(String autoExpandFolderName)
|
|
|
|
{
|
|
|
|
mAutoExpandFolderName = autoExpandFolderName;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized int getAccountNumber()
|
|
|
|
{
|
|
|
|
return mAccountNumber;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized FolderMode getFolderDisplayMode()
|
|
|
|
{
|
|
|
|
return mFolderDisplayMode;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized boolean setFolderDisplayMode(FolderMode displayMode)
|
|
|
|
{
|
|
|
|
FolderMode oldDisplayMode = mFolderDisplayMode;
|
|
|
|
mFolderDisplayMode = displayMode;
|
|
|
|
return oldDisplayMode != displayMode;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized FolderMode getFolderSyncMode()
|
|
|
|
{
|
|
|
|
return mFolderSyncMode;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized boolean setFolderSyncMode(FolderMode syncMode)
|
|
|
|
{
|
|
|
|
FolderMode oldSyncMode = mFolderSyncMode;
|
|
|
|
mFolderSyncMode = syncMode;
|
2010-04-29 00:59:14 -04:00
|
|
|
|
2010-03-03 23:00:30 -05:00
|
|
|
if (syncMode == FolderMode.NONE && oldSyncMode != FolderMode.NONE)
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
if (syncMode != FolderMode.NONE && oldSyncMode == FolderMode.NONE)
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized FolderMode getFolderPushMode()
|
|
|
|
{
|
|
|
|
return mFolderPushMode;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized boolean setFolderPushMode(FolderMode pushMode)
|
|
|
|
{
|
|
|
|
FolderMode oldPushMode = mFolderPushMode;
|
2010-04-29 00:59:14 -04:00
|
|
|
|
2010-03-03 23:00:30 -05:00
|
|
|
mFolderPushMode = pushMode;
|
|
|
|
return pushMode != oldPushMode;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized boolean isShowOngoing()
|
|
|
|
{
|
|
|
|
return mNotifySync;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setShowOngoing(boolean showOngoing)
|
|
|
|
{
|
|
|
|
this.mNotifySync = showOngoing;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized HideButtons getHideMessageViewButtons()
|
|
|
|
{
|
|
|
|
return mHideMessageViewButtons;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setHideMessageViewButtons(HideButtons hideMessageViewButtons)
|
|
|
|
{
|
|
|
|
mHideMessageViewButtons = hideMessageViewButtons;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized FolderMode getFolderTargetMode()
|
|
|
|
{
|
|
|
|
return mFolderTargetMode;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setFolderTargetMode(FolderMode folderTargetMode)
|
|
|
|
{
|
|
|
|
mFolderTargetMode = folderTargetMode;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized boolean isSignatureBeforeQuotedText()
|
|
|
|
{
|
|
|
|
return mIsSignatureBeforeQuotedText;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setSignatureBeforeQuotedText(boolean mIsSignatureBeforeQuotedText)
|
|
|
|
{
|
|
|
|
this.mIsSignatureBeforeQuotedText = mIsSignatureBeforeQuotedText;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized boolean isNotifySelfNewMail()
|
|
|
|
{
|
|
|
|
return mNotifySelfNewMail;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setNotifySelfNewMail(boolean notifySelfNewMail)
|
|
|
|
{
|
|
|
|
mNotifySelfNewMail = notifySelfNewMail;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized String getExpungePolicy()
|
|
|
|
{
|
|
|
|
return mExpungePolicy;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setExpungePolicy(String expungePolicy)
|
|
|
|
{
|
|
|
|
mExpungePolicy = expungePolicy;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized int getMaxPushFolders()
|
|
|
|
{
|
|
|
|
return mMaxPushFolders;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized boolean setMaxPushFolders(int maxPushFolders)
|
|
|
|
{
|
|
|
|
int oldMaxPushFolders = mMaxPushFolders;
|
|
|
|
mMaxPushFolders = maxPushFolders;
|
|
|
|
return oldMaxPushFolders != maxPushFolders;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized boolean isRing()
|
|
|
|
{
|
|
|
|
return mRing;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setRing(boolean ring)
|
|
|
|
{
|
|
|
|
mRing = ring;
|
|
|
|
}
|
|
|
|
|
|
|
|
public LocalStore getLocalStore() throws MessagingException
|
|
|
|
{
|
2010-04-29 00:59:14 -04:00
|
|
|
return Store.getLocalInstance(this, K9.app);
|
2010-03-03 23:00:30 -05:00
|
|
|
}
|
2010-04-29 00:59:14 -04:00
|
|
|
|
2010-03-03 23:00:30 -05:00
|
|
|
public Store getRemoteStore() throws MessagingException
|
|
|
|
{
|
2010-04-29 00:59:14 -04:00
|
|
|
return Store.getRemoteInstance(this);
|
2010-03-03 23:00:30 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public synchronized String toString()
|
|
|
|
{
|
|
|
|
return mDescription;
|
|
|
|
}
|
2010-04-29 00:59:14 -04:00
|
|
|
|
2010-03-06 19:30:40 -05:00
|
|
|
public void setCompression(String networkType, boolean useCompression)
|
|
|
|
{
|
|
|
|
compressionMap.put(networkType, useCompression);
|
|
|
|
}
|
2010-04-29 00:59:14 -04:00
|
|
|
|
2010-03-06 19:30:40 -05:00
|
|
|
public boolean useCompression(String networkType)
|
|
|
|
{
|
|
|
|
Boolean useCompression = compressionMap.get(networkType);
|
|
|
|
if (useCompression == null)
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return useCompression;
|
|
|
|
}
|
|
|
|
}
|
2010-04-29 00:59:14 -04:00
|
|
|
|
2010-03-06 19:30:40 -05:00
|
|
|
public boolean useCompression(int type)
|
|
|
|
{
|
|
|
|
String networkType = TYPE_OTHER;
|
|
|
|
switch (type)
|
|
|
|
{
|
|
|
|
case ConnectivityManager.TYPE_MOBILE:
|
|
|
|
networkType = TYPE_MOBILE;
|
|
|
|
break;
|
|
|
|
case ConnectivityManager.TYPE_WIFI:
|
|
|
|
networkType = TYPE_WIFI;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return useCompression(networkType);
|
|
|
|
}
|
2010-04-29 00:59:14 -04:00
|
|
|
|
2010-03-03 23:00:30 -05:00
|
|
|
@Override
|
|
|
|
public boolean equals(Object o)
|
|
|
|
{
|
|
|
|
if (o instanceof Account)
|
|
|
|
{
|
|
|
|
return ((Account)o).mUuid.equals(mUuid);
|
|
|
|
}
|
|
|
|
return super.equals(o);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public int hashCode()
|
|
|
|
{
|
|
|
|
return mUuid.hashCode();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private synchronized List<Identity> loadIdentities(SharedPreferences prefs)
|
|
|
|
{
|
|
|
|
List<Identity> newIdentities = new ArrayList<Identity>();
|
|
|
|
int ident = 0;
|
|
|
|
boolean gotOne = false;
|
|
|
|
do
|
|
|
|
{
|
|
|
|
gotOne = false;
|
|
|
|
String name = prefs.getString(mUuid + ".name." + ident, null);
|
|
|
|
String email = prefs.getString(mUuid + ".email." + ident, null);
|
|
|
|
boolean signatureUse = prefs.getBoolean(mUuid + ".signatureUse." + ident, true);
|
|
|
|
String signature = prefs.getString(mUuid + ".signature." + ident, null);
|
|
|
|
String description = prefs.getString(mUuid + ".description." + ident, null);
|
|
|
|
if (email != null)
|
|
|
|
{
|
|
|
|
Identity identity = new Identity();
|
|
|
|
identity.setName(name);
|
|
|
|
identity.setEmail(email);
|
|
|
|
identity.setSignatureUse(signatureUse);
|
|
|
|
identity.setSignature(signature);
|
|
|
|
identity.setDescription(description);
|
|
|
|
newIdentities.add(identity);
|
|
|
|
gotOne = true;
|
|
|
|
}
|
|
|
|
ident++;
|
|
|
|
}
|
|
|
|
while (gotOne);
|
|
|
|
|
|
|
|
if (newIdentities.size() == 0)
|
|
|
|
{
|
|
|
|
String name = prefs.getString(mUuid + ".name", null);
|
|
|
|
String email = prefs.getString(mUuid + ".email", null);
|
|
|
|
boolean signatureUse = prefs.getBoolean(mUuid + ".signatureUse", true);
|
|
|
|
String signature = prefs.getString(mUuid + ".signature", null);
|
|
|
|
Identity identity = new Identity();
|
|
|
|
identity.setName(name);
|
|
|
|
identity.setEmail(email);
|
|
|
|
identity.setSignatureUse(signatureUse);
|
|
|
|
identity.setSignature(signature);
|
|
|
|
identity.setDescription(email);
|
|
|
|
newIdentities.add(identity);
|
|
|
|
}
|
|
|
|
|
|
|
|
return newIdentities;
|
|
|
|
}
|
|
|
|
|
|
|
|
private synchronized void deleteIdentities(SharedPreferences prefs, SharedPreferences.Editor editor)
|
|
|
|
{
|
|
|
|
int ident = 0;
|
|
|
|
boolean gotOne = false;
|
|
|
|
do
|
|
|
|
{
|
|
|
|
gotOne = false;
|
|
|
|
String email = prefs.getString(mUuid + ".email." + ident, null);
|
|
|
|
if (email != null)
|
|
|
|
{
|
|
|
|
editor.remove(mUuid + ".name." + ident);
|
|
|
|
editor.remove(mUuid + ".email." + ident);
|
|
|
|
editor.remove(mUuid + ".signatureUse." + ident);
|
|
|
|
editor.remove(mUuid + ".signature." + ident);
|
|
|
|
editor.remove(mUuid + ".description." + ident);
|
|
|
|
gotOne = true;
|
|
|
|
}
|
|
|
|
ident++;
|
|
|
|
}
|
|
|
|
while (gotOne);
|
|
|
|
}
|
|
|
|
|
|
|
|
private synchronized void saveIdentities(SharedPreferences prefs, SharedPreferences.Editor editor)
|
|
|
|
{
|
|
|
|
deleteIdentities(prefs, editor);
|
|
|
|
int ident = 0;
|
|
|
|
|
|
|
|
for (Identity identity : identities)
|
|
|
|
{
|
|
|
|
editor.putString(mUuid + ".name." + ident, identity.getName());
|
|
|
|
editor.putString(mUuid + ".email." + ident, identity.getEmail());
|
|
|
|
editor.putBoolean(mUuid + ".signatureUse." + ident, identity.getSignatureUse());
|
|
|
|
editor.putString(mUuid + ".signature." + ident, identity.getSignature());
|
|
|
|
editor.putString(mUuid + ".description." + ident, identity.getDescription());
|
|
|
|
ident++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized List<Identity> getIdentities()
|
|
|
|
{
|
|
|
|
return identities;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void setIdentities(List<Identity> newIdentities)
|
|
|
|
{
|
|
|
|
identities = new ArrayList<Identity>(newIdentities);
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized Identity getIdentity(int i)
|
|
|
|
{
|
|
|
|
if (i < identities.size())
|
|
|
|
{
|
|
|
|
return identities.get(i);
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean isAnIdentity(Address[] addrs)
|
|
|
|
{
|
|
|
|
if (addrs == null)
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
for (Address addr : addrs)
|
|
|
|
{
|
|
|
|
if (findIdentity(addr) != null)
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean isAnIdentity(Address addr)
|
|
|
|
{
|
|
|
|
return findIdentity(addr) != null;
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized Identity findIdentity(Address addr)
|
|
|
|
{
|
|
|
|
for (Identity identity : identities)
|
|
|
|
{
|
|
|
|
String email = identity.getEmail();
|
|
|
|
if (email != null && email.equalsIgnoreCase(addr.getAddress()))
|
|
|
|
{
|
|
|
|
return identity;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
2010-04-05 22:54:48 -04:00
|
|
|
|
|
|
|
public Searchable getSearchableFolders()
|
|
|
|
{
|
|
|
|
return searchableFolders;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setSearchableFolders(Searchable searchableFolders)
|
|
|
|
{
|
|
|
|
this.searchableFolders = searchableFolders;
|
|
|
|
}
|
2010-05-09 11:27:41 -04:00
|
|
|
|
|
|
|
public int getIdleRefreshMinutes()
|
|
|
|
{
|
|
|
|
return mIdleRefreshMinutes;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setIdleRefreshMinutes(int idleRefreshMinutes)
|
|
|
|
{
|
|
|
|
mIdleRefreshMinutes = idleRefreshMinutes;
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean isPushPollOnConnect()
|
|
|
|
{
|
|
|
|
return mPushPollOnConnect;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setPushPollOnConnect(boolean pushPollOnConnect)
|
|
|
|
{
|
|
|
|
mPushPollOnConnect = pushPollOnConnect;
|
|
|
|
}
|
2010-03-03 23:00:30 -05:00
|
|
|
}
|