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