/** {@hide} */
public boolean isUserUnlockingOrUnlocked(@UserIdInt int userId) {
+ // TODO Switch to using UMS internal isUserUnlockingOrUnlocked
try {
return ActivityManagerNative.getDefault().isUserRunning(userId,
ActivityManager.FLAG_AND_UNLOCKING_OR_UNLOCKED);
* createAndManageUser is called by the device owner.
*/
public abstract UserInfo createUserEvenWhenDisallowed(String name, int flags);
+
+ /**
+ * Return whether the given user is running in an
+ * {@link com.android.server.am.UserState#STATE_RUNNING_UNLOCKING "unlocking"} or
+ * {@link com.android.server.am.UserState#STATE_RUNNING_UNLOCKED "unlocked"} state.
+ */
+ public abstract boolean isUserUnlockingOrUnlocked(int userId);
+
+ /**
+ * Sets whether the given user is running in an
+ * {@link com.android.server.am.UserState#STATE_RUNNING_UNLOCKING "unlocking"} or
+ * {@link com.android.server.am.UserState#STATE_RUNNING_UNLOCKED "unlocked"} state.
+ */
+ public abstract void setUserUnlockingOrUnlocked(int userId, boolean unlockingOrUnlocked);
}
import static android.Manifest.permission.INTERACT_ACROSS_USERS;
import static android.Manifest.permission.INTERACT_ACROSS_USERS_FULL;
+import static android.app.ActivityManager.FLAG_AND_UNLOCKING_OR_UNLOCKED;
import static android.app.ActivityManager.USER_OP_ERROR_IS_SYSTEM;
import static android.app.ActivityManager.USER_OP_ERROR_RELATED_USERS_CANNOT_STOP;
import static android.app.ActivityManager.USER_OP_IS_CURRENT;
private final LockPatternUtils mLockPatternUtils;
+ private UserManagerInternal mUserManagerInternal;
+
UserController(ActivityManagerService service) {
mService = service;
mHandler = mService.mHandler;
if (!StorageManager.isUserKeyUnlocked(userId)) return;
if (uss.setState(STATE_RUNNING_LOCKED, STATE_RUNNING_UNLOCKING)) {
+ getUserManagerInternal().setUserUnlockingOrUnlocked(userId, true);
uss.mUnlockProgress.start();
// Prepare app storage before we go any further
if (!StorageManager.isUserKeyUnlocked(userId)) return;
if (uss.setState(STATE_RUNNING_UNLOCKING, STATE_RUNNING_UNLOCKED)) {
+ getUserManagerInternal().setUserUnlockingOrUnlocked(userId, true);
uss.mUnlockProgress.finish();
// Dispatch unlocked to external apps
if (uss.state != UserState.STATE_STOPPING
&& uss.state != UserState.STATE_SHUTDOWN) {
uss.setState(UserState.STATE_STOPPING);
+ getUserManagerInternal().setUserUnlockingOrUnlocked(userId, false);
updateStartedUserArrayLocked();
long ident = Binder.clearCallingIdentity();
}
uss.setState(UserState.STATE_SHUTDOWN);
}
+ getUserManagerInternal().setUserUnlockingOrUnlocked(userId, false);
mService.mBatteryStatsService.noteEvent(
BatteryStats.HistoryItem.EVENT_USER_RUNNING_FINISH,
// so we can just fairly silently bring the user back from
// the almost-dead.
uss.setState(uss.lastState);
+ if (isUserRunningLocked(userId, FLAG_AND_UNLOCKING_OR_UNLOCKED)) {
+ getUserManagerInternal().setUserUnlockingOrUnlocked(userId, true);
+ }
updateStartedUserArrayLocked();
needStart = true;
} else if (uss.state == UserState.STATE_SHUTDOWN) {
return mLockPatternUtils.isLockScreenDisabled(userId);
}
+ private UserManagerInternal getUserManagerInternal() {
+ if (mUserManagerInternal == null) {
+ mUserManagerInternal = LocalServices.getService(UserManagerInternal.class);
+ }
+ return mUserManagerInternal;
+ }
+
void dump(PrintWriter pw, boolean dumpAll) {
pw.println(" mStartedUsers:");
for (int i = 0; i < mStartedUsers.size(); i++) {
import android.os.Trace;
import android.os.UserHandle;
import android.os.UserManager;
+import android.os.UserManagerInternal;
import android.os.storage.IMountService;
import android.os.storage.MountServiceInternal;
import android.os.storage.StorageEventListener;
// List of packages names to keep cached, even if they are uninstalled for all users
private List<String> mKeepUninstalledPackages;
+ private UserManagerInternal mUserManagerInternal;
+
private static class IFVerificationParams {
PackageParser.Package pkg;
boolean replacing;
// give them what they want
} else {
// Caller expressed no opinion, so match based on user state
- if (StorageManager.isUserKeyUnlocked(userId)) {
+ if (getUserManagerInternal().isUserUnlockingOrUnlocked(userId)) {
flags |= PackageManager.MATCH_DIRECT_BOOT_AWARE | MATCH_DIRECT_BOOT_UNAWARE;
} else {
flags |= PackageManager.MATCH_DIRECT_BOOT_AWARE;
return flags;
}
+ private UserManagerInternal getUserManagerInternal() {
+ if (mUserManagerInternal == null) {
+ mUserManagerInternal = LocalServices.getService(UserManagerInternal.class);
+ }
+ return mUserManagerInternal;
+ }
+
/**
* Update given flags when being used to request {@link PackageInfo}.
*/
@GuardedBy("mUsersLock")
private boolean mForceEphemeralUsers;
+ @GuardedBy("mUsersLock")
+ private final SparseBooleanArray mUnlockingOrUnlockedUsers = new SparseBooleanArray();
+
private static UserManagerService sInstance;
public static UserManagerService getInstance() {
synchronized (mUsersLock) {
mUsers.remove(userHandle);
mIsUserManaged.delete(userHandle);
+ mUnlockingOrUnlockedUsers.delete(userHandle);
}
synchronized (mRestrictionsLock) {
mBaseUserRestrictions.remove(userHandle);
}
return user;
}
+
+ @Override
+ public void setUserUnlockingOrUnlocked(int userId, boolean unlockingOrUnlocked) {
+ synchronized (mUsersLock) {
+ mUnlockingOrUnlockedUsers.put(userId, unlockingOrUnlocked);
+ }
+ }
+
+ @Override
+ public boolean isUserUnlockingOrUnlocked(int userId) {
+ synchronized (mUsersLock) {
+ return mUnlockingOrUnlockedUsers.get(userId);
+ }
+ }
}
/* Remove all the users except of the system one. */