ACCESS CONTROL ISSUES 1 - INTENT FILTER VULNERABILITY (1)
- 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 9:
data:image/s3,"s3://crabby-images/580ab/580abf9c98907a3fd3ac610b82cc105b0678282d" alt=""
- The application allows to see the API credentials:
data:image/s3,"s3://crabby-images/17669/17669d31ba8ee9ebb2ef59301a8ef3f19d73d066" alt=""
data:image/s3,"s3://crabby-images/52ff4/52ff4fab19f4f7542a5eb44ab3e96fe2b8f2800b" alt=""
- However, the goal of this challenge is to access the API credentials from outside the application, taking advantage of the incorrect validation system used in this activity.
- Let's have a look at the Java source code of the activity for this challenge, AccessControl1Activity:
data:image/s3,"s3://crabby-images/f44bc/f44bc2bdad4ead1fab9ac6c65825773504317c7d" alt=""
- The jakhar.aseem.diva.action.VIEW_CREDS is the intent filter responsible for allowing the credentials to be displayed by the application:
data:image/s3,"s3://crabby-images/dfdfb/dfdfb83a50825a1c0ebf53143b2d1f7002def346" alt=""
data:image/s3,"s3://crabby-images/47e4a/47e4aec046c4bf9d99fdd5a89b87dd0300769ae8" alt=""
- Opening the Java source code for APICredsActivity.java:
- Also, the AndroidManifest.xml indicates the presence of the mentioned intent filter:
- Now, using the Activity Manager tool we can start the intent filter jakhar.aseem.diva.action.VIEW_CREDS from Santoku Linux, without using the DIVA application interface at the Nexus 5 device:
data:image/s3,"s3://crabby-images/9b83e/9b83ec471d18188b9a7f1b8f95cd0270b475a80e" alt=""
-The result is the application starting by itself and showing the API credentials:
data:image/s3,"s3://crabby-images/6a9db/6a9dbf27c7b3a7bb0086aaf80ed6096e114f16db" alt=""
- By the way, an apart for the previous exercise, Activity Manager can also be used for other tasks. For instance, to open a web browser remotely at the mobile device:
data:image/s3,"s3://crabby-images/f1d81/f1d81f31718a08d080b4c33db34d4baea3f0fddb" alt=""
data:image/s3,"s3://crabby-images/a10bd/a10bdfd000aa1ce7a71a50ba5eb9fe7d4c3ffa27" alt=""