mirror of
https://github.com/oxen-io/session-android.git
synced 2025-01-12 10:23:49 +00:00
This attempts to work around a ROM crash bug
getActiveNotifications() seems to throw an NPE on some Motorola ROMs, all of which appear to be 6.0.1. This change just swallows the exception. 6.0 doesn't support bundled notifications, so I think it's alright if they don't get canceled, since the summary notification will still be displayed correctly. This would only affect users who have an android wear device attached to one of these buggy ROMs. By swallowing this exception, they would not always get notifictions dismissed on their wear device. Fixes #6043 // FREEBIE
This commit is contained in:
parent
cfef855d99
commit
360c2b2a50
@ -130,36 +130,47 @@ public class MessageNotifier {
|
|||||||
notifications.cancel(SUMMARY_NOTIFICATION_ID);
|
notifications.cancel(SUMMARY_NOTIFICATION_ID);
|
||||||
|
|
||||||
if (Build.VERSION.SDK_INT >= 23) {
|
if (Build.VERSION.SDK_INT >= 23) {
|
||||||
StatusBarNotification[] activeNotifications = notifications.getActiveNotifications();
|
try {
|
||||||
|
StatusBarNotification[] activeNotifications = notifications.getActiveNotifications();
|
||||||
|
|
||||||
for (StatusBarNotification activeNotification : activeNotifications) {
|
for (StatusBarNotification activeNotification : activeNotifications) {
|
||||||
if (activeNotification.getId() != NotificationBarManager.RED_PHONE_NOTIFICATION) {
|
if (activeNotification.getId() != NotificationBarManager.RED_PHONE_NOTIFICATION) {
|
||||||
notifications.cancel(activeNotification.getId());
|
notifications.cancel(activeNotification.getId());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
} catch (Throwable e) {
|
||||||
|
// XXX Appears to be a ROM bug, see #6043
|
||||||
|
Log.w(TAG, e);
|
||||||
|
notifications.cancelAll();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void cancelOrphanedNotifications(@NonNull Context context, NotificationState notificationState) {
|
private static void cancelOrphanedNotifications(@NonNull Context context, NotificationState notificationState) {
|
||||||
if (Build.VERSION.SDK_INT >= 23) {
|
if (Build.VERSION.SDK_INT >= 23) {
|
||||||
NotificationManager notifications = ServiceUtil.getNotificationManager(context);
|
try {
|
||||||
StatusBarNotification[] activeNotifications = notifications.getActiveNotifications();
|
NotificationManager notifications = ServiceUtil.getNotificationManager(context);
|
||||||
|
StatusBarNotification[] activeNotifications = notifications.getActiveNotifications();
|
||||||
|
|
||||||
for (StatusBarNotification notification : activeNotifications) {
|
for (StatusBarNotification notification : activeNotifications) {
|
||||||
boolean validNotification = false;
|
boolean validNotification = false;
|
||||||
|
|
||||||
if (notification.getId() != SUMMARY_NOTIFICATION_ID && notification.getId() != NotificationBarManager.RED_PHONE_NOTIFICATION) {
|
if (notification.getId() != SUMMARY_NOTIFICATION_ID && notification.getId() != NotificationBarManager.RED_PHONE_NOTIFICATION) {
|
||||||
for (NotificationItem item : notificationState.getNotifications()) {
|
for (NotificationItem item : notificationState.getNotifications()) {
|
||||||
if (notification.getId() == (SUMMARY_NOTIFICATION_ID + item.getThreadId())) {
|
if (notification.getId() == (SUMMARY_NOTIFICATION_ID + item.getThreadId())) {
|
||||||
validNotification = true;
|
validNotification = true;
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!validNotification) {
|
||||||
|
notifications.cancel(notification.getId());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!validNotification) {
|
|
||||||
notifications.cancel(notification.getId());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
} catch (Throwable e) {
|
||||||
|
// XXX Android ROM Bug, see #6043
|
||||||
|
Log.w(TAG, e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user