ACCESS CONTROL ISSUES 2 - INTENT FILTER VULNERABILITY (2)
- 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/c3f28/c3f2886851dac2b54795feadd45cf0e594145cf7" alt=""
- Clicking the tab for challenge 10:
data:image/s3,"s3://crabby-images/a175a/a175a8e6d4c0948ccfdfe76da133ec869e30b3f7" alt=""
- The applications asks the user to register at a website in order to get a PIN, valid to login and see the content of some API credentials related to a third party application:
data:image/s3,"s3://crabby-images/b93c9/b93c9d14c41356d68a08a811a2d9f60843e3520f" alt=""
- Using a false PIN, the access is denied:
data:image/s3,"s3://crabby-images/54173/54173b9cdf537ff90ebe34e81aa69ec304bd0030" alt=""
- The goal of this challenge would be to access the third party API credentials from outside the application, without using any PIN.
- Looking at the AndroidManifest.xml, inside the activity for this challenge it is defined the intent filter jakhar.aseem.diva.action.VIEW_CREDS2:
data:image/s3,"s3://crabby-images/d151a/d151a659b0c0138f2e9115a90df2f1c26dc1d414" alt=""
data:image/s3,"s3://crabby-images/c9c18/c9c186c8c6d85112335603cef6cbc7dc26d68203" alt=""
- We could try using the Activity Manager and starting the intent filter, but it does not work because it just prompts the user for registering:
data:image/s3,"s3://crabby-images/c7a4d/c7a4ded9c4e2c961da36acecc27f52c4409a711f" alt=""
data:image/s3,"s3://crabby-images/04ac7/04ac76eae40220b161301a06ac4794097923d2fa" alt=""
- However, using Drozer will be a lot more powerful. Setting up the Drozer server at Nexus 5:
data:image/s3,"s3://crabby-images/f4429/f4429cf051d3a16a34dde9bb1dea90a00c14aa59" alt=""
- Launching the Drozer client at Linux Santoku:
data:image/s3,"s3://crabby-images/36dd8/36dd8762b8bf5f1b2f25678ee526efc21b3f534e" alt=""
- Running the info option, the activity APICreds2Activity is detected:
data:image/s3,"s3://crabby-images/81d48/81d48995bf8c474196dd98bd31d0cc48966266be" alt=""
- Opening the Java source code of the activity APICreds2Activity:
data:image/s3,"s3://crabby-images/f756a/f756a774febb6d2cdccd6732451e02f4df5ac035" alt=""
data:image/s3,"s3://crabby-images/4841d/4841df628efc638e8d19a276c6ef156b46b4a9a8" alt=""
data:image/s3,"s3://crabby-images/583f0/583f04a0ca111d3cb106ee290eea8b1b2793a946" alt=""
- It is noticeable that a boolean is compared to the value "true", and then asked for registering at a website.
data:image/s3,"s3://crabby-images/b9dd2/b9dd21aed43f473f8940d563e860bd89ea967413" alt=""
- Opening the AccessControl2Activity.java for this challenge:
data:image/s3,"s3://crabby-images/8e46f/8e46fbeec1c45448192a7042044ae8bb1abac68c" alt=""
data:image/s3,"s3://crabby-images/359a4/359a410dd7c2c46b50c135ca5b8c99d67157566f" alt=""
data:image/s3,"s3://crabby-images/43aeb/43aeb3c9157e5c85037d404134be5ad85a1cae14" alt=""
- So, as mentioned, a boolean is defined to validate the PIN entered by the user.
- Going to the code of the application, a string called check_pin is defined:
data:image/s3,"s3://crabby-images/d04bb/d04bba8fa6bd350c6fea54fd3c967b32c59a88ad" alt=""
data:image/s3,"s3://crabby-images/d87ad/d87ad8adbe1e612bbf713868ce1666b707ae111d" alt=""
data:image/s3,"s3://crabby-images/59633/596335bdd43d633aad9bc8e5f6ee9d0eab676660" alt=""
- Now, from Drozer the value of check_pin is changed from "true" to "false", and the intent filter started with Activity Manager in order to bypass the access control protection:
data:image/s3,"s3://crabby-images/c34f4/c34f48cf1943eb19dbb7b086788a99265d67e4fa" alt=""
- The result is successful because the API Credentials are now available for the user without entering any valid or invalid PIN:
data:image/s3,"s3://crabby-images/ec62b/ec62b7cf78fd06a33cc86c75c35fb403680c82e1" alt=""