Merge "Only show enhanced options for migrated apps" into sc-dev

This commit is contained in:
Julia Reynolds
2021-04-05 13:30:57 +00:00
committed by Android (Google) Code Review
11 changed files with 445 additions and 20 deletions

View File

@@ -0,0 +1,72 @@
/*
* Copyright (C) 2021 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under the
* License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the specific language governing
* permissions and limitations under the License.
*/
package com.android.settings.applications.specialaccess.notificationaccess;
import android.content.ComponentName;
import android.content.Context;
import android.os.Build;
import android.service.notification.NotificationListenerFilter;
import com.android.settings.core.BasePreferenceController;
import com.android.settings.notification.NotificationBackend;
public class BridgedAppsLinkPreferenceController extends BasePreferenceController {
private ComponentName mCn;
private int mUserId;
private NotificationBackend mNm;
private NotificationListenerFilter mNlf;
private int mTargetSdk;
public BridgedAppsLinkPreferenceController(Context context, String key) {
super(context, key);
}
public BridgedAppsLinkPreferenceController setCn(ComponentName cn) {
mCn = cn;
return this;
}
public BridgedAppsLinkPreferenceController setUserId(int userId) {
mUserId = userId;
return this;
}
public BridgedAppsLinkPreferenceController setNm(NotificationBackend nm) {
mNm = nm;
return this;
}
public BridgedAppsLinkPreferenceController setTargetSdk(int targetSdk) {
mTargetSdk = targetSdk;
return this;
}
@Override
public int getAvailabilityStatus() {
if (mNm.isNotificationListenerAccessGranted(mCn)) {
if (mTargetSdk > Build.VERSION_CODES.S) {
return AVAILABLE;
}
mNlf = mNm.getListenerFilter(mCn, mUserId);
if (!mNlf.areAllTypesAllowed() || !mNlf.getDisallowedPackages().isEmpty()) {
return AVAILABLE;
}
}
return DISABLED_DEPENDENT_SETTING;
}
}

View File

@@ -16,14 +16,11 @@ package com.android.settings.applications.specialaccess.notificationaccess;
import android.content.ComponentName;
import android.content.Context;
import android.content.pm.VersionedPackage;
import android.os.UserHandle;
import android.service.notification.NotificationListenerFilter;
import androidx.annotation.VisibleForTesting;
import androidx.preference.CheckBoxPreference;
import androidx.preference.Preference;
import androidx.preference.PreferenceScreen;
import androidx.preference.SwitchPreference;
import com.android.settings.applications.AppStateBaseBridge;
import com.android.settings.core.BasePreferenceController;
@@ -126,9 +123,6 @@ public class BridgedAppsPreferenceController extends BasePreferenceController im
final int N = apps.size();
for (int i = 0; i < N; i++) {
final AppEntry entry = apps.get(i);
if (!shouldAddPreference(entry)) {
continue;
}
final String prefKey = entry.info.packageName + "|" + entry.info.uid;
appsKeySet.add(prefKey);
CheckBoxPreference preference = mScreen.findPreference(prefKey);
@@ -211,9 +205,4 @@ public class BridgedAppsPreferenceController extends BasePreferenceController im
}
}
}
@VisibleForTesting
static boolean shouldAddPreference(AppEntry app) {
return app != null && UserHandle.isApp(app.info.uid);
}
}

View File

@@ -69,7 +69,7 @@ public class BridgedAppsSettings extends DashboardFragment {
case MENU_SHOW_SYSTEM:
mShowSystem = !mShowSystem;
item.setTitle(mShowSystem ? R.string.menu_hide_system : R.string.menu_show_system);
mFilter = mShowSystem ? ApplicationsState.FILTER_ALL_ENABLED
mFilter = mShowSystem ? ApplicationsState.FILTER_NOT_HIDE
: ApplicationsState.FILTER_DOWNLOADED_AND_LAUNCHER;
use(BridgedAppsPreferenceController.class).setFilter(mFilter).rebuild();

View File

@@ -22,6 +22,8 @@ import android.app.Activity;
import android.app.NotificationManager;
import android.app.settings.SettingsEnums;
import android.companion.ICompanionDeviceManager;
import android.compat.annotation.ChangeId;
import android.compat.annotation.EnabledAfter;
import android.content.ComponentName;
import android.content.Context;
import android.content.Intent;
@@ -29,6 +31,7 @@ import android.content.pm.PackageInfo;
import android.content.pm.PackageManager;
import android.content.pm.ResolveInfo;
import android.content.pm.ServiceInfo;
import android.os.Build;
import android.os.Bundle;
import android.os.ServiceManager;
import android.os.UserHandle;
@@ -88,11 +91,18 @@ public class NotificationAccessDetails extends DashboardFragment {
mPm = getPackageManager();
retrieveAppEntry();
loadNotificationListenerService();
NotificationBackend backend = new NotificationBackend();
int listenerTargetSdk = Build.VERSION_CODES.S;
try {
listenerTargetSdk = mPm.getTargetSdkVersion(mComponentName.getPackageName());
} catch (PackageManager.NameNotFoundException e){
// how did we get here?
}
use(ApprovalPreferenceController.class)
.setPkgInfo(mPackageInfo)
.setCn(mComponentName)
.setNm(context.getSystemService(NotificationManager.class))
.setPm(context.getPackageManager())
.setPm(mPm)
.setParent(this);
use(HeaderPreferenceController.class)
.setFragment(this)
@@ -104,15 +114,27 @@ public class NotificationAccessDetails extends DashboardFragment {
ServiceManager.getService(Context.COMPANION_DEVICE_SERVICE)))
.setCn(mComponentName)
.setUserId(mUserId);
use(PreUpgradePreferenceController.class)
.setNm(backend)
.setCn(mComponentName)
.setUserId(mUserId)
.setTargetSdk(listenerTargetSdk);
use(BridgedAppsLinkPreferenceController.class)
.setNm(backend)
.setCn(mComponentName)
.setUserId(mUserId)
.setTargetSdk(listenerTargetSdk);
final int finalListenerTargetSdk = listenerTargetSdk;
getPreferenceControllers().forEach(controllers -> {
controllers.forEach(controller -> {
if (controller instanceof TypeFilterPreferenceController) {
TypeFilterPreferenceController tfpc =
(TypeFilterPreferenceController) controller;
tfpc.setNm(new NotificationBackend())
tfpc.setNm(backend)
.setCn(mComponentName)
.setServiceInfo(mServiceInfo)
.setUserId(mUserId);
.setUserId(mUserId)
.setTargetSdk(finalListenerTargetSdk);
}
});
});
@@ -154,7 +176,7 @@ public class NotificationAccessDetails extends DashboardFragment {
setIntentAndFinish(true /* appChanged */);
}
Preference apps = getPreferenceScreen().findPreference(
use(BridgedAppsPreferenceController.class).getPreferenceKey());
use(BridgedAppsLinkPreferenceController.class).getPreferenceKey());
if (apps != null) {
apps.setOnPreferenceClickListener(preference -> {

View File

@@ -0,0 +1,76 @@
/*
* Copyright (C) 2021 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.android.settings.applications.specialaccess.notificationaccess;
import android.content.ComponentName;
import android.content.Context;
import android.os.Build;
import android.service.notification.NotificationListenerFilter;
import com.android.settings.core.BasePreferenceController;
import com.android.settings.notification.NotificationBackend;
public class PreUpgradePreferenceController extends BasePreferenceController {
private ComponentName mCn;
private int mUserId;
private NotificationBackend mNm;
private NotificationListenerFilter mNlf;
private int mTargetSdk;
public PreUpgradePreferenceController(Context context, String key) {
super(context, key);
}
public PreUpgradePreferenceController setCn(ComponentName cn) {
mCn = cn;
return this;
}
public PreUpgradePreferenceController setUserId(int userId) {
mUserId = userId;
return this;
}
public PreUpgradePreferenceController setNm(NotificationBackend nm) {
mNm = nm;
return this;
}
public PreUpgradePreferenceController setTargetSdk(int targetSdk) {
mTargetSdk = targetSdk;
return this;
}
@Override
public int getAvailabilityStatus() {
if (mNm.isNotificationListenerAccessGranted(mCn)) {
mNlf = mNm.getListenerFilter(mCn, mUserId);
if (mTargetSdk > Build.VERSION_CODES.S) {
return CONDITIONALLY_UNAVAILABLE;
}
if (!mNlf.areAllTypesAllowed() || !mNlf.getDisallowedPackages().isEmpty()) {
return CONDITIONALLY_UNAVAILABLE;
}
return AVAILABLE;
} else {
return CONDITIONALLY_UNAVAILABLE;
}
}
}

View File

@@ -19,6 +19,7 @@ package com.android.settings.applications.specialaccess.notificationaccess;
import android.content.ComponentName;
import android.content.Context;
import android.content.pm.ServiceInfo;
import android.os.Build;
import android.service.notification.NotificationListenerFilter;
import android.service.notification.NotificationListenerService;
import android.text.TextUtils;
@@ -41,6 +42,7 @@ public abstract class TypeFilterPreferenceController extends BasePreferenceContr
private NotificationBackend mNm;
private NotificationListenerFilter mNlf;
private ServiceInfo mSi;
private int mTargetSdk;
public TypeFilterPreferenceController(Context context, String key) {
super(context, key);
@@ -66,15 +68,26 @@ public abstract class TypeFilterPreferenceController extends BasePreferenceContr
return this;
}
public TypeFilterPreferenceController setTargetSdk(int targetSdk) {
mTargetSdk = targetSdk;
return this;
}
abstract protected int getType();
@Override
public int getAvailabilityStatus() {
if (mNm.isNotificationListenerAccessGranted(mCn)) {
return AVAILABLE;
} else {
return DISABLED_DEPENDENT_SETTING;
if (mTargetSdk > Build.VERSION_CODES.S) {
return AVAILABLE;
}
mNlf = mNm.getListenerFilter(mCn, mUserId);
if (!mNlf.areAllTypesAllowed() || !mNlf.getDisallowedPackages().isEmpty()) {
return AVAILABLE;
}
}
return DISABLED_DEPENDENT_SETTING;
}
private boolean hasFlag(int value, int flag) {