2020-04-11 11:40:40 +00:00
|
|
|
#include <string_view>
|
|
|
|
|
|
|
|
#include <magisk.hpp>
|
|
|
|
#include <selinux.hpp>
|
2022-05-12 09:03:42 +00:00
|
|
|
#include <base.hpp>
|
2020-04-11 11:40:40 +00:00
|
|
|
|
|
|
|
using namespace std;
|
|
|
|
|
|
|
|
#define UNLABEL_CON "u:object_r:unlabeled:s0"
|
|
|
|
#define SYSTEM_CON "u:object_r:system_file:s0"
|
|
|
|
#define ADB_CON "u:object_r:adb_data_file:s0"
|
|
|
|
#define ROOT_CON "u:object_r:rootfs:s0"
|
2020-06-04 06:29:42 +00:00
|
|
|
#define MAGISK_CON "u:object_r:" SEPOL_FILE_TYPE ":s0"
|
|
|
|
#define EXEC_CON "u:object_r:" SEPOL_EXEC_TYPE ":s0"
|
2020-04-11 11:40:40 +00:00
|
|
|
|
|
|
|
static void restore_syscon(int dirfd) {
|
2020-12-31 06:11:24 +00:00
|
|
|
struct dirent *entry;
|
|
|
|
char *con;
|
2020-04-11 11:40:40 +00:00
|
|
|
|
2021-04-03 08:08:36 +00:00
|
|
|
if (fgetfilecon(dirfd, &con) >= 0) {
|
2021-09-02 14:54:53 +00:00
|
|
|
if (strlen(con) == 0 || strcmp(con, UNLABEL_CON) == 0 || strcmp(con, ADB_CON) == 0)
|
2021-04-03 08:08:36 +00:00
|
|
|
fsetfilecon(dirfd, SYSTEM_CON);
|
|
|
|
freecon(con);
|
|
|
|
}
|
2020-04-11 11:40:40 +00:00
|
|
|
|
2022-02-02 10:39:13 +00:00
|
|
|
auto dir = xopen_dir(dirfd);
|
|
|
|
while ((entry = xreaddir(dir.get()))) {
|
2020-12-31 06:11:24 +00:00
|
|
|
int fd = openat(dirfd, entry->d_name, O_RDONLY | O_CLOEXEC);
|
|
|
|
if (entry->d_type == DT_DIR) {
|
|
|
|
restore_syscon(fd);
|
2022-02-02 10:39:13 +00:00
|
|
|
continue;
|
2020-12-31 06:11:24 +00:00
|
|
|
} else if (entry->d_type == DT_REG) {
|
2021-04-03 08:08:36 +00:00
|
|
|
if (fgetfilecon(fd, &con) >= 0) {
|
2021-09-02 14:54:53 +00:00
|
|
|
if (con[0] == '\0' || strcmp(con, UNLABEL_CON) == 0 || strcmp(con, ADB_CON) == 0)
|
2021-04-03 08:08:36 +00:00
|
|
|
fsetfilecon(fd, SYSTEM_CON);
|
|
|
|
freecon(con);
|
|
|
|
}
|
2020-12-31 06:11:24 +00:00
|
|
|
} else if (entry->d_type == DT_LNK) {
|
|
|
|
getfilecon_at(dirfd, entry->d_name, &con);
|
2021-09-02 14:54:53 +00:00
|
|
|
if (con[0] == '\0' || strcmp(con, UNLABEL_CON) == 0 || strcmp(con, ADB_CON) == 0)
|
2020-12-31 06:11:24 +00:00
|
|
|
setfilecon_at(dirfd, entry->d_name, con);
|
|
|
|
freecon(con);
|
|
|
|
}
|
|
|
|
close(fd);
|
|
|
|
}
|
2020-04-11 11:40:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void restore_magiskcon(int dirfd) {
|
2020-12-31 06:11:24 +00:00
|
|
|
struct dirent *entry;
|
2020-04-11 11:40:40 +00:00
|
|
|
|
2020-12-31 06:11:24 +00:00
|
|
|
fsetfilecon(dirfd, MAGISK_CON);
|
|
|
|
fchown(dirfd, 0, 0);
|
2020-04-11 11:40:40 +00:00
|
|
|
|
2022-02-02 10:39:13 +00:00
|
|
|
auto dir = xopen_dir(dirfd);
|
|
|
|
while ((entry = xreaddir(dir.get()))) {
|
2020-12-31 06:11:24 +00:00
|
|
|
int fd = xopenat(dirfd, entry->d_name, O_RDONLY | O_CLOEXEC);
|
|
|
|
if (entry->d_type == DT_DIR) {
|
|
|
|
restore_magiskcon(fd);
|
2022-02-02 10:39:13 +00:00
|
|
|
continue;
|
2020-12-31 06:11:24 +00:00
|
|
|
} else if (entry->d_type) {
|
|
|
|
fsetfilecon(fd, MAGISK_CON);
|
|
|
|
fchown(fd, 0, 0);
|
|
|
|
}
|
|
|
|
close(fd);
|
|
|
|
}
|
2020-04-11 11:40:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void restorecon() {
|
2022-06-01 05:24:13 +00:00
|
|
|
if (!selinux_enabled())
|
|
|
|
return;
|
2020-12-31 06:11:24 +00:00
|
|
|
int fd = xopen(SELINUX_CONTEXT, O_WRONLY | O_CLOEXEC);
|
|
|
|
if (write(fd, ADB_CON, sizeof(ADB_CON)) >= 0)
|
|
|
|
lsetfilecon(SECURE_DIR, ADB_CON);
|
|
|
|
close(fd);
|
|
|
|
lsetfilecon(MODULEROOT, SYSTEM_CON);
|
2022-02-02 10:39:13 +00:00
|
|
|
restore_syscon(xopen(MODULEROOT, O_RDONLY | O_CLOEXEC));
|
2022-07-21 19:08:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void restore_databincon() {
|
2022-02-02 10:39:13 +00:00
|
|
|
restore_magiskcon(xopen(DATABIN, O_RDONLY | O_CLOEXEC));
|
2020-04-11 11:40:40 +00:00
|
|
|
}
|
|
|
|
|
2020-04-19 10:33:25 +00:00
|
|
|
void restore_tmpcon() {
|
2022-06-01 05:24:13 +00:00
|
|
|
if (!selinux_enabled())
|
|
|
|
return;
|
2020-12-31 06:11:24 +00:00
|
|
|
if (MAGISKTMP == "/sbin")
|
|
|
|
setfilecon(MAGISKTMP.data(), ROOT_CON);
|
|
|
|
else
|
|
|
|
chmod(MAGISKTMP.data(), 0700);
|
2020-04-11 11:40:40 +00:00
|
|
|
|
2020-12-31 06:11:24 +00:00
|
|
|
auto dir = xopen_dir(MAGISKTMP.data());
|
|
|
|
int dfd = dirfd(dir.get());
|
2020-04-11 11:40:40 +00:00
|
|
|
|
2021-01-18 20:37:08 +00:00
|
|
|
for (dirent *entry; (entry = xreaddir(dir.get()));)
|
|
|
|
setfilecon_at(dfd, entry->d_name, SYSTEM_CON);
|
|
|
|
|
2021-01-26 10:16:11 +00:00
|
|
|
if (SDK_INT >= 26) {
|
|
|
|
string magisk = MAGISKTMP + "/magisk";
|
|
|
|
setfilecon(magisk.data(), EXEC_CON);
|
|
|
|
}
|
2020-04-11 11:40:40 +00:00
|
|
|
}
|