summaryrefslogtreecommitdiff
path: root/cmds/pm
diff options
context:
space:
mode:
authorSudheer Shanka <sudheersai@google.com>2016-06-17 22:08:07 +0000
committerandroid-build-merger <android-build-merger@google.com>2016-06-17 22:08:07 +0000
commit098bc0d84010db02c9f0072c4c8a564211bc2319 (patch)
tree79930b8dcaa64b2e3bbd8561eb0df181680605fe /cmds/pm
parent821f3b7bf766738fe234e313467a8c495a5cf513 (diff)
parentf6824b51cca4ecb0812f8ccd97e71ae9077f8671 (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.java36
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;