2017-04-14 21:21:31 +02:00
|
|
|
/* su.h - Store all general su info
|
|
|
|
*/
|
2018-07-18 12:12:47 +02:00
|
|
|
|
2017-04-14 21:21:31 +02:00
|
|
|
#ifndef _SU_H_
|
|
|
|
#define _SU_H_
|
2018-07-18 12:12:47 +02:00
|
|
|
|
2017-04-14 21:21:31 +02:00
|
|
|
#include <limits.h>
|
|
|
|
#include <sys/types.h>
|
2017-07-07 19:12:47 +02:00
|
|
|
#include <sys/stat.h>
|
2018-07-18 12:12:47 +02:00
|
|
|
|
2017-05-29 12:54:33 +02:00
|
|
|
#include "list.h"
|
|
|
|
|
2017-04-18 15:09:53 +02:00
|
|
|
#define MAGISKSU_VER_STR xstr(MAGISK_VERSION) ":MAGISKSU (topjohnwu)"
|
2018-07-18 12:12:47 +02:00
|
|
|
|
2017-06-08 16:50:39 +02:00
|
|
|
// DB settings for root access
|
2017-05-31 21:19:45 +02:00
|
|
|
#define ROOT_ACCESS_ENTRY "root_access"
|
2017-01-27 22:30:02 +01:00
|
|
|
#define ROOT_ACCESS_DISABLED 0
|
|
|
|
#define ROOT_ACCESS_APPS_ONLY 1
|
|
|
|
#define ROOT_ACCESS_ADB_ONLY 2
|
|
|
|
#define ROOT_ACCESS_APPS_AND_ADB 3
|
2018-07-18 12:12:47 +02:00
|
|
|
|
2017-06-08 16:50:39 +02:00
|
|
|
// DB settings for multiuser
|
2017-05-31 21:19:45 +02:00
|
|
|
#define MULTIUSER_MODE_ENTRY "multiuser_mode"
|
2017-05-26 20:40:12 +02:00
|
|
|
#define MULTIUSER_MODE_OWNER_ONLY 0
|
|
|
|
#define MULTIUSER_MODE_OWNER_MANAGED 1
|
|
|
|
#define MULTIUSER_MODE_USER 2
|
|
|
|
|
2017-06-08 16:50:39 +02:00
|
|
|
// DB settings for namespace seperation
|
|
|
|
#define NAMESPACE_MODE_ENTRY "mnt_ns"
|
|
|
|
#define NAMESPACE_MODE_GLOBAL 0
|
|
|
|
#define NAMESPACE_MODE_REQUESTER 1
|
|
|
|
#define NAMESPACE_MODE_ISOLATE 2
|
|
|
|
|
2017-10-28 10:03:39 +02:00
|
|
|
// DB entry for requester
|
|
|
|
#define REQUESTER_ENTRY "requester"
|
|
|
|
|
2018-07-18 12:12:47 +02:00
|
|
|
// DO NOT CHANGE LINE BELOW, java package name will always be the same
|
2017-01-23 15:51:00 +01:00
|
|
|
#define JAVA_PACKAGE_NAME "com.topjohnwu.magisk"
|
2018-07-18 12:12:47 +02:00
|
|
|
// This is used if wrapping the fragment classes and activities
|
2017-04-14 21:21:31 +02:00
|
|
|
// with classes in another package.
|
2017-01-23 15:51:00 +01:00
|
|
|
#define REQUESTOR_PREFIX JAVA_PACKAGE_NAME ".superuser"
|
2018-07-18 12:12:47 +02:00
|
|
|
|
|
|
|
#define DEFAULT_SHELL "/system/bin/sh"
|
2017-12-11 20:03:05 +01:00
|
|
|
#define DATABASE_PATH "/data/adb/magisk.db"
|
2018-07-18 12:12:47 +02:00
|
|
|
|
2017-05-29 12:54:33 +02:00
|
|
|
typedef enum {
|
2017-12-11 20:03:05 +01:00
|
|
|
QUERY = 0,
|
|
|
|
DENY = 1,
|
|
|
|
ALLOW = 2,
|
2017-05-29 12:54:33 +02:00
|
|
|
} policy_t;
|
|
|
|
|
2017-05-31 21:19:45 +02:00
|
|
|
struct su_info {
|
2017-12-11 20:03:05 +01:00
|
|
|
unsigned uid; /* Key to find su_info */
|
|
|
|
pthread_mutex_t lock; /* Internal lock */
|
|
|
|
int count; /* Just a count for debugging purpose */
|
|
|
|
|
|
|
|
/* These values should be guarded with internal lock */
|
|
|
|
policy_t policy;
|
|
|
|
int multiuser_mode;
|
|
|
|
int root_access;
|
|
|
|
int mnt_ns;
|
|
|
|
|
|
|
|
/* These should be guarded with global list lock */
|
|
|
|
struct list_head pos;
|
|
|
|
int ref;
|
|
|
|
int clock;
|
2018-07-18 12:12:47 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
struct su_request {
|
2017-12-11 20:03:05 +01:00
|
|
|
unsigned uid;
|
|
|
|
int login;
|
|
|
|
int keepenv;
|
|
|
|
char *shell;
|
|
|
|
char *command;
|
|
|
|
char **argv;
|
|
|
|
int argc;
|
2018-07-18 12:12:47 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
struct su_context {
|
2017-12-11 20:03:05 +01:00
|
|
|
struct su_info *info;
|
|
|
|
struct su_request to;
|
|
|
|
char pkg_name[PATH_MAX];
|
|
|
|
char sock_path[PATH_MAX];
|
|
|
|
pid_t pid;
|
|
|
|
int notify;
|
|
|
|
mode_t umask;
|
|
|
|
char *cwd;
|
|
|
|
struct stat st;
|
|
|
|
int pipefd[2];
|
2018-07-18 12:12:47 +02:00
|
|
|
};
|
|
|
|
|
2017-05-29 12:54:33 +02:00
|
|
|
extern struct su_context *su_ctx;
|
2017-04-14 21:21:31 +02:00
|
|
|
|
|
|
|
// su.c
|
|
|
|
|
|
|
|
int su_daemon_main(int argc, char **argv);
|
2017-05-29 12:54:33 +02:00
|
|
|
__attribute__ ((noreturn)) void exit2(int status);
|
2017-09-15 09:23:50 +02:00
|
|
|
void set_identity(unsigned uid);
|
2017-04-14 21:21:31 +02:00
|
|
|
|
|
|
|
// su_client.c
|
|
|
|
|
|
|
|
int socket_create_temp(char *path, size_t len);
|
|
|
|
int socket_accept(int serv_fd);
|
|
|
|
void socket_send_request(int fd, const struct su_context *ctx);
|
|
|
|
void socket_receive_result(int fd, char *result, ssize_t result_len);
|
|
|
|
|
|
|
|
// activity.c
|
|
|
|
|
|
|
|
void app_send_result(struct su_context *ctx, policy_t policy);
|
|
|
|
void app_send_request(struct su_context *ctx);
|
|
|
|
|
|
|
|
// db.c
|
|
|
|
|
2017-05-29 12:54:33 +02:00
|
|
|
void database_check(struct su_context *ctx);
|
2017-04-14 21:21:31 +02:00
|
|
|
|
2018-07-18 12:12:47 +02:00
|
|
|
#endif
|