mirror of
https://github.com/oxen-io/session-android.git
synced 2025-01-12 19:53:39 +00:00
Only notify when address is in contacts
This commit is contained in:
parent
27d3dc918e
commit
b58c87a56b
@ -354,6 +354,19 @@ public class RecipientDatabase extends Database {
|
|||||||
return results;
|
return results;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public List<Address> getSystemContacts() {
|
||||||
|
SQLiteDatabase db = databaseHelper.getReadableDatabase();
|
||||||
|
List<Address> results = new LinkedList<>();
|
||||||
|
|
||||||
|
try (Cursor cursor = db.query(TABLE_NAME, new String[] {ADDRESS}, SYSTEM_DISPLAY_NAME + " IS NOT NULL AND " + SYSTEM_DISPLAY_NAME + " != \"\"", null, null, null, null)) {
|
||||||
|
while (cursor != null && cursor.moveToNext()) {
|
||||||
|
results.add(Address.fromSerialized(cursor.getString(0)));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return results;
|
||||||
|
}
|
||||||
|
|
||||||
// XXX This shouldn't be here, and is just a temporary workaround
|
// XXX This shouldn't be here, and is just a temporary workaround
|
||||||
public RegisteredState isRegistered(@NonNull Address address) {
|
public RegisteredState isRegistered(@NonNull Address address) {
|
||||||
SQLiteDatabase db = databaseHelper.getReadableDatabase();
|
SQLiteDatabase db = databaseHelper.getReadableDatabase();
|
||||||
|
@ -67,7 +67,7 @@ public class DirectoryHelper {
|
|||||||
if (notifyOfNewUsers) notifyNewUsers(context, masterSecret, newlyActiveUsers);
|
if (notifyOfNewUsers) notifyNewUsers(context, masterSecret, newlyActiveUsers);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static @NonNull List<Address> refreshDirectory(@NonNull Context context, @NonNull SignalServiceAccountManager accountManager)
|
private static @NonNull List<Address> refreshDirectory(@NonNull Context context, @NonNull SignalServiceAccountManager accountManager)
|
||||||
throws IOException
|
throws IOException
|
||||||
{
|
{
|
||||||
if (TextUtils.isEmpty(TextSecurePreferences.getLocalNumber(context))) {
|
if (TextUtils.isEmpty(TextSecurePreferences.getLocalNumber(context))) {
|
||||||
@ -101,8 +101,10 @@ public class DirectoryHelper {
|
|||||||
}
|
}
|
||||||
|
|
||||||
Set<Address> currentActiveAddresses = new HashSet<>(recipientDatabase.getRegistered());
|
Set<Address> currentActiveAddresses = new HashSet<>(recipientDatabase.getRegistered());
|
||||||
|
Set<Address> contactAddresses = new HashSet<>(recipientDatabase.getSystemContacts());
|
||||||
List<Address> newlyActiveAddresses = Stream.of(activeAddresses)
|
List<Address> newlyActiveAddresses = Stream.of(activeAddresses)
|
||||||
.filter(address -> !currentActiveAddresses.contains(address))
|
.filter(address -> !currentActiveAddresses.contains(address))
|
||||||
|
.filter(contactAddresses::contains)
|
||||||
.toList();
|
.toList();
|
||||||
|
|
||||||
recipientDatabase.setRegistered(activeAddresses, inactiveAddresses);
|
recipientDatabase.setRegistered(activeAddresses, inactiveAddresses);
|
||||||
@ -127,6 +129,7 @@ public class DirectoryHelper {
|
|||||||
RecipientDatabase recipientDatabase = DatabaseFactory.getRecipientDatabase(context);
|
RecipientDatabase recipientDatabase = DatabaseFactory.getRecipientDatabase(context);
|
||||||
SignalServiceAccountManager accountManager = AccountManagerFactory.createManager(context);
|
SignalServiceAccountManager accountManager = AccountManagerFactory.createManager(context);
|
||||||
boolean activeUser = recipient.resolve().getRegistered() == RegisteredState.REGISTERED;
|
boolean activeUser = recipient.resolve().getRegistered() == RegisteredState.REGISTERED;
|
||||||
|
boolean systemContact = recipient.isSystemContact();
|
||||||
String number = recipient.getAddress().serialize();
|
String number = recipient.getAddress().serialize();
|
||||||
Optional<ContactTokenDetails> details = accountManager.getContact(number);
|
Optional<ContactTokenDetails> details = accountManager.getContact(number);
|
||||||
|
|
||||||
@ -141,7 +144,7 @@ public class DirectoryHelper {
|
|||||||
ApplicationContext.getInstance(context).getJobManager().add(new MultiDeviceContactUpdateJob(context));
|
ApplicationContext.getInstance(context).getJobManager().add(new MultiDeviceContactUpdateJob(context));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!activeUser) {
|
if (!activeUser && systemContact) {
|
||||||
notifyNewUsers(context, masterSecret, Collections.singletonList(recipient.getAddress()));
|
notifyNewUsers(context, masterSecret, Collections.singletonList(recipient.getAddress()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user