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