2017-04-06 06:12:29 +08:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <pthread.h>
|
2017-04-07 07:50:02 +08:00
|
|
|
#include <signal.h>
|
2017-04-09 07:25:10 +08:00
|
|
|
#include <string.h>
|
|
|
|
#include <sys/wait.h>
|
2017-04-07 07:50:02 +08:00
|
|
|
#include <sys/types.h>
|
2016-12-31 02:44:24 +08:00
|
|
|
|
2017-04-06 06:12:29 +08:00
|
|
|
#include "magisk.h"
|
|
|
|
#include "utils.h"
|
|
|
|
#include "magiskhide.h"
|
2017-04-09 07:25:10 +08:00
|
|
|
#include "daemon.h"
|
2017-04-20 22:45:56 +08:00
|
|
|
#include "resetprop.h"
|
2018-10-28 04:25:31 -04:00
|
|
|
#include "flags.h"
|
2016-12-31 02:44:24 +08:00
|
|
|
|
2018-11-01 13:23:12 -04:00
|
|
|
int hide_enabled = 0;
|
2017-04-06 06:12:29 +08:00
|
|
|
static pthread_t proc_monitor_thread;
|
2018-11-01 13:23:12 -04:00
|
|
|
pthread_mutex_t list_lock;
|
2017-01-01 18:54:13 +08:00
|
|
|
|
2018-11-01 14:08:33 -04:00
|
|
|
[[noreturn]] static void usage(char *arg0) {
|
2017-04-09 07:25:10 +08:00
|
|
|
fprintf(stderr,
|
2017-07-08 23:51:58 +08:00
|
|
|
"MagiskHide v" xstr(MAGISK_VERSION) "(" xstr(MAGISK_VER_CODE) ") (by topjohnwu) - Hide Magisk!\n\n"
|
2017-08-15 01:25:54 +08:00
|
|
|
"Usage: %s [--options [arguments...] ]\n\n"
|
2017-04-09 07:25:10 +08:00
|
|
|
"Options:\n"
|
2017-08-15 01:25:54 +08:00
|
|
|
" --enable Start magiskhide\n"
|
|
|
|
" --disable Stop magiskhide\n"
|
|
|
|
" --add PROCESS Add PROCESS to the hide list\n"
|
|
|
|
" --rm PROCESS Remove PROCESS from the hide list\n"
|
|
|
|
" --ls Print out the current hide list\n"
|
2017-04-09 07:25:10 +08:00
|
|
|
, arg0);
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
|
2018-11-01 14:08:33 -04:00
|
|
|
int launch_magiskhide() {
|
|
|
|
if (hide_enabled)
|
|
|
|
return HIDE_IS_ENABLED;
|
2016-12-31 02:44:24 +08:00
|
|
|
|
2018-10-12 00:50:47 -04:00
|
|
|
if (!log_daemon_started) {
|
2018-03-18 12:02:56 +08:00
|
|
|
setprop(MAGISKHIDE_PROP, "0");
|
|
|
|
// Remove without actually removing persist props
|
2018-11-04 03:38:06 -05:00
|
|
|
deleteprop(MAGISKHIDE_PROP);
|
2018-11-01 14:08:33 -04:00
|
|
|
return LOGCAT_DISABLED;
|
2018-02-12 02:48:15 +08:00
|
|
|
}
|
|
|
|
|
2018-11-01 13:23:12 -04:00
|
|
|
hide_enabled = 1;
|
2017-07-02 23:04:57 +08:00
|
|
|
LOGI("* Starting MagiskHide\n");
|
2017-04-24 21:43:30 +08:00
|
|
|
|
2018-11-04 03:38:06 -05:00
|
|
|
deleteprop(MAGISKHIDE_PROP, true);
|
2017-04-20 22:45:56 +08:00
|
|
|
|
2017-04-17 16:36:49 +08:00
|
|
|
hide_sensitive_props();
|
|
|
|
|
2017-05-12 15:28:15 +08:00
|
|
|
// Initialize the mutex lock
|
2018-11-01 13:23:12 -04:00
|
|
|
pthread_mutex_init(&list_lock, nullptr);
|
2017-05-12 15:28:15 +08:00
|
|
|
|
2017-04-06 06:12:29 +08:00
|
|
|
// Initialize the hide list
|
2018-11-07 02:10:38 -05:00
|
|
|
if (!init_list())
|
2017-04-09 07:25:10 +08:00
|
|
|
goto error;
|
2017-04-20 22:45:56 +08:00
|
|
|
|
|
|
|
// Add SafetyNet by default
|
2018-11-07 02:10:38 -05:00
|
|
|
add_list("com.google.android.gms.unstable");
|
2016-12-31 02:44:24 +08:00
|
|
|
|
2017-04-22 00:54:08 +08:00
|
|
|
// Get thread reference
|
|
|
|
proc_monitor_thread = pthread_self();
|
|
|
|
// Start monitoring
|
|
|
|
proc_monitor();
|
2018-11-01 14:08:33 -04:00
|
|
|
return DAEMON_SUCCESS;
|
2017-04-22 00:54:08 +08:00
|
|
|
|
2017-04-09 07:25:10 +08:00
|
|
|
error:
|
2018-11-01 13:23:12 -04:00
|
|
|
hide_enabled = 0;
|
2018-11-01 14:08:33 -04:00
|
|
|
return DAEMON_ERROR;
|
2017-04-06 06:12:29 +08:00
|
|
|
}
|
2016-12-31 02:44:24 +08:00
|
|
|
|
2018-11-01 14:08:33 -04:00
|
|
|
int stop_magiskhide() {
|
2017-04-09 07:25:10 +08:00
|
|
|
LOGI("* Stopping MagiskHide\n");
|
|
|
|
|
2018-11-01 13:23:12 -04:00
|
|
|
hide_enabled = 0;
|
2017-05-26 22:05:04 +08:00
|
|
|
setprop(MAGISKHIDE_PROP, "0");
|
2017-07-18 12:26:23 +08:00
|
|
|
// Remove without actually removing persist props
|
2018-11-04 03:38:06 -05:00
|
|
|
deleteprop(MAGISKHIDE_PROP);
|
2017-11-09 03:05:01 +08:00
|
|
|
pthread_kill(proc_monitor_thread, TERM_THREAD);
|
2017-04-22 00:54:08 +08:00
|
|
|
|
2018-11-01 14:08:33 -04:00
|
|
|
return DAEMON_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
void magiskhide_handler(int client) {
|
|
|
|
int req = read_int(client);
|
|
|
|
int res = DAEMON_ERROR;
|
|
|
|
|
|
|
|
switch (req) {
|
|
|
|
case STOP_MAGISKHIDE:
|
|
|
|
case ADD_HIDELIST:
|
|
|
|
case RM_HIDELIST:
|
|
|
|
case LS_HIDELIST:
|
|
|
|
if (!hide_enabled) {
|
|
|
|
write_int(client, HIDE_NOT_ENABLED);
|
|
|
|
close(client);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (req) {
|
|
|
|
case LAUNCH_MAGISKHIDE:
|
|
|
|
res = launch_magiskhide();
|
|
|
|
break;
|
|
|
|
case STOP_MAGISKHIDE:
|
|
|
|
res = stop_magiskhide();
|
|
|
|
break;
|
|
|
|
case ADD_HIDELIST:
|
|
|
|
res = add_list(client);
|
|
|
|
break;
|
|
|
|
case RM_HIDELIST:
|
|
|
|
res = rm_list(client);
|
|
|
|
break;
|
|
|
|
case LS_HIDELIST:
|
|
|
|
ls_list(client);
|
|
|
|
client = -1;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
write_int(client, res);
|
2017-04-15 03:23:09 +08:00
|
|
|
close(client);
|
2017-04-06 06:12:29 +08:00
|
|
|
}
|
2016-12-31 02:44:24 +08:00
|
|
|
|
2017-04-06 06:12:29 +08:00
|
|
|
int magiskhide_main(int argc, char *argv[]) {
|
2017-04-09 07:25:10 +08:00
|
|
|
if (argc < 2) {
|
|
|
|
usage(argv[0]);
|
|
|
|
}
|
2018-11-01 14:08:33 -04:00
|
|
|
int req;
|
2017-04-09 07:25:10 +08:00
|
|
|
if (strcmp(argv[1], "--enable") == 0) {
|
|
|
|
req = LAUNCH_MAGISKHIDE;
|
|
|
|
} else if (strcmp(argv[1], "--disable") == 0) {
|
|
|
|
req = STOP_MAGISKHIDE;
|
|
|
|
} else if (strcmp(argv[1], "--add") == 0 && argc > 2) {
|
|
|
|
req = ADD_HIDELIST;
|
|
|
|
} else if (strcmp(argv[1], "--rm") == 0 && argc > 2) {
|
|
|
|
req = RM_HIDELIST;
|
|
|
|
} else if (strcmp(argv[1], "--ls") == 0) {
|
2017-09-06 02:25:40 +08:00
|
|
|
req = LS_HIDELIST;
|
2017-10-10 19:49:15 +08:00
|
|
|
} else {
|
|
|
|
usage(argv[0]);
|
2017-04-09 07:25:10 +08:00
|
|
|
}
|
2018-11-01 14:08:33 -04:00
|
|
|
|
2018-06-17 01:28:29 +08:00
|
|
|
int fd = connect_daemon();
|
2018-11-01 14:08:33 -04:00
|
|
|
write_int(fd, MAGISKHIDE);
|
2017-04-09 07:25:10 +08:00
|
|
|
write_int(fd, req);
|
|
|
|
if (req == ADD_HIDELIST || req == RM_HIDELIST) {
|
|
|
|
write_string(fd, argv[2]);
|
|
|
|
}
|
2018-02-11 17:23:36 +08:00
|
|
|
int code = read_int(fd);
|
2017-04-22 01:40:07 +08:00
|
|
|
switch (code) {
|
2017-05-05 16:13:26 +08:00
|
|
|
case DAEMON_SUCCESS:
|
|
|
|
break;
|
|
|
|
case ROOT_REQUIRED:
|
|
|
|
fprintf(stderr, "Root is required for this operation\n");
|
2017-09-06 02:25:40 +08:00
|
|
|
return code;
|
2018-04-08 02:12:40 +08:00
|
|
|
case LOGCAT_DISABLED:
|
|
|
|
fprintf(stderr, "Logcat is disabled, cannot start MagiskHide\n");
|
2018-11-01 14:08:33 -04:00
|
|
|
return code;
|
2017-04-22 01:40:07 +08:00
|
|
|
case HIDE_NOT_ENABLED:
|
2018-04-08 02:12:40 +08:00
|
|
|
fprintf(stderr, "MagiskHide is not enabled yet\n");
|
2017-09-06 02:25:40 +08:00
|
|
|
return code;
|
2017-04-22 01:40:07 +08:00
|
|
|
case HIDE_IS_ENABLED:
|
2018-04-08 02:12:40 +08:00
|
|
|
fprintf(stderr, "MagiskHide is already enabled\n");
|
2017-09-06 02:25:40 +08:00
|
|
|
return code;
|
2017-04-22 01:40:07 +08:00
|
|
|
case HIDE_ITEM_EXIST:
|
|
|
|
fprintf(stderr, "Process [%s] already exists in hide list\n", argv[2]);
|
2017-09-06 02:25:40 +08:00
|
|
|
return code;
|
2017-04-22 01:40:07 +08:00
|
|
|
case HIDE_ITEM_NOT_EXIST:
|
|
|
|
fprintf(stderr, "Process [%s] does not exist in hide list\n", argv[2]);
|
2017-09-06 02:25:40 +08:00
|
|
|
return code;
|
2018-02-11 17:23:36 +08:00
|
|
|
case DAEMON_ERROR:
|
|
|
|
default:
|
|
|
|
fprintf(stderr, "Error occured in daemon...\n");
|
|
|
|
return code;
|
2017-09-06 02:25:40 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
if (req == LS_HIDELIST) {
|
|
|
|
int argc = read_int(fd);
|
|
|
|
for (int i = 0; i < argc; ++i) {
|
|
|
|
char *s = read_string(fd);
|
|
|
|
printf("%s\n", s);
|
|
|
|
free(s);
|
|
|
|
}
|
2017-04-09 07:25:10 +08:00
|
|
|
}
|
2017-09-06 02:25:40 +08:00
|
|
|
close(fd);
|
|
|
|
|
|
|
|
return 0;
|
2017-04-06 06:12:29 +08:00
|
|
|
}
|