INTRODUCTION
- Layout for this exercise:
data:image/s3,"s3://crabby-images/eff64/eff64c8df9c52a6791f4391521c0a128af583a1a" alt=""
1 - What is DIVA?
- According with the developer Aseem Jakhar, DIVA (Damn Insecure and Vulnerable App) is an application intentionally designed to be insecure.
https://github.com/payatu/diva-android
- The goal of DIVA is to teach developers and security professionals flaws that are generally present in the Apps, due to poor or insecure coding practices.
- DIVA covers common vulnerabilities in Android apps, ranging from insecure logging , insecure storage, input validation, access control issues, and also a few vulnerabilities in native code, which makes it more interesting from the perspective of covering both Java and C vulnerabilities.
data:image/s3,"s3://crabby-images/091d2/091d25b029657b380eebe94bd96d3a1e46af1be1" alt=""
data:image/s3,"s3://crabby-images/48d0b/48d0bf8e975b0114ab004ae1a5256294c7957593" alt=""
2 - Installing DIVA from Santoku Linux to Android device
- Once downloaded and extracted the application to Santoku Linux, the file diva-beta.apk is available to be used and analyzed:
data:image/s3,"s3://crabby-images/8afac/8afac7c03a1a7839dac4c0894ad2b553aba794c7" alt=""
- Santoku connects to the mobile device:
data:image/s3,"s3://crabby-images/85677/85677c90ab352c85e4cb4cf150a93e3dc367d3d5" alt=""
- Installing DIVA on Nexus, using ADB (Android Debug Bridge):
data:image/s3,"s3://crabby-images/ce372/ce372aa3afbf443f825450692f74489e8e961684" alt=""
data:image/s3,"s3://crabby-images/4eb96/4eb961ab223e94e05fb6f00d45e085762c06f44a" alt=""
- Launching the application:
data:image/s3,"s3://crabby-images/13d7f/13d7f544e5f64c0d5dab8fc0d86730d5345b091c" alt=""
- DIVA includes 13 challenges:
data:image/s3,"s3://crabby-images/d08f8/d08f8d7fafa9187d1692792edf046c03131fce27" alt=""
data:image/s3,"s3://crabby-images/be767/be7673866ef1b36726bf0bbd492811c4cf161fc7" alt=""
3 - Decompiling, reversing and analyzing the application
- To analyze and operate with DIVA's source code it is essential to decompile the application, for instance with jadx:
data:image/s3,"s3://crabby-images/3080a/3080a26e489bd7e1dc2852b83c1945398a92da6a" alt=""
- Executing jadx over diva-beta.apk. Although displaying some errors, the final result is successful:
data:image/s3,"s3://crabby-images/8623f/8623fd57fa48a305079fb69b867c354c77364e5f" alt=""
- As a result of executing jadx a diva-beta folder is created:
data:image/s3,"s3://crabby-images/77828/778282d0aebbf8928ad3cb716b6b3177884caec6" alt=""
- The folder diva-beta contains all the components of the application:
- The manifest file tells that the package of the application is jakhar.assem.diva:
data:image/s3,"s3://crabby-images/eeaca/eeacacd07e9eef1c3e4cf1ec7e13f4e8b0897b94" alt=""
data:image/s3,"s3://crabby-images/bd2b7/bd2b7fac58a5cd5f098f6b695aee5f8bab74b370" alt=""
- Going down the path of the folders indicated by the package:
data:image/s3,"s3://crabby-images/5730c/5730cc8691ceabffe53e21de6aa5b2dc687a0504" alt=""
- Once reached to the inner folder diva, there is the Java source code of all the activities used by the application, which will be very useful to find a solution to each of the DIVA's challenges:
data:image/s3,"s3://crabby-images/e5010/e5010944341ec8df47b8bfa6f85099ea79388c8d" alt=""