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