Show disabled add actions in COPE mode
Before this change these actions were hidden. After this change, they are displayed but disabled which makes it more intuitive. Bug: 336762423 Test: atest UserSettingsTest && atest UserDetailsSettingsTest Flag: android.multiuser.new_multiuser_settings_ux Change-Id: Ie07816b7d3817d12e78e1ec2692fcddea9328933
This commit is contained in:
@@ -43,10 +43,12 @@ public class AddUserWhenLockedPreferenceController extends TogglePreferenceContr
|
|||||||
restrictedSwitchPreference.setVisible(false);
|
restrictedSwitchPreference.setVisible(false);
|
||||||
} else {
|
} else {
|
||||||
if (android.multiuser.Flags.newMultiuserSettingsUx()) {
|
if (android.multiuser.Flags.newMultiuserSettingsUx()) {
|
||||||
|
restrictedSwitchPreference.setVisible(true);
|
||||||
if (mUserCaps.mDisallowAddUserSetByAdmin) {
|
if (mUserCaps.mDisallowAddUserSetByAdmin) {
|
||||||
restrictedSwitchPreference.setDisabledByAdmin(mUserCaps.mEnforcedAdmin);
|
restrictedSwitchPreference.setDisabledByAdmin(mUserCaps.mEnforcedAdmin);
|
||||||
|
} else if (mUserCaps.mDisallowAddUser) {
|
||||||
|
restrictedSwitchPreference.setVisible(false);
|
||||||
}
|
}
|
||||||
restrictedSwitchPreference.setVisible(true);
|
|
||||||
} else {
|
} else {
|
||||||
restrictedSwitchPreference.setDisabledByAdmin(
|
restrictedSwitchPreference.setDisabledByAdmin(
|
||||||
mUserCaps.disallowAddUser() ? mUserCaps.getEnforcedAdmin() : null);
|
mUserCaps.disallowAddUser() ? mUserCaps.getEnforcedAdmin() : null);
|
||||||
|
@@ -19,12 +19,16 @@ package com.android.settings.users;
|
|||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
|
import android.os.UserHandle;
|
||||||
import android.os.UserManager;
|
import android.os.UserManager;
|
||||||
|
|
||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.core.TogglePreferenceController;
|
import com.android.settings.core.TogglePreferenceController;
|
||||||
|
import com.android.settingslib.RestrictedLockUtils;
|
||||||
|
import com.android.settingslib.RestrictedLockUtilsInternal;
|
||||||
|
import com.android.settingslib.RestrictedSwitchPreference;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Controls the preference on the user settings screen which determines whether the guest user
|
* Controls the preference on the user settings screen which determines whether the guest user
|
||||||
@@ -43,6 +47,10 @@ public class GuestTelephonyPreferenceController extends TogglePreferenceControll
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getAvailabilityStatus() {
|
public int getAvailabilityStatus() {
|
||||||
|
if (!mContext.getPackageManager().hasSystemFeature(PackageManager.FEATURE_TELEPHONY)
|
||||||
|
|| UserManager.isHeadlessSystemUserMode()) {
|
||||||
|
return DISABLED_FOR_USER;
|
||||||
|
}
|
||||||
if (android.multiuser.Flags.newMultiuserSettingsUx()) {
|
if (android.multiuser.Flags.newMultiuserSettingsUx()) {
|
||||||
if (!mUserCaps.isAdmin()) {
|
if (!mUserCaps.isAdmin()) {
|
||||||
return DISABLED_FOR_USER;
|
return DISABLED_FOR_USER;
|
||||||
@@ -81,8 +89,31 @@ public class GuestTelephonyPreferenceController extends TogglePreferenceControll
|
|||||||
public void updateState(Preference preference) {
|
public void updateState(Preference preference) {
|
||||||
super.updateState(preference);
|
super.updateState(preference);
|
||||||
mUserCaps.updateAddUserCapabilities(mContext);
|
mUserCaps.updateAddUserCapabilities(mContext);
|
||||||
preference.setVisible(isAvailable()
|
final RestrictedSwitchPreference restrictedSwitchPreference =
|
||||||
&& mContext.getPackageManager().hasSystemFeature(PackageManager.FEATURE_TELEPHONY)
|
(RestrictedSwitchPreference) preference;
|
||||||
&& !UserManager.isHeadlessSystemUserMode());
|
restrictedSwitchPreference.setChecked(isChecked());
|
||||||
|
if (!isAvailable()) {
|
||||||
|
restrictedSwitchPreference.setVisible(false);
|
||||||
|
} else {
|
||||||
|
if (android.multiuser.Flags.newMultiuserSettingsUx()) {
|
||||||
|
restrictedSwitchPreference.setVisible(true);
|
||||||
|
final RestrictedLockUtils.EnforcedAdmin disallowRemoveUserAdmin =
|
||||||
|
RestrictedLockUtilsInternal.checkIfRestrictionEnforced(mContext,
|
||||||
|
UserManager.DISALLOW_REMOVE_USER, UserHandle.myUserId());
|
||||||
|
if (disallowRemoveUserAdmin != null) {
|
||||||
|
restrictedSwitchPreference.setDisabledByAdmin(disallowRemoveUserAdmin);
|
||||||
|
} else if (mUserCaps.mDisallowAddUserSetByAdmin) {
|
||||||
|
restrictedSwitchPreference.setDisabledByAdmin(mUserCaps.mEnforcedAdmin);
|
||||||
|
} else if (mUserCaps.mDisallowAddUser) {
|
||||||
|
// Adding user is restricted by system
|
||||||
|
restrictedSwitchPreference.setVisible(false);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
restrictedSwitchPreference.setDisabledByAdmin(
|
||||||
|
mUserCaps.disallowAddUser() ? mUserCaps.getEnforcedAdmin() : null);
|
||||||
|
restrictedSwitchPreference.setVisible(mUserCaps.mUserSwitcherEnabled
|
||||||
|
&& isAvailable());
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -74,11 +74,18 @@ public class RemoveGuestOnExitPreferenceController extends BasePreferenceControl
|
|||||||
restrictedSwitchPreference.setVisible(false);
|
restrictedSwitchPreference.setVisible(false);
|
||||||
} else {
|
} else {
|
||||||
if (android.multiuser.Flags.newMultiuserSettingsUx()) {
|
if (android.multiuser.Flags.newMultiuserSettingsUx()) {
|
||||||
|
restrictedSwitchPreference.setVisible(true);
|
||||||
final RestrictedLockUtils.EnforcedAdmin disallowRemoveUserAdmin =
|
final RestrictedLockUtils.EnforcedAdmin disallowRemoveUserAdmin =
|
||||||
RestrictedLockUtilsInternal.checkIfRestrictionEnforced(mContext,
|
RestrictedLockUtilsInternal.checkIfRestrictionEnforced(mContext,
|
||||||
UserManager.DISALLOW_REMOVE_USER, UserHandle.myUserId());
|
UserManager.DISALLOW_REMOVE_USER, UserHandle.myUserId());
|
||||||
restrictedSwitchPreference.setDisabledByAdmin(disallowRemoveUserAdmin);
|
if (disallowRemoveUserAdmin != null) {
|
||||||
restrictedSwitchPreference.setVisible(true);
|
restrictedSwitchPreference.setDisabledByAdmin(disallowRemoveUserAdmin);
|
||||||
|
} else if (mUserCaps.mDisallowAddUserSetByAdmin) {
|
||||||
|
restrictedSwitchPreference.setDisabledByAdmin(mUserCaps.mEnforcedAdmin);
|
||||||
|
} else if (mUserCaps.mDisallowAddUser) {
|
||||||
|
// Adding user is restricted by system
|
||||||
|
restrictedSwitchPreference.setVisible(false);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
restrictedSwitchPreference.setDisabledByAdmin(
|
restrictedSwitchPreference.setDisabledByAdmin(
|
||||||
mUserCaps.disallowAddUser() ? mUserCaps.getEnforcedAdmin() : null);
|
mUserCaps.disallowAddUser() ? mUserCaps.getEnforcedAdmin() : null);
|
||||||
|
@@ -1469,7 +1469,7 @@ public class UserSettings extends SettingsPreferenceFragment
|
|||||||
private boolean updateAddGuestPreference(Context context, boolean isGuestAlreadyCreated) {
|
private boolean updateAddGuestPreference(Context context, boolean isGuestAlreadyCreated) {
|
||||||
boolean isVisible = false;
|
boolean isVisible = false;
|
||||||
if (!isGuestAlreadyCreated && (mUserCaps.mCanAddGuest
|
if (!isGuestAlreadyCreated && (mUserCaps.mCanAddGuest
|
||||||
|| (Flags.newMultiuserSettingsUx() && mUserCaps.mDisallowAddUserSetByAdmin))
|
|| (Flags.newMultiuserSettingsUx() && mUserCaps.mDisallowAddUser))
|
||||||
&& mUserManager.canAddMoreUsers(UserManager.USER_TYPE_FULL_GUEST)
|
&& mUserManager.canAddMoreUsers(UserManager.USER_TYPE_FULL_GUEST)
|
||||||
&& WizardManagerHelper.isDeviceProvisioned(context)
|
&& WizardManagerHelper.isDeviceProvisioned(context)
|
||||||
&& (mUserCaps.mUserSwitcherEnabled || Flags.newMultiuserSettingsUx())) {
|
&& (mUserCaps.mUserSwitcherEnabled || Flags.newMultiuserSettingsUx())) {
|
||||||
@@ -1488,6 +1488,19 @@ public class UserSettings extends SettingsPreferenceFragment
|
|||||||
if (Flags.newMultiuserSettingsUx()
|
if (Flags.newMultiuserSettingsUx()
|
||||||
&& mUserCaps.mDisallowAddUserSetByAdmin) {
|
&& mUserCaps.mDisallowAddUserSetByAdmin) {
|
||||||
mAddGuest.setDisabledByAdmin(mUserCaps.mEnforcedAdmin);
|
mAddGuest.setDisabledByAdmin(mUserCaps.mEnforcedAdmin);
|
||||||
|
} else if (Flags.newMultiuserSettingsUx() && mUserCaps.mDisallowAddUser) {
|
||||||
|
final List<UserManager.EnforcingUser> enforcingUsers =
|
||||||
|
mUserManager.getUserRestrictionSources(UserManager.DISALLOW_ADD_USER,
|
||||||
|
UserHandle.of(UserHandle.myUserId()));
|
||||||
|
if (!enforcingUsers.isEmpty()) {
|
||||||
|
final UserManager.EnforcingUser enforcingUser = enforcingUsers.get(0);
|
||||||
|
final int restrictionSource = enforcingUser.getUserRestrictionSource();
|
||||||
|
if (restrictionSource == UserManager.RESTRICTION_SOURCE_SYSTEM) {
|
||||||
|
mAddGuest.setEnabled(false);
|
||||||
|
} else {
|
||||||
|
mAddGuest.setVisible(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
mAddGuest.setEnabled(canSwitchUserNow() || Flags.newMultiuserSettingsUx());
|
mAddGuest.setEnabled(canSwitchUserNow() || Flags.newMultiuserSettingsUx());
|
||||||
}
|
}
|
||||||
@@ -1518,7 +1531,8 @@ public class UserSettings extends SettingsPreferenceFragment
|
|||||||
|
|
||||||
private void updateAddUserCommon(Context context, RestrictedPreference addUser,
|
private void updateAddUserCommon(Context context, RestrictedPreference addUser,
|
||||||
boolean canAddRestrictedProfile) {
|
boolean canAddRestrictedProfile) {
|
||||||
if ((mUserCaps.mCanAddUser && !mUserCaps.mDisallowAddUserSetByAdmin)
|
if ((mUserCaps.mCanAddUser
|
||||||
|
&& !(mUserCaps.mDisallowAddUserSetByAdmin && Flags.newMultiuserSettingsUx()))
|
||||||
&& WizardManagerHelper.isDeviceProvisioned(context)
|
&& WizardManagerHelper.isDeviceProvisioned(context)
|
||||||
&& (mUserCaps.mUserSwitcherEnabled || Flags.newMultiuserSettingsUx())) {
|
&& (mUserCaps.mUserSwitcherEnabled || Flags.newMultiuserSettingsUx())) {
|
||||||
addUser.setVisible(true);
|
addUser.setVisible(true);
|
||||||
@@ -1539,10 +1553,23 @@ public class UserSettings extends SettingsPreferenceFragment
|
|||||||
addUser.setDisabledByAdmin(
|
addUser.setDisabledByAdmin(
|
||||||
mUserCaps.mDisallowAddUser ? mUserCaps.mEnforcedAdmin : null);
|
mUserCaps.mDisallowAddUser ? mUserCaps.mEnforcedAdmin : null);
|
||||||
}
|
}
|
||||||
} else if (Flags.newMultiuserSettingsUx()
|
} else if (Flags.newMultiuserSettingsUx() && mUserCaps.mDisallowAddUserSetByAdmin) {
|
||||||
&& mUserCaps.mDisallowAddUserSetByAdmin) {
|
|
||||||
addUser.setVisible(true);
|
addUser.setVisible(true);
|
||||||
addUser.setDisabledByAdmin(mUserCaps.mEnforcedAdmin);
|
addUser.setDisabledByAdmin(mUserCaps.mEnforcedAdmin);
|
||||||
|
} else if (Flags.newMultiuserSettingsUx() && mUserCaps.mDisallowAddUser) {
|
||||||
|
final List<UserManager.EnforcingUser> enforcingUsers =
|
||||||
|
mUserManager.getUserRestrictionSources(UserManager.DISALLOW_ADD_USER,
|
||||||
|
UserHandle.of(UserHandle.myUserId()));
|
||||||
|
if (!enforcingUsers.isEmpty()) {
|
||||||
|
final UserManager.EnforcingUser enforcingUser = enforcingUsers.get(0);
|
||||||
|
final int restrictionSource = enforcingUser.getUserRestrictionSource();
|
||||||
|
if (restrictionSource == UserManager.RESTRICTION_SOURCE_SYSTEM) {
|
||||||
|
addUser.setVisible(true);
|
||||||
|
addUser.setEnabled(false);
|
||||||
|
} else {
|
||||||
|
addUser.setVisible(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
addUser.setVisible(false);
|
addUser.setVisible(false);
|
||||||
}
|
}
|
||||||
|
@@ -34,6 +34,7 @@ import static org.mockito.Mockito.never;
|
|||||||
import static org.mockito.Mockito.spy;
|
import static org.mockito.Mockito.spy;
|
||||||
import static org.mockito.Mockito.times;
|
import static org.mockito.Mockito.times;
|
||||||
import static org.mockito.Mockito.verify;
|
import static org.mockito.Mockito.verify;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
import static org.robolectric.Shadows.shadowOf;
|
import static org.robolectric.Shadows.shadowOf;
|
||||||
|
|
||||||
import android.app.settings.SettingsEnums;
|
import android.app.settings.SettingsEnums;
|
||||||
@@ -450,6 +451,33 @@ public class UserSettingsTest {
|
|||||||
verify(mAddUserPreference).setEnabled(true);
|
verify(mAddUserPreference).setEnabled(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@RequiresFlagsEnabled({Flags.FLAG_NEW_MULTIUSER_SETTINGS_UX})
|
||||||
|
public void updateUserList_disallowAddUser_shouldShowButDisableAddActions() {
|
||||||
|
givenUsers(getAdminUser(true));
|
||||||
|
mUserCapabilities.mCanAddGuest = true;
|
||||||
|
mUserCapabilities.mCanAddUser = false;
|
||||||
|
mUserCapabilities.mDisallowAddUser = true;
|
||||||
|
mUserCapabilities.mDisallowAddUserSetByAdmin = false;
|
||||||
|
List<UserManager.EnforcingUser> enforcingUsers = new ArrayList<>();
|
||||||
|
enforcingUsers.add(new UserManager.EnforcingUser(UserHandle.myUserId(),
|
||||||
|
UserManager.RESTRICTION_SOURCE_SYSTEM));
|
||||||
|
when(mUserManager.getUserRestrictionSources(UserManager.DISALLOW_ADD_USER,
|
||||||
|
UserHandle.of(UserHandle.myUserId()))).thenReturn(enforcingUsers);
|
||||||
|
|
||||||
|
doReturn(true)
|
||||||
|
.when(mUserManager).canAddMoreUsers(eq(UserManager.USER_TYPE_FULL_GUEST));
|
||||||
|
doReturn(true)
|
||||||
|
.when(mUserManager).canAddMoreUsers(eq(UserManager.USER_TYPE_FULL_SECONDARY));
|
||||||
|
|
||||||
|
mFragment.updateUserList();
|
||||||
|
|
||||||
|
verify(mAddGuestPreference).setVisible(true);
|
||||||
|
verify(mAddGuestPreference).setEnabled(false);
|
||||||
|
verify(mAddUserPreference).setVisible(true);
|
||||||
|
verify(mAddUserPreference).setEnabled(false);
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@RequiresFlagsDisabled({Flags.FLAG_NEW_MULTIUSER_SETTINGS_UX})
|
@RequiresFlagsDisabled({Flags.FLAG_NEW_MULTIUSER_SETTINGS_UX})
|
||||||
public void updateUserList_addUserDisallowedByAdmin_shouldNotShowAddUser() {
|
public void updateUserList_addUserDisallowedByAdmin_shouldNotShowAddUser() {
|
||||||
|
Reference in New Issue
Block a user