1 #ifndef _SEPOL_NODE_RECORD_H_ 2 #define _SEPOL_NODE_RECORD_H_ 3 4 #include <stddef.h> 5 #include <sepol/context_record.h> 6 #include <sepol/handle.h> 7 8 #ifdef __cplusplus 9 extern "C" { 10 #endif 11 12 struct sepol_node; 13 struct sepol_node_key; 14 typedef struct sepol_node sepol_node_t; 15 typedef struct sepol_node_key sepol_node_key_t; 16 17 #define SEPOL_PROTO_IP4 0 18 #define SEPOL_PROTO_IP6 1 19 20 /* Key */ 21 extern int sepol_node_compare(const sepol_node_t * node, 22 const sepol_node_key_t * key); 23 24 extern int sepol_node_compare2(const sepol_node_t * node, 25 const sepol_node_t * node2); 26 27 extern int sepol_node_key_create(sepol_handle_t * handle, 28 const char *addr, 29 const char *mask, 30 int proto, sepol_node_key_t ** key_ptr); 31 32 extern void sepol_node_key_unpack(const sepol_node_key_t * key, 33 const char **addr, 34 const char **mask, int *proto); 35 36 extern int sepol_node_key_extract(sepol_handle_t * handle, 37 const sepol_node_t * node, 38 sepol_node_key_t ** key_ptr); 39 40 extern void sepol_node_key_free(sepol_node_key_t * key); 41 42 /* Address */ 43 extern int sepol_node_get_addr(sepol_handle_t * handle, 44 const sepol_node_t * node, char **addr); 45 46 extern int sepol_node_get_addr_bytes(sepol_handle_t * handle, 47 const sepol_node_t * node, 48 char **addr, size_t * addr_sz); 49 50 extern int sepol_node_set_addr(sepol_handle_t * handle, 51 sepol_node_t * node, 52 int proto, const char *addr); 53 54 extern int sepol_node_set_addr_bytes(sepol_handle_t * handle, 55 sepol_node_t * node, 56 const char *addr, size_t addr_sz); 57 58 /* Netmask */ 59 extern int sepol_node_get_mask(sepol_handle_t * handle, 60 const sepol_node_t * node, char **mask); 61 62 extern int sepol_node_get_mask_bytes(sepol_handle_t * handle, 63 const sepol_node_t * node, 64 char **mask, size_t * mask_sz); 65 66 extern int sepol_node_set_mask(sepol_handle_t * handle, 67 sepol_node_t * node, 68 int proto, const char *mask); 69 70 extern int sepol_node_set_mask_bytes(sepol_handle_t * handle, 71 sepol_node_t * node, 72 const char *mask, size_t mask_sz); 73 74 /* Protocol */ 75 extern int sepol_node_get_proto(const sepol_node_t * node); 76 77 extern void sepol_node_set_proto(sepol_node_t * node, int proto); 78 79 extern const char *sepol_node_get_proto_str(int proto); 80 81 /* Context */ 82 extern sepol_context_t *sepol_node_get_con(const sepol_node_t * node); 83 84 extern int sepol_node_set_con(sepol_handle_t * handle, 85 sepol_node_t * node, sepol_context_t * con); 86 87 /* Create/Clone/Destroy */ 88 extern int sepol_node_create(sepol_handle_t * handle, sepol_node_t ** node_ptr); 89 90 extern int sepol_node_clone(sepol_handle_t * handle, 91 const sepol_node_t * node, 92 sepol_node_t ** node_ptr); 93 94 extern void sepol_node_free(sepol_node_t * node); 95 96 #ifdef __cplusplus 97 } 98 #endif 99 100 #endif 101