user_record.h 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. #ifndef _SEPOL_USER_RECORD_H_
  2. #define _SEPOL_USER_RECORD_H_
  3. #include <stddef.h>
  4. #include <sepol/handle.h>
  5. struct sepol_user;
  6. struct sepol_user_key;
  7. typedef struct sepol_user sepol_user_t;
  8. typedef struct sepol_user_key sepol_user_key_t;
  9. /* Key */
  10. extern int sepol_user_key_create(sepol_handle_t * handle,
  11. const char *name, sepol_user_key_t ** key);
  12. extern void sepol_user_key_unpack(const sepol_user_key_t * key,
  13. const char **name);
  14. extern int sepol_user_key_extract(sepol_handle_t * handle,
  15. const sepol_user_t * user,
  16. sepol_user_key_t ** key_ptr);
  17. extern void sepol_user_key_free(sepol_user_key_t * key);
  18. extern int sepol_user_compare(const sepol_user_t * user,
  19. const sepol_user_key_t * key);
  20. extern int sepol_user_compare2(const sepol_user_t * user,
  21. const sepol_user_t * user2);
  22. /* Name */
  23. extern const char *sepol_user_get_name(const sepol_user_t * user);
  24. extern int sepol_user_set_name(sepol_handle_t * handle,
  25. sepol_user_t * user, const char *name);
  26. /* MLS */
  27. extern const char *sepol_user_get_mlslevel(const sepol_user_t * user);
  28. extern int sepol_user_set_mlslevel(sepol_handle_t * handle,
  29. sepol_user_t * user, const char *mls_level);
  30. extern const char *sepol_user_get_mlsrange(const sepol_user_t * user);
  31. extern int sepol_user_set_mlsrange(sepol_handle_t * handle,
  32. sepol_user_t * user, const char *mls_range);
  33. /* Role management */
  34. extern int sepol_user_get_num_roles(const sepol_user_t * user);
  35. extern int sepol_user_add_role(sepol_handle_t * handle,
  36. sepol_user_t * user, const char *role);
  37. extern void sepol_user_del_role(sepol_user_t * user, const char *role);
  38. extern int sepol_user_has_role(const sepol_user_t * user, const char *role);
  39. extern int sepol_user_get_roles(sepol_handle_t * handle,
  40. const sepol_user_t * user,
  41. const char ***roles_arr,
  42. unsigned int *num_roles);
  43. extern int sepol_user_set_roles(sepol_handle_t * handle,
  44. sepol_user_t * user,
  45. const char **roles_arr, unsigned int num_roles);
  46. /* Create/Clone/Destroy */
  47. extern int sepol_user_create(sepol_handle_t * handle, sepol_user_t ** user_ptr);
  48. extern int sepol_user_clone(sepol_handle_t * handle,
  49. const sepol_user_t * user,
  50. sepol_user_t ** user_ptr);
  51. extern void sepol_user_free(sepol_user_t * user);
  52. #endif