1 #ifndef _SEPOL_USER_RECORD_H_ 2 #define _SEPOL_USER_RECORD_H_ 3 4 #include <stddef.h> 5 #include <sepol/handle.h> 6 7 #ifdef __cplusplus 8 extern "C" { 9 #endif 10 11 struct sepol_user; 12 struct sepol_user_key; 13 typedef struct sepol_user sepol_user_t; 14 typedef struct sepol_user_key sepol_user_key_t; 15 16 /* Key */ 17 extern int sepol_user_key_create(sepol_handle_t * handle, 18 const char *name, sepol_user_key_t ** key); 19 20 extern void sepol_user_key_unpack(const sepol_user_key_t * key, 21 const char **name); 22 23 extern int sepol_user_key_extract(sepol_handle_t * handle, 24 const sepol_user_t * user, 25 sepol_user_key_t ** key_ptr); 26 27 extern void sepol_user_key_free(sepol_user_key_t * key); 28 29 extern int sepol_user_compare(const sepol_user_t * user, 30 const sepol_user_key_t * key); 31 32 extern int sepol_user_compare2(const sepol_user_t * user, 33 const sepol_user_t * user2); 34 35 /* Name */ 36 extern const char *sepol_user_get_name(const sepol_user_t * user); 37 38 extern int sepol_user_set_name(sepol_handle_t * handle, 39 sepol_user_t * user, const char *name); 40 41 /* MLS */ 42 extern const char *sepol_user_get_mlslevel(const sepol_user_t * user); 43 44 extern int sepol_user_set_mlslevel(sepol_handle_t * handle, 45 sepol_user_t * user, const char *mls_level); 46 47 extern const char *sepol_user_get_mlsrange(const sepol_user_t * user); 48 49 extern int sepol_user_set_mlsrange(sepol_handle_t * handle, 50 sepol_user_t * user, const char *mls_range); 51 52 /* Role management */ 53 extern int sepol_user_get_num_roles(const sepol_user_t * user); 54 55 extern int sepol_user_add_role(sepol_handle_t * handle, 56 sepol_user_t * user, const char *role); 57 58 extern void sepol_user_del_role(sepol_user_t * user, const char *role); 59 60 extern int sepol_user_has_role(const sepol_user_t * user, const char *role); 61 62 extern int sepol_user_get_roles(sepol_handle_t * handle, 63 const sepol_user_t * user, 64 const char ***roles_arr, 65 unsigned int *num_roles); 66 67 extern int sepol_user_set_roles(sepol_handle_t * handle, 68 sepol_user_t * user, 69 const char **roles_arr, unsigned int num_roles); 70 71 /* Create/Clone/Destroy */ 72 extern int sepol_user_create(sepol_handle_t * handle, sepol_user_t ** user_ptr); 73 74 extern int sepol_user_clone(sepol_handle_t * handle, 75 const sepol_user_t * user, 76 sepol_user_t ** user_ptr); 77 78 extern void sepol_user_free(sepol_user_t * user); 79 80 #ifdef __cplusplus 81 } 82 #endif 83 84 #endif 85