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