mirror of https://github.com/M66B/FairEmail.git
Fixed setting message ID on append
This commit is contained in:
parent
186f32b173
commit
696c8b32d8
|
@ -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)
|
||||||
|
|
|
@ -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;
|
||||||
|
|
Loading…
Reference in New Issue