• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 #ifndef _SEPOL_PORT_RECORD_H_
2 #define _SEPOL_PORT_RECORD_H_
3 
4 #include <sepol/context_record.h>
5 #include <sepol/handle.h>
6 
7 struct sepol_port;
8 struct sepol_port_key;
9 typedef struct sepol_port sepol_port_t;
10 typedef struct sepol_port_key sepol_port_key_t;
11 
12 #define SEPOL_PROTO_UDP 0
13 #define SEPOL_PROTO_TCP 1
14 
15 /* Key */
16 extern int sepol_port_compare(const sepol_port_t * port,
17 			      const sepol_port_key_t * key);
18 
19 extern int sepol_port_compare2(const sepol_port_t * port,
20 			       const sepol_port_t * port2);
21 
22 extern int sepol_port_key_create(sepol_handle_t * handle,
23 				 int low, int high, int proto,
24 				 sepol_port_key_t ** key_ptr);
25 
26 extern void sepol_port_key_unpack(const sepol_port_key_t * key,
27 				  int *low, int *high, int *proto);
28 
29 extern int sepol_port_key_extract(sepol_handle_t * handle,
30 				  const sepol_port_t * port,
31 				  sepol_port_key_t ** key_ptr);
32 
33 extern void sepol_port_key_free(sepol_port_key_t * key);
34 
35 /* Protocol */
36 extern int sepol_port_get_proto(const sepol_port_t * port);
37 
38 extern void sepol_port_set_proto(sepol_port_t * port, int proto);
39 
40 extern const char *sepol_port_get_proto_str(int proto);
41 
42 /* Port */
43 extern int sepol_port_get_low(const sepol_port_t * port);
44 
45 extern int sepol_port_get_high(const sepol_port_t * port);
46 
47 extern void sepol_port_set_port(sepol_port_t * port, int port_num);
48 
49 extern void sepol_port_set_range(sepol_port_t * port, int low, int high);
50 
51 /* Context */
52 extern sepol_context_t *sepol_port_get_con(const sepol_port_t * port);
53 
54 extern int sepol_port_set_con(sepol_handle_t * handle,
55 			      sepol_port_t * port, sepol_context_t * con);
56 
57 /* Create/Clone/Destroy */
58 extern int sepol_port_create(sepol_handle_t * handle, sepol_port_t ** port_ptr);
59 
60 extern int sepol_port_clone(sepol_handle_t * handle,
61 			    const sepol_port_t * port,
62 			    sepol_port_t ** port_ptr);
63 
64 extern void sepol_port_free(sepol_port_t * port);
65 
66 #endif
67