mirror of
https://github.com/moparisthebest/k-9
synced 2025-01-13 06:38:05 -05:00
Merge pull request #99 from andrewachen/autoconfig_gmail_yahoo
Do a better job of auto-configuring Yahoo! and Gmail accounts
This commit is contained in:
commit
c642b10b39
@ -225,7 +225,12 @@ public class AccountSetupBasics extends K9Activity
|
|||||||
mAccount.setDraftsFolderName(getString(R.string.special_mailbox_name_drafts));
|
mAccount.setDraftsFolderName(getString(R.string.special_mailbox_name_drafts));
|
||||||
mAccount.setTrashFolderName(getString(R.string.special_mailbox_name_trash));
|
mAccount.setTrashFolderName(getString(R.string.special_mailbox_name_trash));
|
||||||
mAccount.setArchiveFolderName(getString(R.string.special_mailbox_name_archive));
|
mAccount.setArchiveFolderName(getString(R.string.special_mailbox_name_archive));
|
||||||
|
// Yahoo! has a special folder for Spam, called "Bulk Mail".
|
||||||
|
if (incomingUriTemplate.getHost().toLowerCase().endsWith(".yahoo.com")) {
|
||||||
|
mAccount.setSpamFolderName("Bulk Mail");
|
||||||
|
} else {
|
||||||
mAccount.setSpamFolderName(getString(R.string.special_mailbox_name_spam));
|
mAccount.setSpamFolderName(getString(R.string.special_mailbox_name_spam));
|
||||||
|
}
|
||||||
mAccount.setSentFolderName(getString(R.string.special_mailbox_name_sent));
|
mAccount.setSentFolderName(getString(R.string.special_mailbox_name_sent));
|
||||||
AccountSetupCheckSettings.actionCheckSettings(this, mAccount, true, true);
|
AccountSetupCheckSettings.actionCheckSettings(this, mAccount, true, true);
|
||||||
} catch (UnsupportedEncodingException enc) {
|
} catch (UnsupportedEncodingException enc) {
|
||||||
|
@ -596,11 +596,81 @@ public class ImapStore extends Store {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Attempt to auto-configure folders by attributes if the server advertises that capability.
|
||||||
|
*
|
||||||
|
* The parsing here is essentially the same as
|
||||||
|
* {@link #listFolders(com.fsck.k9.mail.store.ImapStore.ImapConnection, boolean)}; we should try to consolidate
|
||||||
|
* this at some point. :(
|
||||||
|
* @param connection IMAP Connection
|
||||||
|
* @throws IOException uh oh!
|
||||||
|
* @throws MessagingException uh oh!
|
||||||
|
*/
|
||||||
|
private void autoconfigureFolders(final ImapConnection connection) throws IOException, MessagingException {
|
||||||
|
String commandResponse = null;
|
||||||
|
String commandOptions = "";
|
||||||
|
|
||||||
|
if (connection.capabilities.contains("XLIST")) {
|
||||||
|
if (K9.DEBUG) Log.d(K9.LOG_TAG, "Folder auto-configuration: Using XLIST.");
|
||||||
|
commandResponse = "XLIST";
|
||||||
|
} else if(connection.capabilities.contains("SPECIAL-USE")) {
|
||||||
|
if (K9.DEBUG) Log.d(K9.LOG_TAG, "Folder auto-configuration: Using RFC6154/SPECIAL-USE.");
|
||||||
|
commandResponse = "LIST";
|
||||||
|
commandOptions = " (SPECIAL-USE)";
|
||||||
|
} else {
|
||||||
|
if (K9.DEBUG) Log.d(K9.LOG_TAG, "No detected folder auto-configuration methods.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
final List<ImapResponse> responses =
|
||||||
|
connection.executeSimpleCommand(String.format("%s%s \"\" %s", commandResponse, commandOptions,
|
||||||
|
encodeString(getCombinedPrefix() + "*")));
|
||||||
|
|
||||||
|
for (ImapResponse response : responses) {
|
||||||
|
if (ImapResponseParser.equalsIgnoreCase(response.get(0), commandResponse)) {
|
||||||
|
|
||||||
|
String decodedFolderName;
|
||||||
|
try {
|
||||||
|
decodedFolderName = decodeFolderName(response.getString(3));
|
||||||
|
} catch (CharacterCodingException e) {
|
||||||
|
Log.w(K9.LOG_TAG, "Folder name not correctly encoded with the UTF-7 variant " +
|
||||||
|
"as defined by RFC 3501: " + response.getString(3), e);
|
||||||
|
// We currently just skip folders with malformed names.
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (mPathDelimeter == null) {
|
||||||
|
mPathDelimeter = response.getString(2);
|
||||||
|
mCombinedPrefix = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
ImapList attributes = response.getList(1);
|
||||||
|
for (int i = 0, count = attributes.size(); i < count; i++) {
|
||||||
|
String attribute = attributes.getString(i);
|
||||||
|
if (attribute.equals("\\Drafts")) {
|
||||||
|
mAccount.setDraftsFolderName(decodedFolderName);
|
||||||
|
if (K9.DEBUG) Log.d(K9.LOG_TAG, "Folder auto-configuration detected draft folder: " + decodedFolderName);
|
||||||
|
} else if (attribute.equals("\\Sent")) {
|
||||||
|
mAccount.setSentFolderName(decodedFolderName);
|
||||||
|
if (K9.DEBUG) Log.d(K9.LOG_TAG, "Folder auto-configuration detected sent folder: " + decodedFolderName);
|
||||||
|
} else if (attribute.equals("\\Spam")) {
|
||||||
|
mAccount.setSpamFolderName(decodedFolderName);
|
||||||
|
if (K9.DEBUG) Log.d(K9.LOG_TAG, "Folder auto-configuration detected spam folder: " + decodedFolderName);
|
||||||
|
} else if (attribute.equals("\\Trash")) {
|
||||||
|
mAccount.setTrashFolderName(decodedFolderName);
|
||||||
|
if (K9.DEBUG) Log.d(K9.LOG_TAG, "Folder auto-configuration detected trash folder: " + decodedFolderName);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void checkSettings() throws MessagingException {
|
public void checkSettings() throws MessagingException {
|
||||||
try {
|
try {
|
||||||
ImapConnection connection = new ImapConnection(new StoreImapSettings());
|
ImapConnection connection = new ImapConnection(new StoreImapSettings());
|
||||||
connection.open();
|
connection.open();
|
||||||
|
autoconfigureFolders(connection);
|
||||||
connection.close();
|
connection.close();
|
||||||
} catch (IOException ioe) {
|
} catch (IOException ioe) {
|
||||||
throw new MessagingException(K9.app.getString(R.string.error_unable_to_connect), ioe);
|
throw new MessagingException(K9.app.getString(R.string.error_unable_to_connect), ioe);
|
||||||
|
Loading…
Reference in New Issue
Block a user