Reset unused cids, refactoring

pull/147/head
M66B 6 years ago
parent 53de71bccb
commit ae1a36b482

@ -60,10 +60,20 @@ public interface DaoAttachment {
EntityAttachment getAttachment(long message, String cid); EntityAttachment getAttachment(long message, String cid);
@Query("UPDATE attachment" + @Query("UPDATE attachment" +
" SET progress = :progress" + " SET progress = :progress, available = 0" +
" WHERE id = :id") " WHERE id = :id")
void setProgress(long id, Integer progress); void setProgress(long id, Integer progress);
@Query("UPDATE attachment" +
" SET size = :size, progress = NULL, available = 1" +
" WHERE id = :id")
void setDownloaded(long id, Integer size);
@Query("UPDATE attachment" +
" SET cid = NULL" +
" WHERE id = :id")
void clearCid(long id);
@Insert @Insert
long insertAttachment(EntityAttachment attachment); long insertAttachment(EntityAttachment attachment);

@ -107,7 +107,7 @@ public class EntityAttachment {
OutputStream os = null; OutputStream os = null;
try { try {
this.progress = null; this.progress = null;
db.attachment().updateAttachment(this); db.attachment().setProgress(this.id, null);
is = this.part.getInputStream(); is = this.part.getInputStream();
os = new BufferedOutputStream(new FileOutputStream(file)); os = new BufferedOutputStream(new FileOutputStream(file));
@ -127,13 +127,13 @@ public class EntityAttachment {
this.size = size; this.size = size;
this.progress = null; this.progress = null;
this.available = true; this.available = true;
db.attachment().updateAttachment(this); db.attachment().setDownloaded(this.id, size);
Log.i("Downloaded attachment size=" + this.size); Log.i("Downloaded attachment size=" + this.size);
} catch (IOException ex) { } catch (IOException ex) {
// Reset progress on failure // Reset progress on failure
this.progress = null; this.progress = null;
db.attachment().updateAttachment(this); db.attachment().setProgress(this.id, null);
throw ex; throw ex;
} finally { } finally {
try { try {

@ -184,8 +184,7 @@ public class EntityOperation {
EntityAttachment.getFile(context, attachment.id)); EntityAttachment.getFile(context, attachment.id));
} catch (IOException ex) { } catch (IOException ex) {
Log.e(ex); Log.e(ex);
attachment.available = false; db.attachment().setProgress(attachment.id, null);
db.attachment().updateAttachment(attachment);
} }
} }
} }

@ -843,10 +843,7 @@ public class FragmentCompose extends FragmentEx {
os1 = new BufferedOutputStream(new FileOutputStream(file1)); os1 = new BufferedOutputStream(new FileOutputStream(file1));
os1.write(bytes1); os1.write(bytes1);
attachment1.size = bytes1.length; db.attachment().setDownloaded(attachment1.id, bytes1.length);
attachment1.progress = null;
attachment1.available = true;
db.attachment().updateAttachment(attachment1);
} finally { } finally {
if (os1 != null) if (os1 != null)
os1.close(); os1.close();
@ -868,10 +865,7 @@ public class FragmentCompose extends FragmentEx {
os2 = new BufferedOutputStream(new FileOutputStream(file2)); os2 = new BufferedOutputStream(new FileOutputStream(file2));
os2.write(bytes2); os2.write(bytes2);
attachment2.size = bytes2.length; db.attachment().setDownloaded(attachment2.id, bytes2.length);
attachment2.progress = null;
attachment2.available = true;
db.attachment().updateAttachment(attachment2);
} finally { } finally {
if (os2 != null) if (os2 != null)
os2.close(); os2.close();
@ -1186,10 +1180,7 @@ public class FragmentCompose extends FragmentEx {
if (image) if (image)
attachment.cid = "<" + BuildConfig.APPLICATION_ID + "." + attachment.id + ">"; attachment.cid = "<" + BuildConfig.APPLICATION_ID + "." + attachment.id + ">";
attachment.size = size; db.attachment().setDownloaded(attachment.id, size);
attachment.progress = null;
attachment.available = true;
db.attachment().updateAttachment(attachment);
} finally { } finally {
try { try {
if (is != null) if (is != null)
@ -1201,8 +1192,7 @@ public class FragmentCompose extends FragmentEx {
} }
} catch (IOException ex) { } catch (IOException ex) {
// Reset progress on failure // Reset progress on failure
attachment.progress = null; db.attachment().setProgress(attachment.id, null);
db.attachment().updateAttachment(attachment);
throw ex; throw ex;
} }

@ -379,17 +379,17 @@ public class Helper {
private static void attachSettings(Context context, long id, int sequence) throws IOException { private static void attachSettings(Context context, long id, int sequence) throws IOException {
DB db = DB.getInstance(context); DB db = DB.getInstance(context);
EntityAttachment ops = new EntityAttachment(); EntityAttachment attachment = new EntityAttachment();
ops.message = id; attachment.message = id;
ops.sequence = sequence; attachment.sequence = sequence;
ops.name = "settings.txt"; attachment.name = "settings.txt";
ops.type = "text/plain"; attachment.type = "text/plain";
ops.size = null; attachment.size = null;
ops.progress = 0; attachment.progress = 0;
ops.id = db.attachment().insertAttachment(ops); attachment.id = db.attachment().insertAttachment(attachment);
OutputStream os = null; OutputStream os = null;
File file = EntityAttachment.getFile(context, ops.id); File file = EntityAttachment.getFile(context, attachment.id);
try { try {
os = new BufferedOutputStream(new FileOutputStream(file)); os = new BufferedOutputStream(new FileOutputStream(file));
@ -400,10 +400,7 @@ public class Helper {
for (String key : settings.keySet()) for (String key : settings.keySet())
size += write(os, key + "=" + settings.get(key) + "\r\n"); size += write(os, key + "=" + settings.get(key) + "\r\n");
ops.size = size; db.attachment().setDownloaded(attachment.id, size);
ops.progress = null;
ops.available = true;
db.attachment().updateAttachment(ops);
} finally { } finally {
if (os != null) if (os != null)
os.close(); os.close();
@ -413,17 +410,17 @@ public class Helper {
private static void attachNetworkInfo(Context context, long id, int sequence) throws IOException { private static void attachNetworkInfo(Context context, long id, int sequence) throws IOException {
DB db = DB.getInstance(context); DB db = DB.getInstance(context);
EntityAttachment ops = new EntityAttachment(); EntityAttachment attachment = new EntityAttachment();
ops.message = id; attachment.message = id;
ops.sequence = sequence; attachment.sequence = sequence;
ops.name = "network.txt"; attachment.name = "network.txt";
ops.type = "text/plain"; attachment.type = "text/plain";
ops.size = null; attachment.size = null;
ops.progress = 0; attachment.progress = 0;
ops.id = db.attachment().insertAttachment(ops); attachment.id = db.attachment().insertAttachment(attachment);
OutputStream os = null; OutputStream os = null;
File file = EntityAttachment.getFile(context, ops.id); File file = EntityAttachment.getFile(context, attachment.id);
try { try {
os = new BufferedOutputStream(new FileOutputStream(file)); os = new BufferedOutputStream(new FileOutputStream(file));
@ -439,10 +436,7 @@ public class Helper {
size += write(os, "network=" + ni + " capabilities=" + caps + "\r\n\r\n"); size += write(os, "network=" + ni + " capabilities=" + caps + "\r\n\r\n");
} }
ops.size = size; db.attachment().setDownloaded(attachment.id, size);
ops.progress = null;
ops.available = true;
db.attachment().updateAttachment(ops);
} finally { } finally {
if (os != null) if (os != null)
os.close(); os.close();
@ -473,10 +467,7 @@ public class Helper {
for (EntityLog entry : db.log().getLogs(from)) for (EntityLog entry : db.log().getLogs(from))
size += write(os, String.format("%s %s\r\n", DF.format(entry.time), entry.data)); size += write(os, String.format("%s %s\r\n", DF.format(entry.time), entry.data));
log.size = size; db.attachment().setDownloaded(log.id, size);
log.progress = null;
log.available = true;
db.attachment().updateAttachment(log);
} finally { } finally {
if (os != null) if (os != null)
os.close(); os.close();
@ -486,17 +477,17 @@ public class Helper {
private static void attachOperations(Context context, long id, int sequence) throws IOException { private static void attachOperations(Context context, long id, int sequence) throws IOException {
DB db = DB.getInstance(context); DB db = DB.getInstance(context);
EntityAttachment ops = new EntityAttachment(); EntityAttachment attachment = new EntityAttachment();
ops.message = id; attachment.message = id;
ops.sequence = sequence; attachment.sequence = sequence;
ops.name = "operations.txt"; attachment.name = "operations.txt";
ops.type = "text/plain"; attachment.type = "text/plain";
ops.size = null; attachment.size = null;
ops.progress = 0; attachment.progress = 0;
ops.id = db.attachment().insertAttachment(ops); attachment.id = db.attachment().insertAttachment(attachment);
OutputStream os = null; OutputStream os = null;
File file = EntityAttachment.getFile(context, ops.id); File file = EntityAttachment.getFile(context, attachment.id);
try { try {
os = new BufferedOutputStream(new FileOutputStream(file)); os = new BufferedOutputStream(new FileOutputStream(file));
@ -511,10 +502,7 @@ public class Helper {
op.args, op.args,
op.error)); op.error));
ops.size = size; db.attachment().setDownloaded(attachment.id, size);
ops.progress = null;
ops.available = true;
db.attachment().updateAttachment(ops);
} finally { } finally {
if (os != null) if (os != null)
os.close(); os.close();
@ -524,19 +512,19 @@ public class Helper {
private static void attachLogcat(Context context, long id, int sequence) throws IOException { private static void attachLogcat(Context context, long id, int sequence) throws IOException {
DB db = DB.getInstance(context); DB db = DB.getInstance(context);
EntityAttachment logcat = new EntityAttachment(); EntityAttachment attachment = new EntityAttachment();
logcat.message = id; attachment.message = id;
logcat.sequence = sequence; attachment.sequence = sequence;
logcat.name = "logcat.txt"; attachment.name = "logcat.txt";
logcat.type = "text/plain"; attachment.type = "text/plain";
logcat.size = null; attachment.size = null;
logcat.progress = 0; attachment.progress = 0;
logcat.id = db.attachment().insertAttachment(logcat); attachment.id = db.attachment().insertAttachment(attachment);
Process proc = null; Process proc = null;
BufferedReader br = null; BufferedReader br = null;
OutputStream os = null; OutputStream os = null;
File file = EntityAttachment.getFile(context, logcat.id); File file = EntityAttachment.getFile(context, attachment.id);
try { try {
os = new BufferedOutputStream(new FileOutputStream(file)); os = new BufferedOutputStream(new FileOutputStream(file));
@ -554,10 +542,7 @@ public class Helper {
while ((line = br.readLine()) != null) while ((line = br.readLine()) != null)
size += write(os, line + "\r\n"); size += write(os, line + "\r\n");
logcat.size = size; db.attachment().setDownloaded(attachment.id, size);
logcat.progress = null;
logcat.available = true;
db.attachment().updateAttachment(logcat);
} finally { } finally {
if (os != null) if (os != null)
os.close(); os.close();

@ -43,6 +43,7 @@ import java.io.FileOutputStream;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.net.URL; import java.net.URL;
import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.Date; import java.util.Date;
import java.util.List; import java.util.List;
@ -288,4 +289,16 @@ public class HtmlHelper {
return sb.toString(); return sb.toString();
} }
static List<String> getCids(String html) {
List<String> result = new ArrayList<>();
for (Element element : Jsoup.parse(html).select("img")) {
String src = element.attr("src");
if (src.startsWith("cid:"))
result.add("<" + src.substring(4) + ">");
}
return result;
}
} }

@ -643,11 +643,11 @@ public class ServiceSynchronize extends LifecycleService {
if (message.content) if (message.content)
try { try {
String html = message.read(this); String body = message.read(this);
StringBuilder sb = new StringBuilder(); StringBuilder sb = new StringBuilder();
if (!TextUtils.isEmpty(message.subject)) if (!TextUtils.isEmpty(message.subject))
sb.append(message.subject).append("<br>"); sb.append(message.subject).append("<br>");
sb.append(HtmlHelper.getPreview(html)); sb.append(HtmlHelper.getPreview(body));
mbuilder.setStyle(new Notification.BigTextStyle().bigText(Html.fromHtml(sb.toString()))); mbuilder.setStyle(new Notification.BigTextStyle().bigText(Html.fromHtml(sb.toString())));
} catch (IOException ex) { } catch (IOException ex) {
Log.e(ex); Log.e(ex);
@ -1897,10 +1897,15 @@ public class ServiceSynchronize extends LifecycleService {
throw new MessageRemovedException(); throw new MessageRemovedException();
MessageHelper helper = new MessageHelper((MimeMessage) imessage); MessageHelper helper = new MessageHelper((MimeMessage) imessage);
String html = helper.getHtml(); String body = helper.getHtml();
String preview = HtmlHelper.getPreview(html); String preview = HtmlHelper.getPreview(body);
message.write(this, html); message.write(this, body);
db.message().setMessageContent(message.id, true, preview); db.message().setMessageContent(message.id, true, preview);
List<String> cids = HtmlHelper.getCids(body);
for (EntityAttachment attachment : db.attachment().getAttachments(message.id))
if (attachment.cid != null && !cids.contains(attachment.cid))
db.attachment().clearCid(attachment.id);
} }
private void doAttachment(EntityFolder folder, EntityOperation op, IMAPFolder ifolder, EntityMessage message, JSONArray jargs, DB db) throws JSONException, MessagingException, IOException { private void doAttachment(EntityFolder folder, EntityOperation op, IMAPFolder ifolder, EntityMessage message, JSONArray jargs, DB db) throws JSONException, MessagingException, IOException {
@ -2561,6 +2566,11 @@ public class ServiceSynchronize extends LifecycleService {
db.message().setMessageContent( db.message().setMessageContent(
message.id, true, HtmlHelper.getPreview(body)); message.id, true, HtmlHelper.getPreview(body));
Log.i(folder.name + " downloaded message id=" + message.id + " size=" + message.size); Log.i(folder.name + " downloaded message id=" + message.id + " size=" + message.size);
List<String> cids = HtmlHelper.getCids(body);
for (EntityAttachment attachment : attachments)
if (attachment.cid != null && !cids.contains(attachment.cid))
db.attachment().clearCid(attachment.id);
} }
List<EntityAttachment> iattachments = null; List<EntityAttachment> iattachments = null;

Loading…
Cancel
Save