#pragma once #include #include #include #include #include #include #include #include #include #define SIGTERMTHRD SIGUSR1 #define ISOLATED_MAGIC "isolated" // CLI entries int launch_magiskhide(bool late_props); int stop_magiskhide(); int add_list(int client); int rm_list(int client); void ls_list(int client); #if !ENABLE_INJECT // Process monitoring [[noreturn]] void proc_monitor(); [[noreturn]] void test_proc_monitor(); #else // Response whether target process should be hidden int check_uid_map(int client); #endif // Utility functions void crawl_procfs(const std::function &fn); void crawl_procfs(DIR *dir, const std::function &fn); bool hide_enabled(); void update_uid_map(); // Hide policies void hide_daemon(int pid); void hide_unmount(int pid = -1); void hide_sensitive_props(); void hide_late_sensitive_props(); extern pthread_mutex_t hide_state_lock; extern std::map> uid_proc_map; enum { LAUNCH_MAGISKHIDE, STOP_MAGISKHIDE, ADD_HIDELIST, RM_HIDELIST, LS_HIDELIST, HIDE_STATUS, REMOTE_CHECK_HIDE, REMOTE_DO_HIDE }; enum { HIDE_IS_ENABLED = DAEMON_LAST, HIDE_NOT_ENABLED, HIDE_ITEM_EXIST, HIDE_ITEM_NOT_EXIST, HIDE_NO_NS, HIDE_INVALID_PKG };