Magisk/su.h

122 lines
2.8 KiB
C
Raw Normal View History

2017-04-14 19:21:31 +00:00
/* su.h - Store all general su info
*/
2017-04-14 19:21:31 +00:00
#ifndef _SU_H_
#define _SU_H_
2017-04-14 19:21:31 +00:00
#include <limits.h>
#include <sys/types.h>
2017-07-07 17:12:47 +00:00
#include <sys/stat.h>
#include "list.h"
2017-04-18 13:09:53 +00:00
#define MAGISKSU_VER_STR xstr(MAGISK_VERSION) ":MAGISKSU (topjohnwu)"
2017-06-08 14:50:39 +00:00
// DB settings for root access
2017-05-31 19:19:45 +00:00
#define ROOT_ACCESS_ENTRY "root_access"
#define ROOT_ACCESS_DISABLED 0
#define ROOT_ACCESS_APPS_ONLY 1
#define ROOT_ACCESS_ADB_ONLY 2
#define ROOT_ACCESS_APPS_AND_ADB 3
2017-06-08 14:50:39 +00:00
// DB settings for multiuser
2017-05-31 19:19:45 +00:00
#define MULTIUSER_MODE_ENTRY "multiuser_mode"
2017-05-26 18:40:12 +00:00
#define MULTIUSER_MODE_OWNER_ONLY 0
#define MULTIUSER_MODE_OWNER_MANAGED 1
#define MULTIUSER_MODE_USER 2
2017-06-08 14:50:39 +00: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 08:03:39 +00:00
// DB entry for requester
#define REQUESTER_ENTRY "requester"
// DO NOT CHANGE LINE BELOW, java package name will always be the same
2017-01-23 14:51:00 +00:00
#define JAVA_PACKAGE_NAME "com.topjohnwu.magisk"
// This is used if wrapping the fragment classes and activities
2017-04-14 19:21:31 +00:00
// with classes in another package.
2017-01-23 14:51:00 +00:00
#define REQUESTOR_PREFIX JAVA_PACKAGE_NAME ".superuser"
#define DEFAULT_SHELL "/system/bin/sh"
typedef enum {
QUERY = 0,
DENY = 1,
ALLOW = 2,
} policy_t;
2017-05-31 19:19:45 +00:00
struct su_info {
2017-07-16 07:31:40 +00: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;
2017-05-31 19:19:45 +00:00
int multiuser_mode;
int root_access;
2017-06-08 14:50:39 +00:00
int mnt_ns;
2017-07-16 07:31:40 +00:00
/* These should be guarded with global list lock */
struct list_head pos;
2017-07-16 07:31:40 +00:00
int ref;
int clock;
};
struct su_request {
2017-05-26 18:40:12 +00:00
unsigned uid;
int login;
int keepenv;
char *shell;
char *command;
char **argv;
int argc;
};
2017-09-15 10:01:31 +00:00
struct su_path {
2017-08-11 17:09:02 +00:00
char base_path[PATH_MAX];
2017-09-15 10:01:31 +00:00
char multiuser_path[PATH_MAX];
2017-10-28 08:03:39 +00:00
char pkg_name[PATH_MAX];
2017-09-15 10:01:31 +00:00
char sock_path[PATH_MAX];
};
struct su_context {
2017-05-31 19:19:45 +00:00
struct su_info *info;
2017-05-26 18:40:12 +00:00
struct su_request to;
2017-09-15 10:01:31 +00:00
struct su_path path;
2017-05-31 19:19:45 +00:00
pid_t pid;
int notify;
2017-05-26 18:40:12 +00:00
mode_t umask;
2017-07-07 17:12:47 +00:00
char *cwd;
struct stat st;
2017-10-28 08:03:39 +00:00
int pipefd[2];
};
extern struct su_context *su_ctx;
2017-04-14 19:21:31 +00:00
// su.c
int su_daemon_main(int argc, char **argv);
__attribute__ ((noreturn)) void exit2(int status);
2017-09-15 07:23:50 +00:00
void set_identity(unsigned uid);
2017-04-14 19:21:31 +00: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
void database_check(struct su_context *ctx);
2017-04-14 19:21:31 +00:00
#endif