Fixed setting message ID on append

This commit is contained in:
M66B 2019-02-20 08:57:53 +00:00
parent 186f32b173
commit 696c8b32d8
2 changed files with 11 additions and 13 deletions

View File

@ -19,8 +19,6 @@ package eu.faircode.email;
Copyright 2018-2019 by Marcel Bokhorst (M66B) Copyright 2018-2019 by Marcel Bokhorst (M66B)
*/ */
import java.io.InputStream;
import javax.mail.MessagingException; import javax.mail.MessagingException;
import javax.mail.Session; import javax.mail.Session;
import javax.mail.internet.MimeMessage; import javax.mail.internet.MimeMessage;
@ -33,11 +31,6 @@ public class MimeMessageEx extends MimeMessage {
this.msgid = msgid; this.msgid = msgid;
} }
MimeMessageEx(Session session, InputStream is, String msgid) throws MessagingException {
super(session, is);
this.msgid = msgid;
}
@Override @Override
public String getMessageID() throws MessagingException { public String getMessageID() throws MessagingException {
if (this.msgid == null) if (this.msgid == null)

View File

@ -1848,14 +1848,15 @@ public class ServiceSynchronize extends LifecycleService {
imessage.writeTo(bos); imessage.writeTo(bos);
// Deserialize target message // Deserialize target message
// Make sure the message has a message ID
ByteArrayInputStream bis = new ByteArrayInputStream(bos.toByteArray()); ByteArrayInputStream bis = new ByteArrayInputStream(bos.toByteArray());
String msgid = message.msgid; Message icopy = new MimeMessage(isession, bis);
if (msgid == null) {
msgid = EntityMessage.generateMessageId(); // Make sure the message has a message ID
if (message.msgid == null) {
String msgid = EntityMessage.generateMessageId();
Log.i(target.name + " generated message id=" + msgid); Log.i(target.name + " generated message id=" + msgid);
icopy.setHeader("Message-ID", msgid);
} }
Message icopy = new MimeMessageEx(isession, bis, msgid);
try { try {
// Needed to read flags // Needed to read flags
@ -2203,11 +2204,15 @@ public class ServiceSynchronize extends LifecycleService {
return uids[0].uid; return uids[0].uid;
} else { } else {
ifolder.appendMessages(new Message[]{imessage}); ifolder.appendMessages(new Message[]{imessage});
long uid = -1; long uid = -1;
Message[] messages = ifolder.search(new MessageIDTerm(imessage.getMessageID())); String msgid = imessage.getMessageID();
Log.i("Searching for appended msgid=" + msgid);
Message[] messages = ifolder.search(new MessageIDTerm(msgid));
if (messages != null) if (messages != null)
for (Message iappended : messages) { for (Message iappended : messages) {
long muid = ifolder.getUID(iappended); long muid = ifolder.getUID(iappended);
Log.i("Found appended uid=" + muid);
// RFC3501: Unique identifiers are assigned in a strictly ascending fashion // RFC3501: Unique identifiers are assigned in a strictly ascending fashion
if (muid > uid) if (muid > uid)
uid = muid; uid = muid;