xref: /aosp_15_r20/external/selinux/libsepol/include/sepol/users.h (revision 2d543d20722ada2425b5bdab9d0d1d29470e7bba)
1*2d543d20SAndroid Build Coastguard Worker #ifndef _SEPOL_USERS_H_
2*2d543d20SAndroid Build Coastguard Worker #define _SEPOL_USERS_H_
3*2d543d20SAndroid Build Coastguard Worker 
4*2d543d20SAndroid Build Coastguard Worker #include <sepol/policydb.h>
5*2d543d20SAndroid Build Coastguard Worker #include <sepol/user_record.h>
6*2d543d20SAndroid Build Coastguard Worker #include <sepol/handle.h>
7*2d543d20SAndroid Build Coastguard Worker #include <stddef.h>
8*2d543d20SAndroid Build Coastguard Worker 
9*2d543d20SAndroid Build Coastguard Worker #ifdef __cplusplus
10*2d543d20SAndroid Build Coastguard Worker extern "C" {
11*2d543d20SAndroid Build Coastguard Worker #endif
12*2d543d20SAndroid Build Coastguard Worker 
13*2d543d20SAndroid Build Coastguard Worker /* Modify the user, or add it, if the key is not found */
14*2d543d20SAndroid Build Coastguard Worker extern int sepol_user_modify(sepol_handle_t * handle,
15*2d543d20SAndroid Build Coastguard Worker 			     sepol_policydb_t * policydb,
16*2d543d20SAndroid Build Coastguard Worker 			     const sepol_user_key_t * key,
17*2d543d20SAndroid Build Coastguard Worker 			     const sepol_user_t * data);
18*2d543d20SAndroid Build Coastguard Worker 
19*2d543d20SAndroid Build Coastguard Worker /* Return the number of users */
20*2d543d20SAndroid Build Coastguard Worker extern int sepol_user_count(sepol_handle_t * handle,
21*2d543d20SAndroid Build Coastguard Worker 			    const sepol_policydb_t * p, unsigned int *response);
22*2d543d20SAndroid Build Coastguard Worker 
23*2d543d20SAndroid Build Coastguard Worker /* Check if the specified user exists */
24*2d543d20SAndroid Build Coastguard Worker extern int sepol_user_exists(sepol_handle_t * handle,
25*2d543d20SAndroid Build Coastguard Worker 			     const sepol_policydb_t * policydb,
26*2d543d20SAndroid Build Coastguard Worker 			     const sepol_user_key_t * key, int *response);
27*2d543d20SAndroid Build Coastguard Worker 
28*2d543d20SAndroid Build Coastguard Worker /* Query a user - returns the user or NULL if not found */
29*2d543d20SAndroid Build Coastguard Worker extern int sepol_user_query(sepol_handle_t * handle,
30*2d543d20SAndroid Build Coastguard Worker 			    const sepol_policydb_t * p,
31*2d543d20SAndroid Build Coastguard Worker 			    const sepol_user_key_t * key,
32*2d543d20SAndroid Build Coastguard Worker 			    sepol_user_t ** response);
33*2d543d20SAndroid Build Coastguard Worker 
34*2d543d20SAndroid Build Coastguard Worker /* Iterate the users
35*2d543d20SAndroid Build Coastguard Worker  * The handler may return:
36*2d543d20SAndroid Build Coastguard Worker  * -1 to signal an error condition,
37*2d543d20SAndroid Build Coastguard Worker  * 1 to signal successful exit
38*2d543d20SAndroid Build Coastguard Worker  * 0 to signal continue */
39*2d543d20SAndroid Build Coastguard Worker extern int sepol_user_iterate(sepol_handle_t * handle,
40*2d543d20SAndroid Build Coastguard Worker 			      const sepol_policydb_t * policydb,
41*2d543d20SAndroid Build Coastguard Worker 			      int (*fn) (const sepol_user_t * user,
42*2d543d20SAndroid Build Coastguard Worker 					 void *fn_arg), void *arg);
43*2d543d20SAndroid Build Coastguard Worker 
44*2d543d20SAndroid Build Coastguard Worker #ifdef __cplusplus
45*2d543d20SAndroid Build Coastguard Worker }
46*2d543d20SAndroid Build Coastguard Worker #endif
47*2d543d20SAndroid Build Coastguard Worker 
48*2d543d20SAndroid Build Coastguard Worker #endif
49