Magisk/sepolicy.h

48 lines
1.3 KiB
C
Raw Normal View History

2017-04-15 13:26:29 +02:00
/* sepolicy.h - Header for magiskpolicy non-public APIs
*/
#ifndef _SEPOLICY_H
#define _SEPOLICY_H
#include <getopt.h>
#include <unistd.h>
#include <stdlib.h>
#include <sys/mman.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <stdio.h>
#include <limits.h>
#include <string.h>
#include <sepol/debug.h>
#include <sepol/policydb/policydb.h>
#include <sepol/policydb/expand.h>
#include <sepol/policydb/link.h>
#include <sepol/policydb/services.h>
#include <sepol/policydb/avrule_block.h>
#include <sepol/policydb/conditional.h>
#include <sepol/policydb/constraint.h>
#include "vector.h"
// hashtab traversal macro
#define hashtab_for_each(table, ptr) \
for (int _i = 0; _i < table->size; ++_i) \
for (*ptr = table->htable[_i]; *ptr != NULL; *ptr = (*ptr)->next)
// Global policydb
2017-04-15 20:29:42 +02:00
extern policydb_t *policydb;
2017-04-15 13:26:29 +02:00
// sepolicy manipulation functions
int create_domain(char *d);
int set_domain_state(char* s, int state);
int add_transition(char *s, char *t, char *c, char *d);
int add_file_transition(char *s, char *t, char *c, char *d, char* filename);
int add_typeattribute(char *domainS, char *attr);
int add_rule(char *s, char *t, char *c, char *p, int effect, int not);
2017-04-19 22:04:09 +02:00
int add_xperm_rule(char *s, char *t, char *c, char *range, int effect, int not);
2017-04-15 13:26:29 +02:00
2017-04-15 20:29:42 +02:00
extern int policydb_index_decls(sepol_handle_t * handle, policydb_t * p);
2017-04-15 13:26:29 +02:00
#endif