Merge "Only allow clearing of Euicc Data by owner or demo user" into main am: f1cbe74e08
am: ad49e33f01
am: c200d097e9
Original change: https://android-review.googlesource.com/c/platform/packages/apps/Settings/+/2264402 Change-Id: I53046b290eebcfc8647f19e66539dbb84f34afee Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
This commit is contained in:
@@ -18,10 +18,12 @@ package com.android.settings.network;
|
|||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
|
import android.os.UserManager;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
|
|
||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
|
|
||||||
|
import com.android.settings.Utils;
|
||||||
import com.android.settings.core.BasePreferenceController;
|
import com.android.settings.core.BasePreferenceController;
|
||||||
import com.android.settings.core.PreferenceControllerMixin;
|
import com.android.settings.core.PreferenceControllerMixin;
|
||||||
import com.android.settings.network.telephony.MobileNetworkUtils;
|
import com.android.settings.network.telephony.MobileNetworkUtils;
|
||||||
@@ -33,8 +35,11 @@ import com.android.settings.system.ResetDashboardFragment;
|
|||||||
public class EraseEuiccDataController extends BasePreferenceController {
|
public class EraseEuiccDataController extends BasePreferenceController {
|
||||||
private ResetDashboardFragment mHostFragment;
|
private ResetDashboardFragment mHostFragment;
|
||||||
|
|
||||||
|
private final UserManager mUm;
|
||||||
|
|
||||||
public EraseEuiccDataController(Context context, String preferenceKey) {
|
public EraseEuiccDataController(Context context, String preferenceKey) {
|
||||||
super(context, preferenceKey);
|
super(context, preferenceKey);
|
||||||
|
mUm = context.getSystemService(UserManager.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setFragment(ResetDashboardFragment hostFragment) {
|
public void setFragment(ResetDashboardFragment hostFragment) {
|
||||||
@@ -52,10 +57,12 @@ public class EraseEuiccDataController extends BasePreferenceController {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getAvailabilityStatus() {
|
public int getAvailabilityStatus() {
|
||||||
return SubscriptionUtil.isSimHardwareVisible(mContext) &&
|
boolean isAllowedUser = (mUm.isAdminUser() || Utils.isDemoUser(mContext))
|
||||||
(!MobileNetworkUtils.isMobileNetworkUserRestricted(mContext)) &&
|
&& !MobileNetworkUtils.isMobileNetworkUserRestricted(mContext);
|
||||||
mContext.getPackageManager().hasSystemFeature(
|
boolean hasEuiccFeature = mContext.getPackageManager().hasSystemFeature(
|
||||||
PackageManager.FEATURE_TELEPHONY_EUICC) ? AVAILABLE_UNSEARCHABLE
|
PackageManager.FEATURE_TELEPHONY_EUICC);
|
||||||
: UNSUPPORTED_ON_DEVICE;
|
return SubscriptionUtil.isSimHardwareVisible(mContext)
|
||||||
|
&& isAllowedUser
|
||||||
|
&& hasEuiccFeature ? AVAILABLE_UNSEARCHABLE : UNSUPPORTED_ON_DEVICE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user