IDN support

pull/178/head
M66B 5 years ago
parent 94ccae2ef2
commit fa0ffd0c21

@ -49,6 +49,7 @@ import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.io.OutputStream; import java.io.OutputStream;
import java.io.UnsupportedEncodingException; import java.io.UnsupportedEncodingException;
import java.net.IDN;
import java.nio.charset.Charset; import java.nio.charset.Charset;
import java.nio.charset.StandardCharsets; import java.nio.charset.StandardCharsets;
import java.security.NoSuchAlgorithmException; import java.security.NoSuchAlgorithmException;
@ -187,13 +188,13 @@ public class MessageHelper {
} }
if (message.to != null && message.to.length > 0) if (message.to != null && message.to.length > 0)
imessage.setRecipients(Message.RecipientType.TO, message.to); imessage.setRecipients(Message.RecipientType.TO, convertAddress(message.to));
if (message.cc != null && message.cc.length > 0) if (message.cc != null && message.cc.length > 0)
imessage.setRecipients(Message.RecipientType.CC, message.cc); imessage.setRecipients(Message.RecipientType.CC, convertAddress(message.cc));
if (message.bcc != null && message.bcc.length > 0) if (message.bcc != null && message.bcc.length > 0)
imessage.setRecipients(Message.RecipientType.BCC, message.bcc); imessage.setRecipients(Message.RecipientType.BCC, convertAddress(message.bcc));
if (message.subject != null) if (message.subject != null)
imessage.setSubject(message.subject); imessage.setSubject(message.subject);
@ -202,7 +203,7 @@ public class MessageHelper {
if (identity != null) { if (identity != null) {
// Add reply to // Add reply to
if (identity.replyto != null) if (identity.replyto != null)
imessage.setReplyTo(InternetAddress.parse(identity.replyto)); imessage.setReplyTo(convertAddress(InternetAddress.parse(identity.replyto)));
// Add extra cc // Add extra cc
if (identity.cc != null) if (identity.cc != null)
@ -465,7 +466,7 @@ public class MessageHelper {
result.addAll(Arrays.asList(existing)); result.addAll(Arrays.asList(existing));
Address[] all = imessage.getAllRecipients(); Address[] all = imessage.getAllRecipients();
Address[] addresses = InternetAddress.parse(email); Address[] addresses = convertAddress(InternetAddress.parse(email));
for (Address address : addresses) { for (Address address : addresses) {
boolean found = false; boolean found = false;
if (all != null) if (all != null)
@ -481,6 +482,36 @@ public class MessageHelper {
imessage.setRecipients(type, result.toArray(new Address[0])); imessage.setRecipients(type, result.toArray(new Address[0]));
} }
private static Address[] convertAddress(Address[] addresses) {
// https://en.wikipedia.org/wiki/International_email
for (Address address : addresses) {
String email = ((InternetAddress) address).getAddress();
int at = email.indexOf('@');
if (at > 0) {
String user = email.substring(0, at);
String domain = email.substring(at + 1);
try {
user = IDN.toASCII(user);
} catch (IllegalArgumentException ex) {
Log.e(ex);
}
String[] parts = domain.split("\\.");
for (int p = 0; p < parts.length; p++)
try {
parts[p] = IDN.toASCII(parts[p]);
} catch (IllegalArgumentException ex) {
Log.e(ex);
}
email = user + '@' + TextUtils.join(".", parts);
}
((InternetAddress) address).setAddress(email);
}
return addresses;
}
static void build(Context context, EntityMessage message, List<EntityAttachment> attachments, EntityIdentity identity, boolean send, MimeMessage imessage) throws IOException, MessagingException { static void build(Context context, EntityMessage message, List<EntityAttachment> attachments, EntityIdentity identity, boolean send, MimeMessage imessage) throws IOException, MessagingException {
if (message.receipt != null && message.receipt) { if (message.receipt != null && message.receipt) {
// https://www.ietf.org/rfc/rfc3798.txt // https://www.ietf.org/rfc/rfc3798.txt

Loading…
Cancel
Save