Merge "Add an intent extra to force master clear" into nyc-mr1-dev
am: 3c826b160c
* commit '3c826b160c724d38f49bb479aa13ab8cf685e2d2':
Add an intent extra to force master clear
Change-Id: I5789ac49b040ba6b1330e9680c1a595f24e82af9
This commit is contained in:
@@ -3173,6 +3173,14 @@ public class Intent implements Parcelable, Cloneable {
|
||||
/** {@hide} */
|
||||
public static final String ACTION_MASTER_CLEAR = "android.intent.action.MASTER_CLEAR";
|
||||
|
||||
/**
|
||||
* Boolean intent extra to be used with {@link ACTION_MASTER_CLEAR} in order to force a factory
|
||||
* reset even if {@link android.os.UserManager.DISALLOW_FACTORY_RESET} is set.
|
||||
* @hide
|
||||
*/
|
||||
public static final String EXTRA_FORCE_MASTER_CLEAR =
|
||||
"android.intent.extra.FORCE_MASTER_CLEAR";
|
||||
|
||||
/**
|
||||
* Broadcast action: report that a settings element is being restored from backup. The intent
|
||||
* contains three extras: EXTRA_SETTING_NAME is a string naming the restored setting,
|
||||
|
||||
@@ -570,18 +570,19 @@ public class RecoverySystem {
|
||||
* @throws SecurityException if the current user is not allowed to wipe data.
|
||||
*/
|
||||
public static void rebootWipeUserData(Context context) throws IOException {
|
||||
rebootWipeUserData(context, false, context.getPackageName());
|
||||
rebootWipeUserData(context, false /* shutdown */, context.getPackageName(),
|
||||
false /* force */);
|
||||
}
|
||||
|
||||
/** {@hide} */
|
||||
public static void rebootWipeUserData(Context context, String reason) throws IOException {
|
||||
rebootWipeUserData(context, false, reason);
|
||||
rebootWipeUserData(context, false /* shutdown */, reason, false /* force */);
|
||||
}
|
||||
|
||||
/** {@hide} */
|
||||
public static void rebootWipeUserData(Context context, boolean shutdown)
|
||||
throws IOException {
|
||||
rebootWipeUserData(context, shutdown, context.getPackageName());
|
||||
rebootWipeUserData(context, shutdown, context.getPackageName(), false /* force */);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -595,6 +596,9 @@ public class RecoverySystem {
|
||||
* @param shutdown if true, the device will be powered down after
|
||||
* the wipe completes, rather than being rebooted
|
||||
* back to the regular system.
|
||||
* @param reason the reason for the wipe that is visible in the logs
|
||||
* @param force whether the {@link UserManager.DISALLOW_FACTORY_RESET} user restriction
|
||||
* should be ignored
|
||||
*
|
||||
* @throws IOException if writing the recovery command file
|
||||
* fails, or if the reboot itself fails.
|
||||
@@ -602,10 +606,10 @@ public class RecoverySystem {
|
||||
*
|
||||
* @hide
|
||||
*/
|
||||
public static void rebootWipeUserData(Context context, boolean shutdown, String reason)
|
||||
throws IOException {
|
||||
public static void rebootWipeUserData(Context context, boolean shutdown, String reason,
|
||||
boolean force) throws IOException {
|
||||
UserManager um = (UserManager) context.getSystemService(Context.USER_SERVICE);
|
||||
if (um.hasUserRestriction(UserManager.DISALLOW_FACTORY_RESET)) {
|
||||
if (!force && um.hasUserRestriction(UserManager.DISALLOW_FACTORY_RESET)) {
|
||||
throw new SecurityException("Wiping data is not allowed for this user.");
|
||||
}
|
||||
final ConditionVariable condition = new ConditionVariable();
|
||||
|
||||
@@ -47,6 +47,7 @@ public class MasterClearReceiver extends BroadcastReceiver {
|
||||
final String reason = intent.getStringExtra(Intent.EXTRA_REASON);
|
||||
final boolean wipeExternalStorage = intent.getBooleanExtra(
|
||||
Intent.EXTRA_WIPE_EXTERNAL_STORAGE, false);
|
||||
final boolean forceWipe = intent.getBooleanExtra(Intent.EXTRA_FORCE_MASTER_CLEAR, false);
|
||||
|
||||
Slog.w(TAG, "!!! FACTORY RESET !!!");
|
||||
// The reboot call is blocking, so we need to do it on another thread.
|
||||
@@ -54,7 +55,7 @@ public class MasterClearReceiver extends BroadcastReceiver {
|
||||
@Override
|
||||
public void run() {
|
||||
try {
|
||||
RecoverySystem.rebootWipeUserData(context, shutdown, reason);
|
||||
RecoverySystem.rebootWipeUserData(context, shutdown, reason, forceWipe);
|
||||
Log.wtf(TAG, "Still running after master clear?!");
|
||||
} catch (IOException e) {
|
||||
Slog.e(TAG, "Can't perform master clear/factory reset", e);
|
||||
|
||||
Reference in New Issue
Block a user