Android Security: Welcome To Shell (Permissions)

Written on August 16, 2016

Does a shell started from an application have the same permissions as a shell started via adb? What a good question!

ADB is a shell that you get on a PC with the same permissions as if you were to run a shell/terminal app on the phone itself.

I came across this statement on Reddit which went against my intuition and I had a quick look into it. It was important for me so I can understand the difference in potential attack vectors surrounding open shells.

I started by flicking through the excellent Android Security Internals: An In-Depth Guide to Android’s Security Architecture to get an overview about how process permissions worked on android. Most of the overview is just a condensed version of a few pages of this great book.

This post will mostly talk about how this stuff works with low-level kernel permissions work in the OS, as opposed to high-level operations that involve the package manager (pm).

A brief summary of the low-level stuff is:

  • Privileges are based upon the processes UID, GID and supplementary GIDs
  • Like all POSIX systems [clarification needed] access to system resources regulated by the kernel (files, sockets etc) is based on the owner and access mode of the resource and the UID & GID of accessing process
  • Some permissions on Android are mapped to GIDs data/etc/platform.xml
    • Other permissions are checked via pm and I’m guessing are not checkable by the process outlined in this post.
  • These GIDs are mapped to AIDs android_filesystem_config.h
  • For applications (quick diversion) the package manager will add the GIDs for the application at install time, for permissions that appear in the platform.xml file, to data/system/packages.list for the applications entry.
  • When a process is forked from the zygote process, as it does for new application processes, the UID and GIDs are set. Kernel and system daemons use these to grant access to resources and functions.

Relative shell permissions

So, does a shell started from an application have the same permissions as a shell started via adb? Lets see.

Starting with an adb shell we can see the parent process tree via a cut down ps output:

1

And using this to look into the GIDs that the shell user has:

2

We can compare this to a shell command from an installed application. Due to quirks with Runtime.exec() I found this simplest to do by issuing a slow shell command (sleep 100) from an installed app and inspecting from my already open adb shell. Below as expected, we see a totally different PPID tree

3

Note: u0_a89 is User 0 (UID 100000) started app (UID 10089)

And querying for GIDs we have:

4

Where 10089 is the UID of the application that issues the shell command.

From the above we can see that the GID permissions are not in fact identical, and that the users are also different!

One obvious example of this is that the adb shell has GID 3003 which is

#define AID_INET 3003 /* can create AF_INET and AF_INET6 sockets */

so by default it will effectively have the INTERNET permission.

Other Shell Permissions

To see what other permissions the shell user has check out the below from /data/system/packages.xml:

packages.xml

Further Research

It would be interesting to know what the os resources the shell user has access to. I imagine this can be found by a simple command on a rooted / emulated device.

Conclusion

In a word, yes. An open shells permissions are granted depending on its processes Owner and Group(s). Depending where the shell is initiated these can be different.

I found this an interesting poke around kernel permissions (a sentence I never thought I would say!) so thought I would share. If you see anything incorrect here please let me know.

If you find this stuff interesting you may like doridori/Android-Security-Reference.

Appendix: ro.*

A side note here. According to ADB (Android Debug Bridge): How it works? if the sys prop ro.secure = 1 (as it should be with all OEM devices) than adbd will run as shell, otherwise it will run as root i.e. like the emulator, and probably the now defunct dev devices.

This app will extend root to adbd. I presume by temp setting ro.secure and restarting adbd.