Merge "Check whether the user is a sub profile before starting Settings homepage" into main
This commit is contained in:
@@ -20,6 +20,7 @@ import android.app.Activity
|
||||
import android.content.ActivityNotFoundException
|
||||
import android.content.Context
|
||||
import android.content.Intent
|
||||
import android.content.pm.UserInfo
|
||||
import android.provider.Settings
|
||||
import android.util.Log
|
||||
import com.android.settings.SettingsActivity
|
||||
@@ -93,9 +94,17 @@ object EmbeddedDeepLinkUtils {
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Returns whether the user is a sub profile.
|
||||
*/
|
||||
@JvmStatic
|
||||
fun isSubProfile(userInfo: UserInfo): Boolean =
|
||||
userInfo.isManagedProfile || userInfo.isPrivateProfile
|
||||
|
||||
private fun Context.startTrampolineIntent(trampolineIntent: Intent): Boolean = try {
|
||||
val userInfo = userManager.getUserInfo(user.identifier)
|
||||
if (userInfo.isManagedProfile) {
|
||||
if (isSubProfile(userInfo)) {
|
||||
trampolineIntent.setClass(this, DeepLinkHomepageActivityInternal::class.java)
|
||||
.putExtra(SettingsActivity.EXTRA_USER_HANDLE, user)
|
||||
startActivityAsUser(
|
||||
|
||||
@@ -70,6 +70,7 @@ import com.android.settings.SettingsApplication;
|
||||
import com.android.settings.accounts.AvatarViewMixin;
|
||||
import com.android.settings.activityembedding.ActivityEmbeddingRulesController;
|
||||
import com.android.settings.activityembedding.ActivityEmbeddingUtils;
|
||||
import com.android.settings.activityembedding.EmbeddedDeepLinkUtils;
|
||||
import com.android.settings.core.CategoryMixin;
|
||||
import com.android.settings.core.FeatureFlags;
|
||||
import com.android.settings.homepage.contextualcards.ContextualCardsFragment;
|
||||
@@ -204,7 +205,7 @@ public class SettingsHomepageActivity extends FragmentActivity implements
|
||||
if (mIsEmbeddingActivityEnabled) {
|
||||
final UserManager um = getSystemService(UserManager.class);
|
||||
final UserInfo userInfo = um.getUserInfo(getUserId());
|
||||
if (userInfo.isManagedProfile()) {
|
||||
if (EmbeddedDeepLinkUtils.isSubProfile(userInfo)) {
|
||||
final Intent intent = new Intent(getIntent())
|
||||
.addFlags(Intent.FLAG_ACTIVITY_FORWARD_RESULT)
|
||||
.putExtra(EXTRA_USER_HANDLE, getUser())
|
||||
|
||||
Reference in New Issue
Block a user