Send signature images

pull/174/head
M66B 5 years ago
parent baab4cba36
commit 3e4d46b1a7

@ -25,12 +25,14 @@ import android.net.MailTo;
import android.net.Uri; import android.net.Uri;
import android.text.TextUtils; import android.text.TextUtils;
import androidx.documentfile.provider.DocumentFile;
import androidx.preference.PreferenceManager; import androidx.preference.PreferenceManager;
import com.sun.mail.util.FolderClosedIOException; import com.sun.mail.util.FolderClosedIOException;
import com.sun.mail.util.MessageRemovedIOException; import com.sun.mail.util.MessageRemovedIOException;
import org.jsoup.nodes.Document; import org.jsoup.nodes.Document;
import org.jsoup.nodes.Element;
import java.io.BufferedInputStream; import java.io.BufferedInputStream;
import java.io.BufferedOutputStream; import java.io.BufferedOutputStream;
@ -61,6 +63,7 @@ import java.util.TimeZone;
import java.util.regex.Pattern; import java.util.regex.Pattern;
import javax.activation.DataHandler; import javax.activation.DataHandler;
import javax.activation.DataSource;
import javax.activation.FileDataSource; import javax.activation.FileDataSource;
import javax.activation.FileTypeMap; import javax.activation.FileTypeMap;
import javax.mail.Address; import javax.mail.Address;
@ -488,9 +491,51 @@ public class MessageHelper {
Document document = JsoupEx.parse(message.getFile(context)); Document document = JsoupEx.parse(message.getFile(context));
// When sending message // When sending message
if (identity != null) List<BodyPart> contents = new ArrayList<>();
if (identity != null) {
document.select("div[fairemail=signature],div[fairemail=reference]").removeAttr("fairemail"); document.select("div[fairemail=signature],div[fairemail=reference]").removeAttr("fairemail");
for (Element img : document.select("img")) {
String source = img.attr("src");
if (!source.startsWith("content:"))
continue;
String cid = BuildConfig.APPLICATION_ID + ".content." + contents.size();
img.attr("src", "cid:" + cid);
final Uri uri = Uri.parse(source);
final DocumentFile dfile = DocumentFile.fromSingleUri(context, uri);
BodyPart part = new MimeBodyPart();
part.setFileName(uri.getLastPathSegment());
part.setDisposition(Part.INLINE);
part.setHeader("Content-ID", "<" + cid + ">");
part.setDataHandler(new DataHandler(new DataSource() {
@Override
public InputStream getInputStream() throws IOException {
return context.getContentResolver().openInputStream(uri);
}
@Override
public OutputStream getOutputStream() throws IOException {
return null;
}
@Override
public String getContentType() {
return dfile.getType();
}
@Override
public String getName() {
return uri.getLastPathSegment();
}
}));
contents.add(part);
}
}
// multipart/mixed // multipart/mixed
// multipart/related // multipart/related
// multipart/alternative // multipart/alternative
@ -512,8 +557,8 @@ public class MessageHelper {
altMultiPart.addBodyPart(plainPart); altMultiPart.addBodyPart(plainPart);
altMultiPart.addBodyPart(htmlPart); altMultiPart.addBodyPart(htmlPart);
int availableAttachments = 0; int availableAttachments = contents.size();
boolean hasInline = false; boolean hasInline = contents.size() > 0;
for (EntityAttachment attachment : attachments) for (EntityAttachment attachment : attachments)
if (attachment.available) { if (attachment.available) {
availableAttachments++; availableAttachments++;
@ -592,6 +637,9 @@ public class MessageHelper {
mixedMultiPart.addBodyPart(attachmentPart); mixedMultiPart.addBodyPart(attachmentPart);
} }
for (BodyPart content : contents)
relatedMultiPart.addBodyPart(content);
imessage.setContent(mixedMultiPart); imessage.setContent(mixedMultiPart);
} }
} }

Loading…
Cancel
Save