|
|
|
@ -2299,255 +2299,277 @@ class Core {
|
|
|
|
|
? imessages.length
|
|
|
|
|
: Math.min(imessages.length, account.max_messages));
|
|
|
|
|
|
|
|
|
|
boolean sync = true;
|
|
|
|
|
if (imessages.length > 0 && folder.last_sync_count != null &&
|
|
|
|
|
imessages.length == folder.last_sync_count) {
|
|
|
|
|
// Check if last message known as new messages indicator
|
|
|
|
|
MessageHelper helper = new MessageHelper((MimeMessage) imessages[imessages.length - 1], context);
|
|
|
|
|
String msgid = helper.getMessageID();
|
|
|
|
|
if (msgid != null) {
|
|
|
|
|
int count = db.message().countMessageByMsgId(folder.id, msgid);
|
|
|
|
|
if (count == 1) {
|
|
|
|
|
Log.i(account.name + " POP having last msgid=" + msgid);
|
|
|
|
|
sync = false;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
EntityLog.log(context, account.name + " POP" +
|
|
|
|
|
" device=" + ids.size() +
|
|
|
|
|
" server=" + imessages.length +
|
|
|
|
|
" max=" + max + "/" + account.max_messages +
|
|
|
|
|
" last=" + folder.last_sync_count +
|
|
|
|
|
" sync=" + sync +
|
|
|
|
|
" uidl=" + hasUidl);
|
|
|
|
|
|
|
|
|
|
// Index IDs
|
|
|
|
|
Map<String, String> uidlMsgId = new HashMap<>();
|
|
|
|
|
for (TupleUidl id : ids) {
|
|
|
|
|
if (id.uidl != null && id.msgid != null)
|
|
|
|
|
uidlMsgId.put(id.uidl, id.msgid);
|
|
|
|
|
}
|
|
|
|
|
folder.last_sync_count = imessages.length;
|
|
|
|
|
db.folder().setFolderLastSyncCount(folder.id, folder.last_sync_count);
|
|
|
|
|
|
|
|
|
|
// Fetch UIDLs
|
|
|
|
|
if (hasUidl) {
|
|
|
|
|
FetchProfile ifetch = new FetchProfile();
|
|
|
|
|
ifetch.add(UIDFolder.FetchProfileItem.UID); // This will fetch all UIDs
|
|
|
|
|
ifolder.fetch(imessages, ifetch);
|
|
|
|
|
}
|
|
|
|
|
if (sync) {
|
|
|
|
|
// Index IDs
|
|
|
|
|
Map<String, String> uidlMsgId = new HashMap<>();
|
|
|
|
|
for (TupleUidl id : ids) {
|
|
|
|
|
if (id.uidl != null && id.msgid != null)
|
|
|
|
|
uidlMsgId.put(id.uidl, id.msgid);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!account.leave_on_device) {
|
|
|
|
|
// Fetch UIDLs
|
|
|
|
|
if (hasUidl) {
|
|
|
|
|
Map<String, TupleUidl> known = new HashMap<>();
|
|
|
|
|
for (TupleUidl id : ids)
|
|
|
|
|
if (id.uidl != null)
|
|
|
|
|
known.put(id.uidl, id);
|
|
|
|
|
|
|
|
|
|
for (Message imessage : imessages) {
|
|
|
|
|
String uidl = ifolder.getUID(imessage);
|
|
|
|
|
if (TextUtils.isEmpty(uidl))
|
|
|
|
|
known.clear(); // better safe than sorry
|
|
|
|
|
else
|
|
|
|
|
known.remove(uidl);
|
|
|
|
|
}
|
|
|
|
|
FetchProfile ifetch = new FetchProfile();
|
|
|
|
|
ifetch.add(UIDFolder.FetchProfileItem.UID); // This will fetch all UIDs
|
|
|
|
|
ifolder.fetch(imessages, ifetch);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for (TupleUidl uidl : known.values()) {
|
|
|
|
|
EntityLog.log(context, account.name + " POP purging uidl=" + uidl.uidl);
|
|
|
|
|
db.message().deleteMessage(uidl.id);
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
Map<String, TupleUidl> known = new HashMap<>();
|
|
|
|
|
for (TupleUidl id : ids)
|
|
|
|
|
if (id.msgid != null)
|
|
|
|
|
known.put(id.msgid, id);
|
|
|
|
|
if (!account.leave_on_device) {
|
|
|
|
|
if (hasUidl) {
|
|
|
|
|
Map<String, TupleUidl> known = new HashMap<>();
|
|
|
|
|
for (TupleUidl id : ids)
|
|
|
|
|
if (id.uidl != null)
|
|
|
|
|
known.put(id.uidl, id);
|
|
|
|
|
|
|
|
|
|
for (Message imessage : imessages) {
|
|
|
|
|
String uidl = ifolder.getUID(imessage);
|
|
|
|
|
if (TextUtils.isEmpty(uidl))
|
|
|
|
|
known.clear(); // better safe than sorry
|
|
|
|
|
else
|
|
|
|
|
known.remove(uidl);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for (int i = imessages.length - max; i < imessages.length; i++) {
|
|
|
|
|
Message imessage = imessages[i];
|
|
|
|
|
MessageHelper helper = new MessageHelper((MimeMessage) imessage, context);
|
|
|
|
|
String msgid = helper.getMessageID(); // expensive!
|
|
|
|
|
if (!TextUtils.isEmpty(msgid))
|
|
|
|
|
known.remove(msgid);
|
|
|
|
|
}
|
|
|
|
|
for (TupleUidl uidl : known.values()) {
|
|
|
|
|
EntityLog.log(context, account.name + " POP purging uidl=" + uidl.uidl);
|
|
|
|
|
db.message().deleteMessage(uidl.id);
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
Map<String, TupleUidl> known = new HashMap<>();
|
|
|
|
|
for (TupleUidl id : ids)
|
|
|
|
|
if (id.msgid != null)
|
|
|
|
|
known.put(id.msgid, id);
|
|
|
|
|
|
|
|
|
|
for (int i = imessages.length - max; i < imessages.length; i++) {
|
|
|
|
|
Message imessage = imessages[i];
|
|
|
|
|
MessageHelper helper = new MessageHelper((MimeMessage) imessage, context);
|
|
|
|
|
String msgid = helper.getMessageID(); // expensive!
|
|
|
|
|
if (!TextUtils.isEmpty(msgid))
|
|
|
|
|
known.remove(msgid);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for (TupleUidl uidl : known.values()) {
|
|
|
|
|
EntityLog.log(context, account.name + " POP purging msgid=" + uidl.msgid);
|
|
|
|
|
db.message().deleteMessage(uidl.id);
|
|
|
|
|
for (TupleUidl uidl : known.values()) {
|
|
|
|
|
EntityLog.log(context, account.name + " POP purging msgid=" + uidl.msgid);
|
|
|
|
|
db.message().deleteMessage(uidl.id);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
boolean _new = true;
|
|
|
|
|
for (int i = imessages.length - 1; i >= imessages.length - max; i--) {
|
|
|
|
|
Message imessage = imessages[i];
|
|
|
|
|
try {
|
|
|
|
|
if (!state.isRunning())
|
|
|
|
|
return;
|
|
|
|
|
boolean _new = true;
|
|
|
|
|
for (int i = imessages.length - 1; i >= imessages.length - max; i--) {
|
|
|
|
|
Message imessage = imessages[i];
|
|
|
|
|
try {
|
|
|
|
|
if (!state.isRunning())
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
MessageHelper helper = new MessageHelper((MimeMessage) imessage, context);
|
|
|
|
|
MessageHelper helper = new MessageHelper((MimeMessage) imessage, context);
|
|
|
|
|
|
|
|
|
|
String uidl;
|
|
|
|
|
String msgid;
|
|
|
|
|
if (hasUidl) {
|
|
|
|
|
uidl = ifolder.getUID(imessage);
|
|
|
|
|
if (TextUtils.isEmpty(uidl)) {
|
|
|
|
|
EntityLog.log(context, account.name + " POP no uidl");
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
String uidl;
|
|
|
|
|
String msgid;
|
|
|
|
|
if (hasUidl) {
|
|
|
|
|
uidl = ifolder.getUID(imessage);
|
|
|
|
|
if (TextUtils.isEmpty(uidl)) {
|
|
|
|
|
EntityLog.log(context, account.name + " POP no uidl");
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
msgid = uidlMsgId.get(uidl);
|
|
|
|
|
if (msgid == null) {
|
|
|
|
|
msgid = uidlMsgId.get(uidl);
|
|
|
|
|
if (msgid == null) {
|
|
|
|
|
msgid = helper.getMessageID();
|
|
|
|
|
if (TextUtils.isEmpty(msgid))
|
|
|
|
|
msgid = uidl;
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
uidl = null;
|
|
|
|
|
msgid = helper.getMessageID();
|
|
|
|
|
if (TextUtils.isEmpty(msgid))
|
|
|
|
|
msgid = uidl;
|
|
|
|
|
|
|
|
|
|
if (TextUtils.isEmpty(msgid)) {
|
|
|
|
|
Long time = helper.getReceived();
|
|
|
|
|
if (time == null)
|
|
|
|
|
time = helper.getSent();
|
|
|
|
|
if (time != null)
|
|
|
|
|
msgid = Long.toString(time);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
uidl = null;
|
|
|
|
|
msgid = helper.getMessageID();
|
|
|
|
|
|
|
|
|
|
if (TextUtils.isEmpty(msgid)) {
|
|
|
|
|
Long time = helper.getReceived();
|
|
|
|
|
if (time == null)
|
|
|
|
|
time = helper.getSent();
|
|
|
|
|
if (time != null)
|
|
|
|
|
msgid = Long.toString(time);
|
|
|
|
|
EntityLog.log(context, account.name + " POP no msgid uidl=" + uidl);
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (TextUtils.isEmpty(msgid)) {
|
|
|
|
|
EntityLog.log(context, account.name + " POP no msgid uidl=" + uidl);
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
if (db.message().countMessageByMsgId(folder.id, msgid) > 0) {
|
|
|
|
|
_new = false;
|
|
|
|
|
Log.i(account.name + " POP having " + msgid + "/" + uidl);
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (db.message().countMessageByMsgId(folder.id, msgid) > 0) {
|
|
|
|
|
_new = false;
|
|
|
|
|
Log.i(account.name + " POP having " + msgid + "/" + uidl);
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
try {
|
|
|
|
|
Long sent = helper.getSent();
|
|
|
|
|
Long received = helper.getReceivedHeader();
|
|
|
|
|
if (received == null)
|
|
|
|
|
received = sent;
|
|
|
|
|
if (received == null)
|
|
|
|
|
received = 0L;
|
|
|
|
|
|
|
|
|
|
boolean seen = (received <= account.created);
|
|
|
|
|
EntityLog.log(context, account.name + " POP sync=" + uidl + "/" + msgid +
|
|
|
|
|
" new=" + _new + " seen=" + seen);
|
|
|
|
|
|
|
|
|
|
String[] authentication = helper.getAuthentication();
|
|
|
|
|
MessageHelper.MessageParts parts = helper.getMessageParts();
|
|
|
|
|
|
|
|
|
|
EntityMessage message = new EntityMessage();
|
|
|
|
|
message.account = folder.account;
|
|
|
|
|
message.folder = folder.id;
|
|
|
|
|
message.uid = null;
|
|
|
|
|
message.uidl = uidl;
|
|
|
|
|
message.msgid = msgid;
|
|
|
|
|
message.hash = helper.getHash();
|
|
|
|
|
message.references = TextUtils.join(" ", helper.getReferences());
|
|
|
|
|
message.inreplyto = helper.getInReplyTo();
|
|
|
|
|
message.deliveredto = helper.getDeliveredTo();
|
|
|
|
|
message.thread = helper.getThreadId(context, account.id, 0);
|
|
|
|
|
message.priority = helper.getPriority();
|
|
|
|
|
message.auto_submitted = helper.getAutoSubmitted();
|
|
|
|
|
message.receipt_request = helper.getReceiptRequested();
|
|
|
|
|
message.receipt_to = helper.getReceiptTo();
|
|
|
|
|
message.bimi_selector = helper.getBimiSelector();
|
|
|
|
|
message.dkim = MessageHelper.getAuthentication("dkim", authentication);
|
|
|
|
|
message.spf = MessageHelper.getAuthentication("spf", authentication);
|
|
|
|
|
message.dmarc = MessageHelper.getAuthentication("dmarc", authentication);
|
|
|
|
|
message.return_path = helper.getReturnPath();
|
|
|
|
|
message.submitter = helper.getSender();
|
|
|
|
|
message.from = helper.getFrom();
|
|
|
|
|
message.to = helper.getTo();
|
|
|
|
|
message.cc = helper.getCc();
|
|
|
|
|
message.bcc = helper.getBcc();
|
|
|
|
|
message.reply = helper.getReply();
|
|
|
|
|
message.list_post = helper.getListPost();
|
|
|
|
|
message.unsubscribe = helper.getListUnsubscribe();
|
|
|
|
|
message.headers = helper.getHeaders();
|
|
|
|
|
message.subject = helper.getSubject();
|
|
|
|
|
message.size = parts.getBodySize();
|
|
|
|
|
message.total = helper.getSize();
|
|
|
|
|
message.content = false;
|
|
|
|
|
message.encrypt = parts.getEncryption();
|
|
|
|
|
message.ui_encrypt = message.encrypt;
|
|
|
|
|
message.received = received;
|
|
|
|
|
message.sent = sent;
|
|
|
|
|
message.seen = seen;
|
|
|
|
|
message.answered = false;
|
|
|
|
|
message.flagged = false;
|
|
|
|
|
message.flags = null;
|
|
|
|
|
message.keywords = new String[0];
|
|
|
|
|
message.ui_seen = seen;
|
|
|
|
|
message.ui_answered = false;
|
|
|
|
|
message.ui_flagged = false;
|
|
|
|
|
message.ui_hide = false;
|
|
|
|
|
message.ui_found = false;
|
|
|
|
|
message.ui_ignored = !_new;
|
|
|
|
|
message.ui_browsed = false;
|
|
|
|
|
|
|
|
|
|
if (message.deliveredto != null)
|
|
|
|
|
try {
|
|
|
|
|
Address deliveredto = new InternetAddress(message.deliveredto);
|
|
|
|
|
if (MessageHelper.equalEmail(new Address[]{deliveredto}, message.to))
|
|
|
|
|
message.deliveredto = null;
|
|
|
|
|
} catch (AddressException ex) {
|
|
|
|
|
Log.w(ex);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
Long sent = helper.getSent();
|
|
|
|
|
Long received = helper.getReceivedHeader();
|
|
|
|
|
if (received == null)
|
|
|
|
|
received = sent;
|
|
|
|
|
if (received == null)
|
|
|
|
|
received = 0L;
|
|
|
|
|
|
|
|
|
|
boolean seen = (received <= account.created);
|
|
|
|
|
EntityLog.log(context, account.name + " POP sync=" + uidl + "/" + msgid +
|
|
|
|
|
" new=" + _new + " seen=" + seen);
|
|
|
|
|
|
|
|
|
|
String[] authentication = helper.getAuthentication();
|
|
|
|
|
MessageHelper.MessageParts parts = helper.getMessageParts();
|
|
|
|
|
|
|
|
|
|
EntityMessage message = new EntityMessage();
|
|
|
|
|
message.account = folder.account;
|
|
|
|
|
message.folder = folder.id;
|
|
|
|
|
message.uid = null;
|
|
|
|
|
message.uidl = uidl;
|
|
|
|
|
message.msgid = msgid;
|
|
|
|
|
message.hash = helper.getHash();
|
|
|
|
|
message.references = TextUtils.join(" ", helper.getReferences());
|
|
|
|
|
message.inreplyto = helper.getInReplyTo();
|
|
|
|
|
message.deliveredto = helper.getDeliveredTo();
|
|
|
|
|
message.thread = helper.getThreadId(context, account.id, 0);
|
|
|
|
|
message.priority = helper.getPriority();
|
|
|
|
|
message.auto_submitted = helper.getAutoSubmitted();
|
|
|
|
|
message.receipt_request = helper.getReceiptRequested();
|
|
|
|
|
message.receipt_to = helper.getReceiptTo();
|
|
|
|
|
message.bimi_selector = helper.getBimiSelector();
|
|
|
|
|
message.dkim = MessageHelper.getAuthentication("dkim", authentication);
|
|
|
|
|
message.spf = MessageHelper.getAuthentication("spf", authentication);
|
|
|
|
|
message.dmarc = MessageHelper.getAuthentication("dmarc", authentication);
|
|
|
|
|
message.return_path = helper.getReturnPath();
|
|
|
|
|
message.submitter = helper.getSender();
|
|
|
|
|
message.from = helper.getFrom();
|
|
|
|
|
message.to = helper.getTo();
|
|
|
|
|
message.cc = helper.getCc();
|
|
|
|
|
message.bcc = helper.getBcc();
|
|
|
|
|
message.reply = helper.getReply();
|
|
|
|
|
message.list_post = helper.getListPost();
|
|
|
|
|
message.unsubscribe = helper.getListUnsubscribe();
|
|
|
|
|
message.headers = helper.getHeaders();
|
|
|
|
|
message.subject = helper.getSubject();
|
|
|
|
|
message.size = parts.getBodySize();
|
|
|
|
|
message.total = helper.getSize();
|
|
|
|
|
message.content = false;
|
|
|
|
|
message.encrypt = parts.getEncryption();
|
|
|
|
|
message.ui_encrypt = message.encrypt;
|
|
|
|
|
message.received = received;
|
|
|
|
|
message.sent = sent;
|
|
|
|
|
message.seen = seen;
|
|
|
|
|
message.answered = false;
|
|
|
|
|
message.flagged = false;
|
|
|
|
|
message.flags = null;
|
|
|
|
|
message.keywords = new String[0];
|
|
|
|
|
message.ui_seen = seen;
|
|
|
|
|
message.ui_answered = false;
|
|
|
|
|
message.ui_flagged = false;
|
|
|
|
|
message.ui_hide = false;
|
|
|
|
|
message.ui_found = false;
|
|
|
|
|
message.ui_ignored = !_new;
|
|
|
|
|
message.ui_browsed = false;
|
|
|
|
|
|
|
|
|
|
if (message.deliveredto != null)
|
|
|
|
|
try {
|
|
|
|
|
Address deliveredto = new InternetAddress(message.deliveredto);
|
|
|
|
|
if (MessageHelper.equalEmail(new Address[]{deliveredto}, message.to))
|
|
|
|
|
message.deliveredto = null;
|
|
|
|
|
} catch (AddressException ex) {
|
|
|
|
|
Log.w(ex);
|
|
|
|
|
}
|
|
|
|
|
if (MessageHelper.equalEmail(message.submitter, message.from))
|
|
|
|
|
message.submitter = null;
|
|
|
|
|
|
|
|
|
|
if (message.size == null && message.total != null)
|
|
|
|
|
message.size = message.total;
|
|
|
|
|
|
|
|
|
|
if (MessageHelper.equalEmail(message.submitter, message.from))
|
|
|
|
|
message.submitter = null;
|
|
|
|
|
EntityIdentity identity = matchIdentity(context, folder, message);
|
|
|
|
|
message.identity = (identity == null ? null : identity.id);
|
|
|
|
|
|
|
|
|
|
if (message.size == null && message.total != null)
|
|
|
|
|
message.size = message.total;
|
|
|
|
|
message.sender = MessageHelper.getSortKey(message.from);
|
|
|
|
|
Uri lookupUri = ContactInfo.getLookupUri(message.from);
|
|
|
|
|
message.avatar = (lookupUri == null ? null : lookupUri.toString());
|
|
|
|
|
if (message.avatar == null && notify_known && pro)
|
|
|
|
|
message.ui_ignored = true;
|
|
|
|
|
|
|
|
|
|
EntityIdentity identity = matchIdentity(context, folder, message);
|
|
|
|
|
message.identity = (identity == null ? null : identity.id);
|
|
|
|
|
// No MX check
|
|
|
|
|
|
|
|
|
|
message.sender = MessageHelper.getSortKey(message.from);
|
|
|
|
|
Uri lookupUri = ContactInfo.getLookupUri(message.from);
|
|
|
|
|
message.avatar = (lookupUri == null ? null : lookupUri.toString());
|
|
|
|
|
if (message.avatar == null && notify_known && pro)
|
|
|
|
|
message.ui_ignored = true;
|
|
|
|
|
try {
|
|
|
|
|
db.beginTransaction();
|
|
|
|
|
|
|
|
|
|
// No MX check
|
|
|
|
|
message.id = db.message().insertMessage(message);
|
|
|
|
|
EntityLog.log(context, account.name + " POP added id=" + message.id +
|
|
|
|
|
" uidl/msgid=" + message.uidl + "/" + message.msgid);
|
|
|
|
|
|
|
|
|
|
int sequence = 1;
|
|
|
|
|
for (EntityAttachment attachment : parts.getAttachments()) {
|
|
|
|
|
Log.i(account.name + " POP attachment seq=" + sequence +
|
|
|
|
|
" name=" + attachment.name + " type=" + attachment.type +
|
|
|
|
|
" cid=" + attachment.cid + " pgp=" + attachment.encryption +
|
|
|
|
|
" size=" + attachment.size);
|
|
|
|
|
attachment.message = message.id;
|
|
|
|
|
attachment.sequence = sequence++;
|
|
|
|
|
attachment.id = db.attachment().insertAttachment(attachment);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
db.beginTransaction();
|
|
|
|
|
runRules(context, imessage, account, folder, message, rules);
|
|
|
|
|
reportNewMessage(context, account, folder, message);
|
|
|
|
|
|
|
|
|
|
message.id = db.message().insertMessage(message);
|
|
|
|
|
EntityLog.log(context, account.name + " POP added id=" + message.id +
|
|
|
|
|
" uidl/msgid=" + message.uidl + "/" + message.msgid);
|
|
|
|
|
|
|
|
|
|
int sequence = 1;
|
|
|
|
|
for (EntityAttachment attachment : parts.getAttachments()) {
|
|
|
|
|
Log.i(account.name + " POP attachment seq=" + sequence +
|
|
|
|
|
" name=" + attachment.name + " type=" + attachment.type +
|
|
|
|
|
" cid=" + attachment.cid + " pgp=" + attachment.encryption +
|
|
|
|
|
" size=" + attachment.size);
|
|
|
|
|
attachment.message = message.id;
|
|
|
|
|
attachment.sequence = sequence++;
|
|
|
|
|
attachment.id = db.attachment().insertAttachment(attachment);
|
|
|
|
|
db.setTransactionSuccessful();
|
|
|
|
|
} finally {
|
|
|
|
|
db.endTransaction();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
runRules(context, imessage, account, folder, message, rules);
|
|
|
|
|
reportNewMessage(context, account, folder, message);
|
|
|
|
|
String body = parts.getHtml(context);
|
|
|
|
|
File file = message.getFile(context);
|
|
|
|
|
Helper.writeText(file, body);
|
|
|
|
|
String text = HtmlHelper.getFullText(body);
|
|
|
|
|
message.preview = HtmlHelper.getPreview(text);
|
|
|
|
|
message.language = HtmlHelper.getLanguage(context, message.subject, text);
|
|
|
|
|
db.message().setMessageContent(message.id,
|
|
|
|
|
true,
|
|
|
|
|
message.language,
|
|
|
|
|
parts.isPlainOnly(),
|
|
|
|
|
message.preview,
|
|
|
|
|
parts.getWarnings(message.warning));
|
|
|
|
|
|
|
|
|
|
for (EntityAttachment attachment : parts.getAttachments())
|
|
|
|
|
if (attachment.subsequence == null)
|
|
|
|
|
parts.downloadAttachment(context, attachment);
|
|
|
|
|
|
|
|
|
|
db.setTransactionSuccessful();
|
|
|
|
|
} finally {
|
|
|
|
|
db.endTransaction();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
String body = parts.getHtml(context);
|
|
|
|
|
File file = message.getFile(context);
|
|
|
|
|
Helper.writeText(file, body);
|
|
|
|
|
String text = HtmlHelper.getFullText(body);
|
|
|
|
|
message.preview = HtmlHelper.getPreview(text);
|
|
|
|
|
message.language = HtmlHelper.getLanguage(context, message.subject, text);
|
|
|
|
|
db.message().setMessageContent(message.id,
|
|
|
|
|
true,
|
|
|
|
|
message.language,
|
|
|
|
|
parts.isPlainOnly(),
|
|
|
|
|
message.preview,
|
|
|
|
|
parts.getWarnings(message.warning));
|
|
|
|
|
|
|
|
|
|
for (EntityAttachment attachment : parts.getAttachments())
|
|
|
|
|
if (attachment.subsequence == null)
|
|
|
|
|
parts.downloadAttachment(context, attachment);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ContactInfo.update(context, account, folder, message);
|
|
|
|
|
} catch (Throwable ex) {
|
|
|
|
|
db.folder().setFolderError(folder.id, Log.formatThrowable(ex));
|
|
|
|
|
ContactInfo.update(context, account, folder, message);
|
|
|
|
|
} catch (Throwable ex) {
|
|
|
|
|
db.folder().setFolderError(folder.id, Log.formatThrowable(ex));
|
|
|
|
|
}
|
|
|
|
|
} finally {
|
|
|
|
|
((POP3Message) imessage).invalidate(true);
|
|
|
|
|
}
|
|
|
|
|
} finally {
|
|
|
|
|
((POP3Message) imessage).invalidate(true);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|