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();
|
||||
|
||||
Reference in New Issue
Block a user