diff options
author | TreeHugger Robot <treehugger-gerrit@google.com> | 2016-06-17 22:03:58 +0000 |
---|---|---|
committer | Android (Google) Code Review <android-gerrit@google.com> | 2016-06-17 22:03:59 +0000 |
commit | f6824b51cca4ecb0812f8ccd97e71ae9077f8671 (patch) | |
tree | 6602d83db57539371a9f86235464f948b2173aa3 | |
parent | 8cbe1a6309ed330000269dccbfce26de97f11e83 (diff) | |
parent | bf0a9a7445ffb8718d238d43833f48893e8d5d41 (diff) |
Merge "Add pm operation to set user restrictions." into nyc-dev
-rw-r--r-- | cmds/pm/src/com/android/commands/pm/Pm.java | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/cmds/pm/src/com/android/commands/pm/Pm.java b/cmds/pm/src/com/android/commands/pm/Pm.java index 4470eda0a2fa..c6834f940554 100644 --- a/cmds/pm/src/com/android/commands/pm/Pm.java +++ b/cmds/pm/src/com/android/commands/pm/Pm.java @@ -254,6 +254,10 @@ public final class Pm { return runMovePrimaryStorage(); } + if ("set-user-restriction".equals(op)) { + return runSetUserRestriction(); + } + try { if (args.length == 1) { if (args[0].equalsIgnoreCase("-l")) { @@ -1054,6 +1058,38 @@ public final class Pm { } } + public int runSetUserRestriction() { + int userId = UserHandle.USER_SYSTEM; + String opt = nextOption(); + if (opt != null && "--user".equals(opt)) { + String arg = nextArg(); + if (arg == null || !isNumber(arg)) { + System.err.println("Error: valid userId not specified"); + return 1; + } + userId = Integer.parseInt(arg); + } + + String restriction = nextArg(); + String arg = nextArg(); + boolean value; + if ("1".equals(arg)) { + value = true; + } else if ("0".equals(arg)) { + value = false; + } else { + System.err.println("Error: valid value not specified"); + return 1; + } + try { + mUm.setUserRestriction(restriction, value, userId); + return 0; + } catch (RemoteException e) { + System.err.println(e.toString()); + return 1; + } + } + static class ClearDataObserver extends IPackageDataObserver.Stub { boolean finished; boolean result; |