Introduce concept of DockUser
Dreams and docking often refers to "user zero" or "system user". But more generally, the special user for dreams or switching-to-on-docking need not be user 0, and in fact won't be in certain modes. So this needs updating. Test: the files mentioned in the topic Bug: 257333623 Change-Id: If068aa79a770bed4abf3f7ca1859a95cd1eb4ecd
This commit is contained in:
@@ -16,7 +16,7 @@
|
||||
|
||||
package com.android.settings.users;
|
||||
|
||||
import static android.provider.Settings.Secure.TIMEOUT_TO_USER_ZERO;
|
||||
import static android.provider.Settings.Secure.TIMEOUT_TO_DOCK_USER;
|
||||
|
||||
import android.content.Context;
|
||||
import android.os.UserHandle;
|
||||
@@ -30,20 +30,20 @@ import java.util.Arrays;
|
||||
|
||||
/**
|
||||
* Controls the preference which launches a settings screen for user to configure whether to
|
||||
* automatically switch to the admin user when the device is docked.
|
||||
* automatically switch to the designated Dock User when the device is docked.
|
||||
*/
|
||||
public class TimeoutToUserZeroPreferenceController extends BasePreferenceController {
|
||||
public class TimeoutToDockUserPreferenceController extends BasePreferenceController {
|
||||
private final String[] mEntries;
|
||||
private final String[] mValues;
|
||||
|
||||
public TimeoutToUserZeroPreferenceController(Context context,
|
||||
public TimeoutToDockUserPreferenceController(Context context,
|
||||
String preferenceKey) {
|
||||
super(context, preferenceKey);
|
||||
|
||||
mEntries = mContext.getResources().getStringArray(
|
||||
com.android.settings.R.array.switch_to_user_zero_when_docked_timeout_entries);
|
||||
com.android.settings.R.array.switch_to_dock_user_when_docked_timeout_entries);
|
||||
mValues = mContext.getResources().getStringArray(
|
||||
com.android.settings.R.array.switch_to_user_zero_when_docked_timeout_values);
|
||||
com.android.settings.R.array.switch_to_dock_user_when_docked_timeout_values);
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -57,7 +57,7 @@ public class TimeoutToUserZeroPreferenceController extends BasePreferenceControl
|
||||
public int getAvailabilityStatus() {
|
||||
// Feature not available on device.
|
||||
if (!mContext.getResources().getBoolean(
|
||||
com.android.internal.R.bool.config_enableTimeoutToUserZeroWhenDocked)) {
|
||||
com.android.internal.R.bool.config_enableTimeoutToDockUserWhenDocked)) {
|
||||
return UNSUPPORTED_ON_DEVICE;
|
||||
}
|
||||
|
||||
@@ -68,6 +68,7 @@ public class TimeoutToUserZeroPreferenceController extends BasePreferenceControl
|
||||
}
|
||||
|
||||
// Is currently user zero. Only non user zero can have this setting.
|
||||
// TODO(b/257333623): Allow the Dock User to be non-SystemUser user in HSUM.
|
||||
if (UserHandle.myUserId() == UserHandle.USER_SYSTEM) {
|
||||
return DISABLED_FOR_USER;
|
||||
}
|
||||
@@ -78,9 +79,9 @@ public class TimeoutToUserZeroPreferenceController extends BasePreferenceControl
|
||||
@Override
|
||||
public CharSequence getSummary() {
|
||||
final String key = Settings.Secure.getStringForUser(mContext.getContentResolver(),
|
||||
TIMEOUT_TO_USER_ZERO, UserHandle.myUserId());
|
||||
TIMEOUT_TO_DOCK_USER, UserHandle.myUserId());
|
||||
final int index = Arrays.asList(mValues).indexOf(key != null ? key :
|
||||
mValues[TimeoutToUserZeroSettings.DEFAULT_TIMEOUT_SETTING_VALUE_INDEX]);
|
||||
mValues[TimeoutToDockUserSettings.DEFAULT_TIMEOUT_SETTING_VALUE_INDEX]);
|
||||
|
||||
return mEntries[index];
|
||||
}
|
||||
@@ -16,7 +16,7 @@
|
||||
|
||||
package com.android.settings.users;
|
||||
|
||||
import static android.provider.Settings.Secure.TIMEOUT_TO_USER_ZERO;
|
||||
import static android.provider.Settings.Secure.TIMEOUT_TO_DOCK_USER;
|
||||
|
||||
import android.app.settings.SettingsEnums;
|
||||
import android.content.Context;
|
||||
@@ -33,9 +33,9 @@ import java.util.List;
|
||||
|
||||
/**
|
||||
* Setting screen that lists options for users to configure whether to automatically switch to the
|
||||
* admin user when the device is docked, and if so duration of the timeout.
|
||||
* Dock User when the device is docked, and if so duration of the timeout.
|
||||
*/
|
||||
public class TimeoutToUserZeroSettings extends RadioButtonPickerFragment {
|
||||
public class TimeoutToDockUserSettings extends RadioButtonPickerFragment {
|
||||
// Index of the default key of the timeout setting if it hasn't been changed by the user.
|
||||
public static final int DEFAULT_TIMEOUT_SETTING_VALUE_INDEX = 0;
|
||||
|
||||
@@ -52,7 +52,7 @@ public class TimeoutToUserZeroSettings extends RadioButtonPickerFragment {
|
||||
|
||||
@Override
|
||||
protected int getPreferenceScreenResId() {
|
||||
return R.xml.user_timeout_to_user_zero_settings;
|
||||
return R.xml.user_timeout_to_dock_user_settings;
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -60,9 +60,9 @@ public class TimeoutToUserZeroSettings extends RadioButtonPickerFragment {
|
||||
super.onAttach(context);
|
||||
|
||||
mEntries = getContext().getResources().getStringArray(
|
||||
R.array.switch_to_user_zero_when_docked_timeout_entries);
|
||||
R.array.switch_to_dock_user_when_docked_timeout_entries);
|
||||
mValues = getContext().getResources().getStringArray(
|
||||
R.array.switch_to_user_zero_when_docked_timeout_values);
|
||||
R.array.switch_to_dock_user_when_docked_timeout_values);
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -83,13 +83,13 @@ public class TimeoutToUserZeroSettings extends RadioButtonPickerFragment {
|
||||
@Override
|
||||
protected String getDefaultKey() {
|
||||
final String defaultKey = Settings.Secure.getStringForUser(
|
||||
getContext().getContentResolver(), TIMEOUT_TO_USER_ZERO, UserHandle.myUserId());
|
||||
getContext().getContentResolver(), TIMEOUT_TO_DOCK_USER, UserHandle.myUserId());
|
||||
return defaultKey != null ? defaultKey : mValues[DEFAULT_TIMEOUT_SETTING_VALUE_INDEX];
|
||||
}
|
||||
|
||||
@Override
|
||||
protected boolean setDefaultKey(String key) {
|
||||
Settings.Secure.putStringForUser(getContext().getContentResolver(), TIMEOUT_TO_USER_ZERO,
|
||||
Settings.Secure.putStringForUser(getContext().getContentResolver(), TIMEOUT_TO_DOCK_USER,
|
||||
key, UserHandle.myUserId());
|
||||
return true;
|
||||
}
|
||||
@@ -127,7 +127,7 @@ public class UserSettings extends SettingsPreferenceFragment
|
||||
private static final String KEY_ADD_USER_WHEN_LOCKED = "user_settings_add_users_when_locked";
|
||||
private static final String KEY_ENABLE_GUEST_TELEPHONY = "enable_guest_calling";
|
||||
private static final String KEY_MULTIUSER_TOP_INTRO = "multiuser_top_intro";
|
||||
private static final String KEY_TIMEOUT_TO_USER_ZERO = "timeout_to_user_zero_preference";
|
||||
private static final String KEY_TIMEOUT_TO_DOCK_USER = "timeout_to_dock_user_preference";
|
||||
private static final String KEY_GUEST_CATEGORY = "guest_category";
|
||||
private static final String KEY_GUEST_RESET = "guest_reset";
|
||||
private static final String KEY_GUEST_EXIT = "guest_exit";
|
||||
@@ -220,7 +220,7 @@ public class UserSettings extends SettingsPreferenceFragment
|
||||
private GuestTelephonyPreferenceController mGuestTelephonyPreferenceController;
|
||||
private RemoveGuestOnExitPreferenceController mRemoveGuestOnExitPreferenceController;
|
||||
private MultiUserTopIntroPreferenceController mMultiUserTopIntroPreferenceController;
|
||||
private TimeoutToUserZeroPreferenceController mTimeoutToUserZeroPreferenceController;
|
||||
private TimeoutToDockUserPreferenceController mTimeoutToDockUserPreferenceController;
|
||||
private UserCreatingDialog mUserCreatingDialog;
|
||||
private final AtomicBoolean mGuestCreationScheduled = new AtomicBoolean();
|
||||
private final ExecutorService mExecutor = Executors.newSingleThreadExecutor();
|
||||
@@ -322,15 +322,15 @@ public class UserSettings extends SettingsPreferenceFragment
|
||||
mMultiUserTopIntroPreferenceController = new MultiUserTopIntroPreferenceController(activity,
|
||||
KEY_MULTIUSER_TOP_INTRO);
|
||||
|
||||
mTimeoutToUserZeroPreferenceController = new TimeoutToUserZeroPreferenceController(activity,
|
||||
KEY_TIMEOUT_TO_USER_ZERO);
|
||||
mTimeoutToDockUserPreferenceController = new TimeoutToDockUserPreferenceController(
|
||||
activity, KEY_TIMEOUT_TO_DOCK_USER);
|
||||
|
||||
final PreferenceScreen screen = getPreferenceScreen();
|
||||
mAddUserWhenLockedPreferenceController.displayPreference(screen);
|
||||
mGuestTelephonyPreferenceController.displayPreference(screen);
|
||||
mRemoveGuestOnExitPreferenceController.displayPreference(screen);
|
||||
mMultiUserTopIntroPreferenceController.displayPreference(screen);
|
||||
mTimeoutToUserZeroPreferenceController.displayPreference(screen);
|
||||
mTimeoutToDockUserPreferenceController.displayPreference(screen);
|
||||
|
||||
screen.findPreference(mAddUserWhenLockedPreferenceController.getPreferenceKey())
|
||||
.setOnPreferenceChangeListener(mAddUserWhenLockedPreferenceController);
|
||||
@@ -409,8 +409,8 @@ public class UserSettings extends SettingsPreferenceFragment
|
||||
mAddUserWhenLockedPreferenceController.getPreferenceKey()));
|
||||
mGuestTelephonyPreferenceController.updateState(screen.findPreference(
|
||||
mGuestTelephonyPreferenceController.getPreferenceKey()));
|
||||
mTimeoutToUserZeroPreferenceController.updateState(screen.findPreference(
|
||||
mTimeoutToUserZeroPreferenceController.getPreferenceKey()));
|
||||
mTimeoutToDockUserPreferenceController.updateState(screen.findPreference(
|
||||
mTimeoutToDockUserPreferenceController.getPreferenceKey()));
|
||||
mRemoveGuestOnExitPreferenceController.updateState(screen.findPreference(
|
||||
mRemoveGuestOnExitPreferenceController.getPreferenceKey()));
|
||||
if (mShouldUpdateUserList) {
|
||||
|
||||
Reference in New Issue
Block a user