ACCESS CONTROL ISSUES 3 - CONTENT PROVIDER VULNERABILITY
- Layout for this exercise:
data:image/s3,"s3://crabby-images/25dbf/25dbf5e40a197f43620a26ad2792e3b9c5621175" alt=""
- Connecting from Santoku to Nexus 5 with ADB:
data:image/s3,"s3://crabby-images/af15d/af15dac2b37d586fc8efc9120d93b15c822f51a1" alt=""
- Launching the application:
data:image/s3,"s3://crabby-images/8a009/8a009d416ec01933db4fddca724949a1c23aa8f4" alt=""
- Let's see how the challenge 11 works. Clicking the tab:
data:image/s3,"s3://crabby-images/64b25/64b253d531eff3b0708d0b363fbfcd9d47284de1" alt=""
- The user is prompted to create a PIN to protect private information stored on the application:
data:image/s3,"s3://crabby-images/c631b/c631b446fefd457ec6190f4ac521b9375c60629a" alt=""
- Using the newly created PIN, access to some private notes is available:
data:image/s3,"s3://crabby-images/da38e/da38e0051778286f90a30679d76dced651dee364" alt=""
data:image/s3,"s3://crabby-images/41303/413039400e730e321c70323a20ee9fc94bf6c343" alt=""
- The goal of this challenge is to bypass the access control provided by the PIN, being able to read the private notes from outside the application.
- A content provider manages access to a central repository of data. A provider is part of an Android application, which often provides its own UI for working with the data.
- However, a content provider is primarily intended to be used by other applications, which accesses the provider using a provider client object. In other words, content providers are the standard interface that connects data in one process with code running in another process.
- Checking the source code for the activity AccessControl3Activity.java:
data:image/s3,"s3://crabby-images/979d8/979d8eb378f3823c51443e164dea119375329970" alt=""
data:image/s3,"s3://crabby-images/f362c/f362ce3e604244ece92fae39fc181707a6c04ce1" alt=""
data:image/s3,"s3://crabby-images/2cfd7/2cfd745231f91b3f2af382575348a455ed92d55b" alt=""
- Also, the source code of AccessControl3NotesActivity.java:
data:image/s3,"s3://crabby-images/7c348/7c348bde05df098cb6bb1451952fa708add42e5f" alt=""
data:image/s3,"s3://crabby-images/e1441/e144166be65feaa28e3fcf46b9c62227648ee2d6" alt=""
data:image/s3,"s3://crabby-images/e4757/e47575350509695ac2f8bfb241ac1bd647ed239b" alt=""
- In the same way, checking the AndroidManifest.xml, the content provider jakhar.aseem.diva.provider.notesprovider is detected.
- One of its parameters is androd:exported="true", what makes it vulnerable to be accessed without permission. In order to make it secure, it should be put to either "false" or added a permission to access it:
data:image/s3,"s3://crabby-images/763cc/763cc428fdc6fd9db9c93608e77ca74070e82ddb" alt=""
data:image/s3,"s3://crabby-images/c7a73/c7a73d27787a931c379a9684358688b27bc43ba5" alt=""
data:image/s3,"s3://crabby-images/2b283/2b283c7ed5a2c9120b87fdcee74d06973ee8fc34" alt=""
data:image/s3,"s3://crabby-images/b514b/b514b40f92002cf9b97dd0f27679e3bca27ea83c" alt=""
- Using the finduri option by Drozer, the content provider is found:
data:image/s3,"s3://crabby-images/61e24/61e24b230ee34bbd04959e1e244d04d8847fbc6e" alt=""
- Running the query option by Drozer, the notes are available from Santoku, outside of the application:
data:image/s3,"s3://crabby-images/9ef67/9ef67675dae6d26ea69423c82e3ea2a66e9ef610" alt=""
- Also, adb shell content query can be used to access the notes:
data:image/s3,"s3://crabby-images/b3002/b3002d790a9a4766464bc62f33368b6d255d648c" alt=""