Skip to content

Commit 010dc6e

Browse files
authored
Create FlutterSSL.js
1 parent 1c2c453 commit 010dc6e

File tree

1 file changed

+70
-0
lines changed

1 file changed

+70
-0
lines changed

FlutterSSL.js

+70
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,70 @@
1+
console.warn(Process.arch, "environment Detected")
2+
let do_dlopen = null;
3+
let call_ctor = null;
4+
let LibraryName = "libflutter.so";
5+
let moduleName = Process.arch == "arm" ? "linker" : "linker64";
6+
let reg = Process.arch == "arm" ? "r0" : "x0";
7+
let Arch = Process.arch;
8+
Process.findModuleByName(moduleName)
9+
.enumerateSymbols()
10+
.forEach(function(sym) {
11+
if (sym.name.indexOf('do_dlopen') !== -1) {
12+
do_dlopen = sym.address;
13+
} else if (sym.name.indexOf('call_constructor') !== -1) {
14+
call_ctor = sym.address;
15+
}
16+
})
17+
Interceptor.attach(do_dlopen, function() {
18+
let Lib = this.context[reg].readCString();
19+
if (Lib && Lib.indexOf(LibraryName) !== -1) {
20+
Interceptor.attach(call_ctor, function() {
21+
Hook(LibraryName);
22+
})
23+
}
24+
})
25+
26+
function Hook(Name) {
27+
let Hooked = 0;
28+
let Mod = Process.findModuleByName(Name);
29+
let Arm64Pattern = [
30+
"F? 0F 1C F8 F? 5? 01 A9 F? 5? 02 A9 F? ?? 03 A9 ?? ?? ?? ?? 68 1A 40 F9",
31+
"F? 43 01 D1 FE 67 01 A9 F8 5F 02 A9 F6 57 03 A9 F4 4F 04 A9 13 00 40 F9 F4 03 00 AA 68 1A 40 F9",
32+
"FF 43 01 D1 FE 67 01 A9 ?? ?? 06 94 ?? 7? 06 94 68 1A 40 F9 15 15 41 F9 B5 00 00 B4 B6 4A 40 F9"];
33+
//"FF C3 01 D1 F? 7B 01 A9 FC 6F 02 A9 FA 67 03 A9 F8 5F 04 A9 F6 57 05 ?9"]
34+
let ArmPattern = ["2D E9 F? 4? D0 F8 00 80 81 46 D8 F8 18 00 D0 F8 ??"];
35+
let ranges = Mod.enumerateRanges('r-x');
36+
ranges.forEach(range => {
37+
if (Arch == "arm64") {
38+
Arm64Pattern.forEach(pattern => {
39+
Memory.scan(range.base, range.size, pattern, {
40+
onMatch: function(address, size) {
41+
if (Hooked == 0) {
42+
Hooked = 1;
43+
hook_ssl_verify_peer_cert(address, address.sub(Mod.base), Name);
44+
}
45+
}
46+
});
47+
});
48+
} else if (Arch == "arm") {
49+
ArmPattern.forEach(pattern => {
50+
Memory.scan(range.base, range.size, pattern, {
51+
onMatch: function(address, size) {
52+
if (Hooked == 0) {
53+
Hooked = 1;
54+
hook_ssl_verify_peer_cert(address, address.sub(Mod.base), Name);
55+
}
56+
}
57+
});
58+
});
59+
}
60+
});
61+
}
62+
63+
function hook_ssl_verify_peer_cert(address, offset, Name) {
64+
console.log("ssl_verify_peer_cert Patched at : ", Name, address, offset)
65+
try {
66+
Interceptor.replace(address, new NativeCallback((pathPtr, flags) => {
67+
return 0;
68+
}, 'int', ['pointer', 'int']));
69+
} catch (e) {}
70+
}

0 commit comments

Comments
 (0)