diff options
Diffstat (limited to 'com/android/server/notification/RankingHelper.java')
-rw-r--r-- | com/android/server/notification/RankingHelper.java | 27 |
1 files changed, 23 insertions, 4 deletions
diff --git a/com/android/server/notification/RankingHelper.java b/com/android/server/notification/RankingHelper.java index 98d5c9a5..43d393a2 100644 --- a/com/android/server/notification/RankingHelper.java +++ b/com/android/server/notification/RankingHelper.java @@ -15,6 +15,8 @@ */ package com.android.server.notification; +import static android.app.NotificationManager.IMPORTANCE_NONE; + import com.android.internal.R; import com.android.internal.annotations.VisibleForTesting; import com.android.internal.logging.MetricsLogger; @@ -619,7 +621,7 @@ public class RankingHelper implements RankingConfig { updateConfig(); return; } - if (channel.getImportance() < NotificationManager.IMPORTANCE_NONE + if (channel.getImportance() < IMPORTANCE_NONE || channel.getImportance() > NotificationManager.IMPORTANCE_MAX) { throw new IllegalArgumentException("Invalid importance level"); } @@ -959,6 +961,23 @@ public class RankingHelper implements RankingConfig { return deletedCount; } + public int getBlockedChannelCount(String pkg, int uid) { + Preconditions.checkNotNull(pkg); + int blockedCount = 0; + Record r = getRecord(pkg, uid); + if (r == null) { + return blockedCount; + } + int N = r.channels.size(); + for (int i = 0; i < N; i++) { + final NotificationChannel nc = r.channels.valueAt(i); + if (!nc.isDeleted() && IMPORTANCE_NONE == nc.getImportance()) { + blockedCount++; + } + } + return blockedCount; + } + /** * Sets importance. */ @@ -969,12 +988,12 @@ public class RankingHelper implements RankingConfig { } public void setEnabled(String packageName, int uid, boolean enabled) { - boolean wasEnabled = getImportance(packageName, uid) != NotificationManager.IMPORTANCE_NONE; + boolean wasEnabled = getImportance(packageName, uid) != IMPORTANCE_NONE; if (wasEnabled == enabled) { return; } setImportance(packageName, uid, - enabled ? DEFAULT_IMPORTANCE : NotificationManager.IMPORTANCE_NONE); + enabled ? DEFAULT_IMPORTANCE : IMPORTANCE_NONE); } @VisibleForTesting @@ -1199,7 +1218,7 @@ public class RankingHelper implements RankingConfig { ArrayMap<Integer, String> packageBans = new ArrayMap<>(N); for (int i = 0; i < N; i++) { final Record r = mRecords.valueAt(i); - if (r.importance == NotificationManager.IMPORTANCE_NONE) { + if (r.importance == IMPORTANCE_NONE) { packageBans.put(r.uid, r.pkg); } } |