Primer paso de la investigacion. Se aportan el .apk, las carpetas con el apk extraido y el apk descompilado. El archivo API_DOCUMENTATION.md es un archivo donde se anotaran los descubrimientos del funcionamiento de la API, y los .py son scripts para probar la funcionalidad de la API con los métodos que vayamos encontrando. Finalmente, los archivos .js son scripts de Frida para extraer informacion de la APP durante la ejecucion.

This commit is contained in:
2025-12-04 13:59:22 +01:00
parent 8b8ff223fb
commit f2fd1c3bf5
1055 changed files with 1202 additions and 0 deletions

View File

@@ -0,0 +1,70 @@
/**
* Inspect RequestBody to see what methods we can use
*/
console.log("\n[*] Inspecting RequestBody\n");
Java.perform(function() {
try {
var AuthHeaderInterceptor = Java.use("com.adif.elcanomovil.serviceNetworking.interceptors.AuthHeaderInterceptor");
console.log("[+] Found AuthHeaderInterceptor");
AuthHeaderInterceptor.intercept.implementation = function(chain) {
try {
// Cast chain
var ChainClass = Java.use("j3.g");
var chainObj = Java.cast(chain, ChainClass);
// Get request
var requestField = chainObj.getClass().getDeclaredField("e");
requestField.setAccessible(true);
var request = requestField.get(chainObj);
if (request) {
// Get request body from field "d"
var bodyField = request.getClass().getDeclaredField("d");
bodyField.setAccessible(true);
var reqBody = bodyField.get(request);
if (reqBody) {
console.log("\n" + "=".repeat(80));
console.log("[REQUEST BODY CLASS] " + reqBody.$className);
// List ALL methods
console.log("\n[ALL METHODS]:");
var methods = reqBody.getClass().getMethods();
for (var i = 0; i < methods.length; i++) {
var method = methods[i];
var paramTypes = method.getParameterTypes();
var paramStr = "";
for (var j = 0; j < paramTypes.length; j++) {
if (j > 0) paramStr += ", ";
paramStr += paramTypes[j].getName();
}
console.log(" " + method.getName() + "(" + paramStr + ") -> " + method.getReturnType().getName());
}
console.log("=".repeat(80) + "\n");
// Only print once
AuthHeaderInterceptor.intercept.implementation = this.intercept;
}
}
} catch (e) {
console.log("[ERROR] " + e);
console.log("[STACK] " + e.stack);
}
// Call original
return this.intercept(chain);
};
console.log("[*] Hook installed!\n");
} catch (e) {
console.log("[-] Failed: " + e);
}
});