Home | History | Annotate | Download | only in sepol
      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