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