1 #ifndef _SEPOL_BOOLEANS_H_ 2 #define _SEPOL_BOOLEANS_H_ 3 4 #include <stddef.h> 5 #include <sepol/policydb.h> 6 #include <sepol/boolean_record.h> 7 #include <sepol/handle.h> 8 9 #ifdef __cplusplus 10 extern "C" { 11 #endif 12 13 /*--------------compatibility--------------*/ 14 15 /* Given an existing binary policy (starting at 'data', with length 'len') 16 and a boolean configuration file named by 'boolpath', rewrite the binary 17 policy for the boolean settings in the boolean configuration file. 18 The binary policy is rewritten in place in memory. 19 Returns 0 upon success, or -1 otherwise. */ 20 extern int sepol_genbools(void *data, size_t len, char *boolpath); 21 22 /* Given an existing binary policy (starting at 'data', with length 'len') 23 and boolean settings specified by the parallel arrays ('names', 'values') 24 with 'nel' elements, rewrite the binary policy for the boolean settings. 25 The binary policy is rewritten in place in memory. 26 Returns 0 upon success or -1 otherwise. */ 27 extern int sepol_genbools_array(void *data, size_t len, 28 char **names, int *values, int nel); 29 /*---------------end compatbility------------*/ 30 31 /* Set the specified boolean */ 32 extern int sepol_bool_set(sepol_handle_t * handle, 33 sepol_policydb_t * policydb, 34 const sepol_bool_key_t * key, 35 const sepol_bool_t * data); 36 37 /* Return the number of booleans */ 38 extern int sepol_bool_count(sepol_handle_t * handle, 39 const sepol_policydb_t * p, unsigned int *response); 40 41 /* Check if the specified boolean exists */ 42 extern int sepol_bool_exists(sepol_handle_t * handle, 43 const sepol_policydb_t * policydb, 44 const sepol_bool_key_t * key, int *response); 45 46 /* Query a boolean - returns the boolean, or NULL if not found */ 47 extern int sepol_bool_query(sepol_handle_t * handle, 48 const sepol_policydb_t * p, 49 const sepol_bool_key_t * key, 50 sepol_bool_t ** response); 51 52 /* Iterate the booleans 53 * The handler may return: 54 * -1 to signal an error condition, 55 * 1 to signal successful exit 56 * 0 to signal continue */ 57 58 extern int sepol_bool_iterate(sepol_handle_t * handle, 59 const sepol_policydb_t * policydb, 60 int (*fn) (const sepol_bool_t * boolean, 61 void *fn_arg), void *arg); 62 63 #ifdef __cplusplus 64 } 65 #endif 66 67 #endif 68