mirror of
https://github.com/oxen-io/session-android.git
synced 2025-01-11 23:33:39 +00:00
Only lookup contact address by number if address is a phone number
// FREEBIE
This commit is contained in:
parent
4229c21bdc
commit
5f9a3b7930
@ -133,32 +133,34 @@ class RecipientProvider {
|
|||||||
private @NonNull RecipientDetails getIndividualRecipientDetails(Context context, @NonNull Address address) {
|
private @NonNull RecipientDetails getIndividualRecipientDetails(Context context, @NonNull Address address) {
|
||||||
Optional<RecipientsPreferences> preferences = DatabaseFactory.getRecipientPreferenceDatabase(context).getRecipientsPreferences(new Address[]{address});
|
Optional<RecipientsPreferences> preferences = DatabaseFactory.getRecipientPreferenceDatabase(context).getRecipientsPreferences(new Address[]{address});
|
||||||
MaterialColor color = preferences.isPresent() ? preferences.get().getColor() : null;
|
MaterialColor color = preferences.isPresent() ? preferences.get().getColor() : null;
|
||||||
Uri uri = Uri.withAppendedPath(PhoneLookup.CONTENT_FILTER_URI, Uri.encode(address.toPhoneString()));
|
|
||||||
Cursor cursor = context.getContentResolver().query(uri, CALLER_ID_PROJECTION,
|
|
||||||
null, null, null);
|
|
||||||
|
|
||||||
try {
|
if (address.isPhone()) {
|
||||||
if (cursor != null && cursor.moveToFirst()) {
|
Uri uri = Uri.withAppendedPath(PhoneLookup.CONTENT_FILTER_URI, Uri.encode(address.toPhoneString()));
|
||||||
final String resultNumber = cursor.getString(3);
|
Cursor cursor = context.getContentResolver().query(uri, CALLER_ID_PROJECTION, null, null, null);
|
||||||
if (resultNumber != null) {
|
|
||||||
Uri contactUri = Contacts.getLookupUri(cursor.getLong(2), cursor.getString(1));
|
|
||||||
String name = resultNumber.equals(cursor.getString(0)) ? null : cursor.getString(0);
|
|
||||||
ContactPhoto contactPhoto = ContactPhotoFactory.getContactPhoto(context,
|
|
||||||
Uri.withAppendedPath(Contacts.CONTENT_URI, cursor.getLong(2) + ""),
|
|
||||||
name);
|
|
||||||
|
|
||||||
return new RecipientDetails(cursor.getString(0), cursor.getString(4), contactUri, contactPhoto, color);
|
try {
|
||||||
} else {
|
if (cursor != null && cursor.moveToFirst()) {
|
||||||
Log.w(TAG, "resultNumber is null");
|
final String resultNumber = cursor.getString(3);
|
||||||
|
if (resultNumber != null) {
|
||||||
|
Uri contactUri = Contacts.getLookupUri(cursor.getLong(2), cursor.getString(1));
|
||||||
|
String name = resultNumber.equals(cursor.getString(0)) ? null : cursor.getString(0);
|
||||||
|
ContactPhoto contactPhoto = ContactPhotoFactory.getContactPhoto(context,
|
||||||
|
Uri.withAppendedPath(Contacts.CONTENT_URI, cursor.getLong(2) + ""),
|
||||||
|
name);
|
||||||
|
|
||||||
|
return new RecipientDetails(cursor.getString(0), cursor.getString(4), contactUri, contactPhoto, color);
|
||||||
|
} else {
|
||||||
|
Log.w(TAG, "resultNumber is null");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
} finally {
|
||||||
|
if (cursor != null)
|
||||||
|
cursor.close();
|
||||||
}
|
}
|
||||||
} finally {
|
|
||||||
if (cursor != null)
|
|
||||||
cursor.close();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (STATIC_DETAILS.containsKey(address.toPhoneString())) return STATIC_DETAILS.get(address.toPhoneString());
|
if (STATIC_DETAILS.containsKey(address.serialize())) return STATIC_DETAILS.get(address.serialize());
|
||||||
else return new RecipientDetails(null, null, null, ContactPhotoFactory.getDefaultContactPhoto(null), color);
|
else return new RecipientDetails(null, null, null, ContactPhotoFactory.getDefaultContactPhoto(null), color);
|
||||||
}
|
}
|
||||||
|
|
||||||
private @NonNull RecipientDetails getGroupRecipientDetails(Context context, Address groupId) {
|
private @NonNull RecipientDetails getGroupRecipientDetails(Context context, Address groupId) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user