mirror of
https://github.com/topjohnwu/Magisk.git
synced 2025-01-12 06:33:37 +00:00
Make private applets hidden
This commit is contained in:
parent
646260ad6d
commit
38325e708e
@ -8,45 +8,68 @@
|
|||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
using main_fun = int (*)(int, char *[]);
|
struct Applet {
|
||||||
|
string_view name;
|
||||||
|
int (*fn)(int, char *[]);
|
||||||
|
};
|
||||||
|
|
||||||
constexpr const char *applets[] = { "su", "resetprop", "zygisk", nullptr };
|
constexpr Applet applets[] = {
|
||||||
static main_fun applet_mains[] = { su_client_main, resetprop_main, zygisk_main, nullptr };
|
{ "su", su_client_main },
|
||||||
|
{ "resetprop", resetprop_main },
|
||||||
|
};
|
||||||
|
|
||||||
static int call_applet(int argc, char *argv[]) {
|
constexpr Applet private_applets[] = {
|
||||||
// Applets
|
{ "zygisk", zygisk_main },
|
||||||
string_view base = basename(argv[0]);
|
};
|
||||||
for (int i = 0; applets[i]; ++i) {
|
|
||||||
if (base == applets[i]) {
|
|
||||||
return (*applet_mains[i])(argc, argv);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
fprintf(stderr, "%s: applet not found\n", base.data());
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(int argc, char *argv[]) {
|
int main(int argc, char *argv[]) {
|
||||||
|
if (argc < 1)
|
||||||
|
return 1;
|
||||||
|
|
||||||
enable_selinux();
|
enable_selinux();
|
||||||
cmdline_logging();
|
cmdline_logging();
|
||||||
init_argv0(argc, argv);
|
init_argv0(argc, argv);
|
||||||
|
|
||||||
string_view base = basename(argv[0]);
|
string_view argv0 = basename(argv[0]);
|
||||||
|
|
||||||
// app_process is actually not an applet
|
// app_process is actually not an applet
|
||||||
if (str_starts(base, "app_process")) {
|
if (argv0.starts_with("app_process")) {
|
||||||
return app_process_main(argc, argv);
|
return app_process_main(argc, argv);
|
||||||
}
|
}
|
||||||
|
|
||||||
umask(0);
|
umask(0);
|
||||||
if (base == "magisk" || base == "magisk32" || base == "magisk64") {
|
|
||||||
|
if (argv[0][0] == '\0') {
|
||||||
|
// When argv[0] is an empty string, we're calling private applets
|
||||||
|
if (argc < 2)
|
||||||
|
return 1;
|
||||||
|
--argc;
|
||||||
|
++argv;
|
||||||
|
for (const auto &app : private_applets) {
|
||||||
|
if (argv[0] == app.name) {
|
||||||
|
return app.fn(argc, argv);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
fprintf(stderr, "%s: applet not found\n", argv[0]);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (argv0 == "magisk" || argv0 == "magisk32" || argv0 == "magisk64") {
|
||||||
if (argc > 1 && argv[1][0] != '-') {
|
if (argc > 1 && argv[1][0] != '-') {
|
||||||
// Calling applet via magisk [applet] args
|
// Calling applet with "magisk [applet] args..."
|
||||||
--argc;
|
--argc;
|
||||||
++argv;
|
++argv;
|
||||||
|
argv0 = argv[0];
|
||||||
} else {
|
} else {
|
||||||
return magisk_main(argc, argv);
|
return magisk_main(argc, argv);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return call_applet(argc, argv);
|
for (const auto &app : applets) {
|
||||||
|
if (argv0 == app.name) {
|
||||||
|
return app.fn(argc, argv);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
fprintf(stderr, "%s: applet not found\n", argv0.data());
|
||||||
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -177,7 +177,7 @@ static void connect_companion(int client, bool is_64_bit) {
|
|||||||
fcntl(fds[1], F_SETFD, 0);
|
fcntl(fds[1], F_SETFD, 0);
|
||||||
char buf[16];
|
char buf[16];
|
||||||
snprintf(buf, sizeof(buf), "%d", fds[1]);
|
snprintf(buf, sizeof(buf), "%d", fds[1]);
|
||||||
execl(exe.data(), "zygisk", "companion", buf, (char *) nullptr);
|
execl(exe.data(), "", "zygisk", "companion", buf, (char *) nullptr);
|
||||||
exit(-1);
|
exit(-1);
|
||||||
}
|
}
|
||||||
close(fds[1]);
|
close(fds[1]);
|
||||||
|
@ -46,17 +46,16 @@ int app_process_main(int argc, char *argv[]) {
|
|||||||
fcntl(fds[1], F_SETFD, 0);
|
fcntl(fds[1], F_SETFD, 0);
|
||||||
snprintf(buf, sizeof(buf), "%d", fds[1]);
|
snprintf(buf, sizeof(buf), "%d", fds[1]);
|
||||||
#if defined(__LP64__)
|
#if defined(__LP64__)
|
||||||
execlp("magisk", "zygisk", "passthrough", buf, "1", (char *) nullptr);
|
execlp("magisk", "", "zygisk", "passthrough", buf, "1", (char *) nullptr);
|
||||||
#else
|
#else
|
||||||
execlp("magisk", "zygisk", "passthrough", buf, "0", (char *) nullptr);
|
execlp("magisk", "", "zygisk", "passthrough", buf, "0", (char *) nullptr);
|
||||||
#endif
|
#endif
|
||||||
exit(-1);
|
exit(-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
close(fds[1]);
|
close(fds[1]);
|
||||||
if (read_int(fds[0]) != 0) {
|
if (read_int(fds[0]) != 0) {
|
||||||
fprintf(stderr, "Failed to connect magisk daemon, "
|
fprintf(stderr, "Failed to connect magiskd, try umount %s or reboot.\n", argv[0]);
|
||||||
"try umount %s or reboot.\n", argv[0]);
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
int app_proc_fd = recv_fd(fds[0]);
|
int app_proc_fd = recv_fd(fds[0]);
|
||||||
@ -131,8 +130,8 @@ static void zygiskd(int socket) {
|
|||||||
struct stat s{};
|
struct stat s{};
|
||||||
if (fstat(fd, &s) == 0 && S_ISREG(s.st_mode)) {
|
if (fstat(fd, &s) == 0 && S_ISREG(s.st_mode)) {
|
||||||
android_dlextinfo info {
|
android_dlextinfo info {
|
||||||
.flags = ANDROID_DLEXT_USE_LIBRARY_FD,
|
.flags = ANDROID_DLEXT_USE_LIBRARY_FD,
|
||||||
.library_fd = fd,
|
.library_fd = fd,
|
||||||
};
|
};
|
||||||
if (void *h = android_dlopen_ext("/jit-cache", RTLD_LAZY, &info)) {
|
if (void *h = android_dlopen_ext("/jit-cache", RTLD_LAZY, &info)) {
|
||||||
*(void **) &entry = dlsym(h, "zygisk_companion_entry");
|
*(void **) &entry = dlsym(h, "zygisk_companion_entry");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user