mirror of
https://github.com/SELinuxProject/selinux
synced 2025-01-10 07:29:28 +00:00
ed7a6ba24a
Change-Id: I7da601767c3a4ebed7274e33304d8b589a9115fe Signed-off-by: Stephen Smalley <sds@tycho.nsa.gov>
48 lines
1.4 KiB
C
48 lines
1.4 KiB
C
#ifndef __SEPOL_INTERFACES_H_
|
|
#define __SEPOL_INTERFACES_H_
|
|
|
|
#include <sepol/policydb.h>
|
|
#include <sepol/iface_record.h>
|
|
#include <sepol/handle.h>
|
|
#include <sys/cdefs.h>
|
|
|
|
__BEGIN_DECLS
|
|
|
|
/* Return the number of interfaces */
|
|
extern int sepol_iface_count(sepol_handle_t * handle,
|
|
const sepol_policydb_t * policydb,
|
|
unsigned int *response);
|
|
|
|
/* Check if an interface exists */
|
|
extern int sepol_iface_exists(sepol_handle_t * handle,
|
|
const sepol_policydb_t * policydb,
|
|
const sepol_iface_key_t * key, int *response);
|
|
|
|
/* Query an interface - returns the interface,
|
|
* or NULL if not found */
|
|
extern int sepol_iface_query(sepol_handle_t * handle,
|
|
const sepol_policydb_t * policydb,
|
|
const sepol_iface_key_t * key,
|
|
sepol_iface_t ** response);
|
|
|
|
/* Modify an interface, or add it, if the key
|
|
* is not found */
|
|
extern int sepol_iface_modify(sepol_handle_t * handle,
|
|
sepol_policydb_t * policydb,
|
|
const sepol_iface_key_t * key,
|
|
const sepol_iface_t * data);
|
|
|
|
/* Iterate the interfaces
|
|
* The handler may return:
|
|
* -1 to signal an error condition,
|
|
* 1 to signal successful exit
|
|
* 0 to signal continue */
|
|
|
|
extern int sepol_iface_iterate(sepol_handle_t * handle,
|
|
const sepol_policydb_t * policydb,
|
|
int (*fn) (const sepol_iface_t * iface,
|
|
void *fn_arg), void *arg);
|
|
|
|
__END_DECLS
|
|
#endif
|