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
|
|
|
|
|
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
|
|
|
|
2017-05-26 20:40:12 +02:00
|
|
|
#define APP_DATA_PATH "/data/data/"
|
2017-04-14 21:21:31 +02:00
|
|
|
#define USER_DATA_PATH "/data/user"
|
|
|
|
|
2018-07-18 12:12:47 +02:00
|
|
|
// If --rename-manifest-package is used in AAPT, this
|
|
|
|
// must be changed to correspond to the new APK package name
|
|
|
|
// See the two Android.mk files for more details.
|
2017-01-23 15:51:00 +01:00
|
|
|
#define REQUESTOR JAVA_PACKAGE_NAME
|
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 REQUESTOR_CACHE_PATH "/dev/" REQUESTOR
|
|
|
|
// there's no guarantee that the db or files are actually created named as such by
|
|
|
|
// SQLiteOpenHelper, etc. Though that is the behavior as of current.
|
|
|
|
// it is up to the Android application to symlink as appropriate.
|
2017-01-23 15:51:00 +01:00
|
|
|
#define REQUESTOR_DATABASE_PATH REQUESTOR "/databases/su.db"
|
2018-07-18 12:12:47 +02:00
|
|
|
|
|
|
|
#define DEFAULT_SHELL "/system/bin/sh"
|
|
|
|
|
2017-05-29 12:54:33 +02:00
|
|
|
typedef enum {
|
|
|
|
QUERY = 0,
|
|
|
|
DENY = 1,
|
|
|
|
ALLOW = 2,
|
|
|
|
} policy_t;
|
|
|
|
|
2017-05-31 21:19:45 +02:00
|
|
|
struct su_info {
|
2017-07-16 09:31:40 +02: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 */
|
2017-05-29 12:54:33 +02:00
|
|
|
policy_t policy;
|
2017-05-31 21:19:45 +02:00
|
|
|
int multiuser_mode;
|
|
|
|
int root_access;
|
2017-06-08 16:50:39 +02:00
|
|
|
int mnt_ns;
|
2017-07-16 09:31:40 +02:00
|
|
|
|
|
|
|
/* These should be guarded with global list lock */
|
2017-05-29 12:54:33 +02:00
|
|
|
struct list_head pos;
|
2017-07-16 09:31:40 +02:00
|
|
|
int ref;
|
|
|
|
int clock;
|
2018-07-18 12:12:47 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
struct su_request {
|
2017-05-26 20:40:12 +02: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_user_info {
|
2017-05-26 20:40:12 +02:00
|
|
|
// the user in android userspace (multiuser)
|
|
|
|
// that invoked this action.
|
|
|
|
unsigned android_user_id;
|
2017-08-11 19:09:02 +02:00
|
|
|
// path to superuser directory. this is populated according
|
|
|
|
// to the multiuser mode.
|
|
|
|
// this is used to check uid/gid for protecting socket.
|
|
|
|
// this is used instead of database, as it is more likely
|
|
|
|
// to exist. db will not exist if su has never launched.
|
|
|
|
char base_path[PATH_MAX];
|
2017-05-26 20:40:12 +02:00
|
|
|
// path to su database. this is populated according
|
|
|
|
// to the multiuser mode.
|
|
|
|
char database_path[PATH_MAX];
|
2018-07-18 12:12:47 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
struct su_context {
|
2017-05-31 21:19:45 +02:00
|
|
|
struct su_info *info;
|
2017-05-26 20:40:12 +02:00
|
|
|
struct su_request to;
|
|
|
|
struct su_user_info user;
|
2017-05-31 21:19:45 +02:00
|
|
|
pid_t pid;
|
2017-05-29 12:54:33 +02:00
|
|
|
int notify;
|
2017-05-26 20:40:12 +02:00
|
|
|
mode_t umask;
|
2017-07-07 19:12:47 +02:00
|
|
|
char *cwd;
|
|
|
|
struct stat st;
|
2017-05-26 20:40:12 +02:00
|
|
|
char sock_path[PATH_MAX];
|
2018-07-18 12:12:47 +02:00
|
|
|
};
|
|
|
|
|
2017-05-29 12:54:33 +02:00
|
|
|
extern struct su_context *su_ctx;
|
|
|
|
extern int pipefd[2];
|
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-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
|
|
|
|
|
|
|
// misc.c
|
|
|
|
|
|
|
|
void set_identity(unsigned uid);
|
|
|
|
char *get_command(const struct su_request *to);
|
2017-04-15 20:28:12 +02:00
|
|
|
int fork_zero_fucks();
|
2018-07-18 12:12:47 +02:00
|
|
|
|
|
|
|
#endif
|