Build address

pull/213/head
M66B 2 years ago
parent a8d9372b09
commit 65d8e38bf7

@ -1132,13 +1132,13 @@ public class FragmentCompose extends FragmentBase {
colEmail = cursor.getColumnIndex("email"); colEmail = cursor.getColumnIndex("email");
String name = cursor.getString(colName); String name = cursor.getString(colName);
String email = MessageHelper.sanitizeEmail(cursor.getString(colEmail)); String email = cursor.getString(colEmail);
if (name == null || !suggest_names)
InternetAddress address = MessageHelper.buildAddress(email, name, suggest_names);
if (address == null)
return email; return email;
else {
Address address = new InternetAddress(email, name, StandardCharsets.UTF_8.name()); return MessageHelper.formatAddressesCompose(new Address[]{address});
return MessageHelper.formatAddressesCompose(new Address[]{address});
}
} catch (Throwable ex) { } catch (Throwable ex) {
Log.e(ex); Log.e(ex);
return ex.toString(); return ex.toString();
@ -3287,10 +3287,14 @@ public class FragmentCompose extends FragmentBase {
int colEmail = cursor.getColumnIndex(ContactsContract.CommonDataKinds.Email.ADDRESS); int colEmail = cursor.getColumnIndex(ContactsContract.CommonDataKinds.Email.ADDRESS);
int colName = cursor.getColumnIndex(ContactsContract.Contacts.DISPLAY_NAME); int colName = cursor.getColumnIndex(ContactsContract.Contacts.DISPLAY_NAME);
if (colEmail >= 0 && colName >= 0) { if (colEmail >= 0 && colName >= 0) {
String email = MessageHelper.sanitizeEmail(cursor.getString(colEmail)); String email = cursor.getString(colEmail);
String name = cursor.getString(colName); String name = cursor.getString(colName);
args.putString("email", email); InternetAddress selected = MessageHelper.buildAddress(email, name, suggest_names);
if (selected == null)
return null;
args.putString("email", selected.getAddress());
try { try {
db.beginTransaction(); db.beginTransaction();
@ -3315,7 +3319,7 @@ public class FragmentCompose extends FragmentBase {
if (address != null) if (address != null)
list.addAll(Arrays.asList(address)); list.addAll(Arrays.asList(address));
list.add(new InternetAddress(email, suggest_names ? name : null, StandardCharsets.UTF_8.name())); list.add(selected);
if (requestCode == REQUEST_CONTACT_TO) if (requestCode == REQUEST_CONTACT_TO)
draft.to = list.toArray(new Address[0]); draft.to = list.toArray(new Address[0]);

@ -5242,19 +5242,27 @@ public class MessageHelper {
.replaceAll("[^\\p{ASCII}]", ""); .replaceAll("[^\\p{ASCII}]", "");
} }
static String sanitizeEmail(String email) { static InternetAddress buildAddress(String email, String name, boolean suggest) {
if (email == null) try {
return null; InternetAddress address = (email == null ? new InternetAddress() : new InternetAddress(email));
if (email.contains("<") && email.contains(">")) if (suggest && !TextUtils.isEmpty(name) &&
try { TextUtils.isEmpty(address.getPersonal())) {
InternetAddress address = new InternetAddress(email); try {
return address.getAddress(); address.setPersonal(name, StandardCharsets.UTF_8.name());
} catch (AddressException ex) { } catch (UnsupportedEncodingException ex) {
Log.e(ex); Log.i(ex);
}
} }
return email; if (TextUtils.isEmpty(address.getAddress()) && TextUtils.isEmpty(address.getAddress()))
return null;
return address;
} catch (AddressException ex) {
Log.e(ex);
return null;
}
} }
static String sanitizeName(String name) { static String sanitizeName(String name) {

Loading…
Cancel
Save