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