#pragma once #include #include #include #include #include #include #include "../core-rs.hpp" #define AID_ROOT 0 #define AID_SHELL 2000 #define AID_USER_OFFSET 100000 #define to_app_id(uid) (uid % AID_USER_OFFSET) #define to_user_id(uid) (uid / AID_USER_OFFSET) // Return codes for daemon enum class RespondCode : int { ERROR = -1, OK = 0, ROOT_REQUIRED, ACCESS_DENIED, END }; struct ModuleInfo; // Daemon int connect_daemon(int req, bool create = false); const char *get_magisk_tmp(); void unlock_blocks(); bool setup_magisk_env(); bool check_key_combo(); // Zygisk daemon rust::Str get_zygisk_lib_name(); void set_zygisk_prop(); void restore_zygisk_prop(); // Sockets struct sock_cred : public ucred { std::string context; }; template requires(std::is_trivially_copyable_v) T read_any(int fd) { T val; if (xxread(fd, &val, sizeof(val)) != sizeof(val)) return -1; return val; } template requires(std::is_trivially_copyable_v) void write_any(int fd, T val) { if (fd < 0) return; xwrite(fd, &val, sizeof(val)); } bool get_client_cred(int fd, sock_cred *cred); static inline int read_int(int fd) { return read_any(fd); } static inline void write_int(int fd, int val) { write_any(fd, val); } std::string read_string(int fd); bool read_string(int fd, std::string &str); void write_string(int fd, std::string_view str); template requires(std::is_trivially_copyable_v) void write_vector(int fd, const std::vector &vec) { write_int(fd, vec.size()); xwrite(fd, vec.data(), vec.size() * sizeof(T)); } template requires(std::is_trivially_copyable_v) bool read_vector(int fd, std::vector &vec) { int size = read_int(fd); vec.resize(size); return xread(fd, vec.data(), size * sizeof(T)) == size * sizeof(T); } // Poll control using poll_callback = void(*)(pollfd*); void register_poll(const pollfd *pfd, poll_callback callback); void unregister_poll(int fd, bool auto_close); void clear_poll(); // Thread pool void init_thread_pool(); void exec_task(std::function &&task); // Daemon handlers void denylist_handler(int client, const sock_cred *cred); // Scripting void install_apk(rust::Utf8CStr apk); void uninstall_pkg(rust::Utf8CStr pkg); void exec_common_scripts(rust::Utf8CStr stage); void exec_module_scripts(rust::Utf8CStr stage, const rust::Vec &module_list); void exec_script(const char *script); void clear_pkg(const char *pkg, int user_id); [[noreturn]] void install_module(const char *file); // Denylist extern std::atomic denylist_enforced; int denylist_cli(int argc, char **argv); void initialize_denylist(); void scan_deny_apps(); bool is_deny_target(int uid, std::string_view process); void revert_unmount(int pid = -1) noexcept; void update_deny_flags(int uid, rust::Str process, uint32_t &flags); // MagiskSU void exec_root_shell(int client, int pid, SuRequest &req, MntNsMode mode); void app_log(const SuAppRequest &info, SuPolicy policy, bool notify); void app_notify(const SuAppRequest &info, SuPolicy policy); int app_request(const SuAppRequest &info); // Rust bindings static inline rust::Utf8CStr get_magisk_tmp_rs() { return get_magisk_tmp(); } static inline rust::String resolve_preinit_dir_rs(rust::Utf8CStr base_dir) { return resolve_preinit_dir(base_dir.c_str()); } static inline void exec_script_rs(rust::Utf8CStr script) { exec_script(script.data()); }