diff options
| -rw-r--r-- | api/current.txt | 2 | ||||
| -rw-r--r-- | api/system-current.txt | 2 | ||||
| -rw-r--r-- | api/test-current.txt | 2 | ||||
| -rw-r--r-- | core/java/android/os/Process.java | 10 | ||||
| -rw-r--r-- | core/java/android/os/UserHandle.java | 9 |
5 files changed, 25 insertions, 0 deletions
diff --git a/api/current.txt b/api/current.txt index 8b9274cbce9c..0d031bc429c0 100644 --- a/api/current.txt +++ b/api/current.txt @@ -29061,6 +29061,7 @@ package android.os { method public static final int getThreadPriority(int) throws java.lang.IllegalArgumentException; method public static final int getUidForName(java.lang.String); method public static final boolean is64Bit(); + method public static boolean isApplicationUid(int); method public static final void killProcess(int); method public static final int myPid(); method public static final int myTid(); @@ -29241,6 +29242,7 @@ package android.os { public final class UserHandle implements android.os.Parcelable { ctor public UserHandle(android.os.Parcel); method public int describeContents(); + method public static android.os.UserHandle getUserHandleForUid(int); method public static android.os.UserHandle readFromParcel(android.os.Parcel); method public void writeToParcel(android.os.Parcel, int); method public static void writeToParcel(android.os.UserHandle, android.os.Parcel); diff --git a/api/system-current.txt b/api/system-current.txt index 43a787f4486e..1af8150c035f 100644 --- a/api/system-current.txt +++ b/api/system-current.txt @@ -31354,6 +31354,7 @@ package android.os { method public static final int getThreadPriority(int) throws java.lang.IllegalArgumentException; method public static final int getUidForName(java.lang.String); method public static final boolean is64Bit(); + method public static boolean isApplicationUid(int); method public static final void killProcess(int); method public static final int myPid(); method public static final int myTid(); @@ -31580,6 +31581,7 @@ package android.os { ctor public UserHandle(android.os.Parcel); method public int describeContents(); method public int getIdentifier(); + method public static android.os.UserHandle getUserHandleForUid(int); method public deprecated boolean isOwner(); method public boolean isSystem(); method public static int myUserId(); diff --git a/api/test-current.txt b/api/test-current.txt index 428b359be05e..b6b8697fdaae 100644 --- a/api/test-current.txt +++ b/api/test-current.txt @@ -29070,6 +29070,7 @@ package android.os { method public static final int getThreadPriority(int) throws java.lang.IllegalArgumentException; method public static final int getUidForName(java.lang.String); method public static final boolean is64Bit(); + method public static boolean isApplicationUid(int); method public static final void killProcess(int); method public static final int myPid(); method public static final int myTid(); @@ -29251,6 +29252,7 @@ package android.os { ctor public UserHandle(android.os.Parcel); method public int describeContents(); method public static int getAppId(int); + method public static android.os.UserHandle getUserHandleForUid(int); method public static android.os.UserHandle readFromParcel(android.os.Parcel); method public void writeToParcel(android.os.Parcel, int); method public static void writeToParcel(android.os.UserHandle, android.os.Parcel); diff --git a/core/java/android/os/Process.java b/core/java/android/os/Process.java index b51d2dfb8694..9984755d316f 100644 --- a/core/java/android/os/Process.java +++ b/core/java/android/os/Process.java @@ -823,6 +823,16 @@ public class Process { } /** + * Returns whether the given uid belongs to an application. + * @param uid A kernel uid. + * @return Whether the uid corresponds to an application sandbox running in + * a specific user. + */ + public static boolean isApplicationUid(int uid) { + return UserHandle.isApp(uid); + } + + /** * Returns whether the current process is in an isolated sandbox. * @hide */ diff --git a/core/java/android/os/UserHandle.java b/core/java/android/os/UserHandle.java index 24666fe71724..b3f44536214b 100644 --- a/core/java/android/os/UserHandle.java +++ b/core/java/android/os/UserHandle.java @@ -130,6 +130,15 @@ public final class UserHandle implements Parcelable { } /** + * Returns the user for a given uid. + * @param uid A uid for an application running in a particular user. + * @return A {@link UserHandle} for that user. + */ + public static UserHandle getUserHandleForUid(int uid) { + return of(getUserId(uid)); + } + + /** * Returns the user id for a given uid. * @hide */ |