Match attachments without name/cid by type/size

pull/162/head
M66B 5 years ago
parent d869731306
commit 57f9de9367

@ -885,19 +885,32 @@ public class MessageHelper {
void downloadAttachment(Context context, EntityAttachment local) throws IOException, MessagingException { void downloadAttachment(Context context, EntityAttachment local) throws IOException, MessagingException {
List<EntityAttachment> remotes = getAttachments(); List<EntityAttachment> remotes = getAttachments();
// Match attachment by attributes
// Some servers order attachments randomly // Some servers order attachments randomly
boolean found = false; int index = -1;
// Match attachment by name/cid
for (int i = 0; i < remotes.size(); i++) { for (int i = 0; i < remotes.size(); i++) {
EntityAttachment remote = remotes.get(i); EntityAttachment remote = remotes.get(i);
if (Objects.equals(remote.name, local.name) && if (Objects.equals(remote.name, local.name) &&
Objects.equals(remote.cid, local.cid)) { Objects.equals(remote.cid, local.cid)) {
found = true; index = i;
downloadAttachment(context, i, local); break;
} }
} }
if (!found) { // Match attachment by type/size
if (index < 0)
for (int i = 0; i < remotes.size(); i++) {
EntityAttachment remote = remotes.get(i);
if (remote.name == null && remote.cid == null &&
Objects.equals(remote.type, local.type) &&
Objects.equals(remote.size, local.size)) {
index = i;
break;
}
}
if (index < 0) {
Map<String, String> crumb = new HashMap<>(); Map<String, String> crumb = new HashMap<>();
crumb.put("local", local.toString()); crumb.put("local", local.toString());
Log.w("Attachment not found local=" + local); Log.w("Attachment not found local=" + local);
@ -909,10 +922,12 @@ public class MessageHelper {
Log.breadcrumb("attachments", crumb); Log.breadcrumb("attachments", crumb);
throw new IllegalArgumentException("Attachment not found"); throw new IllegalArgumentException("Attachment not found");
} }
downloadAttachment(context, index, local);
} }
void downloadAttachment(Context context, int index, EntityAttachment local) throws MessagingException, IOException { void downloadAttachment(Context context, int index, EntityAttachment local) throws MessagingException, IOException {
Log.i("downloading attachment id=" + local.id); Log.i("downloading attachment id=" + local.id + " index=" + index + " " + local);
DB db = DB.getInstance(context); DB db = DB.getInstance(context);

Loading…
Cancel
Save