diff options
author | Sudheer Shanka <sudheersai@google.com> | 2016-06-17 22:08:07 +0000 |
---|---|---|
committer | android-build-merger <android-build-merger@google.com> | 2016-06-17 22:08:07 +0000 |
commit | 098bc0d84010db02c9f0072c4c8a564211bc2319 (patch) | |
tree | 79930b8dcaa64b2e3bbd8561eb0df181680605fe /cmds/pm | |
parent | 821f3b7bf766738fe234e313467a8c495a5cf513 (diff) | |
parent | f6824b51cca4ecb0812f8ccd97e71ae9077f8671 (diff) |
Merge \"Add pm operation to set user restrictions.\" into nyc-dev
am: f6824b51cc
Change-Id: I137151742049c0a02d41a02e49abb679234f14b9
Diffstat (limited to 'cmds/pm')
-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; |