mirror of
https://github.com/M66B/FairEmail.git
synced 2025-02-22 14:11:00 +00:00
Added workaround for folder list processing error
This commit is contained in:
parent
e5f89e4d90
commit
8f84ccd178
1 changed files with 18 additions and 9 deletions
|
@ -930,18 +930,27 @@ public class EmailService implements AutoCloseable {
|
|||
List<EntityFolder> getFolders() throws MessagingException {
|
||||
List<EntityFolder> folders = new ArrayList<>();
|
||||
|
||||
for (Folder ifolder : getStore().getDefaultFolder().list("*")) {
|
||||
String fullName = ifolder.getFullName();
|
||||
String[] attrs = ((IMAPFolder) ifolder).getAttributes();
|
||||
String type = EntityFolder.getType(attrs, fullName, true);
|
||||
Log.i(fullName + " attrs=" + TextUtils.join(" ", attrs) + " type=" + type);
|
||||
try {
|
||||
for (Folder ifolder : getStore().getDefaultFolder().list("*")) {
|
||||
String fullName = ifolder.getFullName();
|
||||
String[] attrs = ((IMAPFolder) ifolder).getAttributes();
|
||||
String type = EntityFolder.getType(attrs, fullName, true);
|
||||
Log.i(fullName + " attrs=" + TextUtils.join(" ", attrs) + " type=" + type);
|
||||
|
||||
if (type != null)
|
||||
folders.add(new EntityFolder(fullName, type));
|
||||
if (type != null)
|
||||
folders.add(new EntityFolder(fullName, type));
|
||||
}
|
||||
|
||||
EntityFolder.guessTypes(folders);
|
||||
} catch (MessagingException ex) {
|
||||
if (ex.getMessage() != null &&
|
||||
ex.getMessage().contains("LIST processing failed")) {
|
||||
Log.w(ex);
|
||||
folders.add(new EntityFolder("Inbox", EntityFolder.INBOX));
|
||||
} else
|
||||
throw ex;
|
||||
}
|
||||
|
||||
EntityFolder.guessTypes(folders);
|
||||
|
||||
return folders;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue