Blame include/selinux/label.h

Packit 3feee0
/*
Packit 3feee0
 * Labeling interface for userspace object managers and others.
Packit 3feee0
 *
Packit 3feee0
 * Author : Eamon Walsh <ewalsh@tycho.nsa.gov>
Packit 3feee0
 */
Packit 3feee0
#ifndef _SELABEL_H_
Packit 3feee0
#define _SELABEL_H_
Packit 3feee0
Packit 3feee0
#include <stdbool.h>
Packit 3feee0
#include <sys/types.h>
Packit 3feee0
#include <selinux/selinux.h>
Packit 3feee0
Packit 3feee0
#ifdef __cplusplus
Packit 3feee0
extern "C" {
Packit 3feee0
#endif
Packit 3feee0
Packit 3feee0
/*
Packit 3feee0
 * Opaque type used for all label handles.
Packit 3feee0
 */
Packit 3feee0
Packit 3feee0
struct selabel_handle;
Packit 3feee0
Packit 3feee0
/* 
Packit 3feee0
 * Available backends.
Packit 3feee0
 */
Packit 3feee0
Packit 3feee0
/* file contexts */
Packit 3feee0
#define SELABEL_CTX_FILE	0
Packit 3feee0
/* media contexts */
Packit 3feee0
#define SELABEL_CTX_MEDIA	1
Packit 3feee0
/* x contexts */
Packit 3feee0
#define SELABEL_CTX_X		2
Packit 3feee0
/* db objects */
Packit 3feee0
#define SELABEL_CTX_DB		3
Packit 3feee0
/* Android property service contexts */
Packit 3feee0
#define SELABEL_CTX_ANDROID_PROP 4
Packit 3feee0
/* Android service contexts */
Packit 3feee0
#define SELABEL_CTX_ANDROID_SERVICE 5
Packit 3feee0
Packit 3feee0
/*
Packit 3feee0
 * Available options
Packit 3feee0
 */
Packit 3feee0
Packit 3feee0
/* no-op option, useful for unused slots in an array of options */
Packit 3feee0
#define SELABEL_OPT_UNUSED	0
Packit 3feee0
/* validate contexts before returning them (boolean value) */
Packit 3feee0
#define SELABEL_OPT_VALIDATE	1
Packit 3feee0
/* don't use local customizations to backend data (boolean value) */
Packit 3feee0
#define SELABEL_OPT_BASEONLY	2
Packit 3feee0
/* specify an alternate path to use when loading backend data */
Packit 3feee0
#define SELABEL_OPT_PATH	3
Packit 3feee0
/* select a subset of the search space as an optimization (file backend) */
Packit 3feee0
#define SELABEL_OPT_SUBSET	4
Packit 3feee0
/* require a hash calculation on spec files */
Packit 3feee0
#define SELABEL_OPT_DIGEST	5
Packit 3feee0
/* total number of options */
Packit 3feee0
#define SELABEL_NOPT		6
Packit 3feee0
Packit 3feee0
/*
Packit 3feee0
 * Label operations
Packit 3feee0
 */
Packit 3feee0
Packit 3feee0
/**
Packit 3feee0
 * selabel_open - Create a labeling handle.
Packit 3feee0
 * @backend: one of the constants specifying a supported labeling backend.
Packit 3feee0
 * @opts: array of selabel_opt structures specifying label options or NULL.
Packit 3feee0
 * @nopts: number of elements in opts array or zero for no options.
Packit 3feee0
 *
Packit 3feee0
 * Open a labeling backend for use.  The available backend identifiers are
Packit 3feee0
 * listed above.  Options may be provided via the opts parameter; available
Packit 3feee0
 * options are listed above.  Not all options may be supported by every
Packit 3feee0
 * backend.  Return value is the created handle on success or NULL with
Packit 3feee0
 * @errno set on failure.
Packit 3feee0
 */
Packit 3feee0
struct selabel_handle *selabel_open(unsigned int backend,
Packit 3feee0
				    const struct selinux_opt *opts,
Packit 3feee0
				    unsigned nopts);
Packit 3feee0
Packit 3feee0
/**
Packit 3feee0
 * selabel_close - Close a labeling handle.
Packit 3feee0
 * @handle: specifies handle to close
Packit 3feee0
 *
Packit 3feee0
 * Destroy the specified handle, closing files, freeing allocated memory,
Packit 3feee0
 * etc.  The handle may not be further used after it has been closed.
Packit 3feee0
 */
Packit 3feee0
void selabel_close(struct selabel_handle *handle);
Packit 3feee0
Packit 3feee0
/**
Packit 3feee0
 * selabel_lookup - Perform labeling lookup operation.
Packit 3feee0
 * @handle: specifies backend instance to query
Packit 3feee0
 * @con: returns the appropriate context with which to label the object
Packit 3feee0
 * @key: string input to lookup operation
Packit 3feee0
 * @type: numeric input to the lookup operation
Packit 3feee0
 *
Packit 3feee0
 * Perform a labeling lookup operation.  Return %0 on success, -%1 with
Packit 3feee0
 * @errno set on failure.  The key and type arguments are the inputs to the
Packit 3feee0
 * lookup operation; appropriate values are dictated by the backend in use.
Packit 3feee0
 * The result is returned in the memory pointed to by @con and must be freed
Packit 3feee0
 * by the user with freecon().
Packit 3feee0
 */
Packit 3feee0
int selabel_lookup(struct selabel_handle *handle, char **con,
Packit 3feee0
		   const char *key, int type);
Packit 3feee0
int selabel_lookup_raw(struct selabel_handle *handle, char **con,
Packit 3feee0
		       const char *key, int type);
Packit 3feee0
Packit 3feee0
bool selabel_partial_match(struct selabel_handle *handle, const char *key);
Packit 3feee0
Packit 3feee0
int selabel_lookup_best_match(struct selabel_handle *rec, char **con,
Packit 3feee0
			      const char *key, const char **aliases, int type);
Packit 3feee0
int selabel_lookup_best_match_raw(struct selabel_handle *rec, char **con,
Packit 3feee0
			      const char *key, const char **aliases, int type);
Packit 3feee0
Packit 3feee0
/**
Packit 3feee0
 * selabel_digest - Retrieve the SHA1 digest and the list of specfiles used to
Packit 3feee0
 *		    generate the digest. The SELABEL_OPT_DIGEST option must
Packit 3feee0
 *		    be set in selabel_open() to initiate the digest generation.
Packit 3feee0
 * @handle: specifies backend instance to query
Packit 3feee0
 * @digest: returns a pointer to the SHA1 digest.
Packit 3feee0
 * @digest_len: returns length of digest in bytes.
Packit 3feee0
 * @specfiles: a list of specfiles used in the SHA1 digest generation.
Packit 3feee0
 *	       The list is NULL terminated and will hold @num_specfiles entries.
Packit 3feee0
 * @num_specfiles: number of specfiles in the list.
Packit 3feee0
 *
Packit 3feee0
 * Return %0 on success, -%1 with @errno set on failure.
Packit 3feee0
 */
Packit 3feee0
int selabel_digest(struct selabel_handle *rec,
Packit 3feee0
			    unsigned char **digest, size_t *digest_len,
Packit 3feee0
			    char ***specfiles, size_t *num_specfiles);
Packit 3feee0
Packit 3feee0
enum selabel_cmp_result {
Packit 3feee0
	SELABEL_SUBSET,
Packit 3feee0
	SELABEL_EQUAL,
Packit 3feee0
	SELABEL_SUPERSET,
Packit 3feee0
	SELABEL_INCOMPARABLE
Packit 3feee0
};
Packit 3feee0
Packit 3feee0
/**
Packit 3feee0
 * selabel_cmp - Compare two label configurations.
Packit 3feee0
 * @h1: handle for the first label configuration
Packit 3feee0
 * @h2: handle for the first label configuration
Packit 3feee0
 *
Packit 3feee0
 * Compare two label configurations.
Packit 3feee0
 * Return %SELABEL_SUBSET if @h1 is a subset of @h2, %SELABEL_EQUAL
Packit 3feee0
 * if @h1 is identical to @h2, %SELABEL_SUPERSET if @h1 is a superset
Packit 3feee0
 * of @h2, and %SELABEL_INCOMPARABLE if @h1 and @h2 are incomparable.
Packit 3feee0
 */
Packit 3feee0
enum selabel_cmp_result selabel_cmp(struct selabel_handle *h1,
Packit 3feee0
				    struct selabel_handle *h2);
Packit 3feee0
Packit 3feee0
/**
Packit 3feee0
 * selabel_stats - log labeling operation statistics.
Packit 3feee0
 * @handle: specifies backend instance to query
Packit 3feee0
 *
Packit 3feee0
 * Log a message with information about the number of queries performed,
Packit 3feee0
 * number of unused matching entries, or other operational statistics.
Packit 3feee0
 * Message is backend-specific, some backends may not output a message.
Packit 3feee0
 */
Packit 3feee0
void selabel_stats(struct selabel_handle *handle);
Packit 3feee0
Packit 3feee0
/*
Packit 3feee0
 * Type codes used by specific backends
Packit 3feee0
 */
Packit 3feee0
Packit 3feee0
/* X backend */
Packit 3feee0
#define SELABEL_X_PROP		1
Packit 3feee0
#define SELABEL_X_EXT		2
Packit 3feee0
#define SELABEL_X_CLIENT	3
Packit 3feee0
#define SELABEL_X_EVENT		4
Packit 3feee0
#define SELABEL_X_SELN		5
Packit 3feee0
#define SELABEL_X_POLYPROP	6
Packit 3feee0
#define SELABEL_X_POLYSELN	7
Packit 3feee0
Packit 3feee0
/* DB backend */
Packit 3feee0
#define SELABEL_DB_DATABASE	1
Packit 3feee0
#define SELABEL_DB_SCHEMA	2
Packit 3feee0
#define SELABEL_DB_TABLE	3
Packit 3feee0
#define SELABEL_DB_COLUMN	4
Packit 3feee0
#define SELABEL_DB_SEQUENCE	5
Packit 3feee0
#define SELABEL_DB_VIEW		6
Packit 3feee0
#define SELABEL_DB_PROCEDURE	7
Packit 3feee0
#define SELABEL_DB_BLOB		8
Packit 3feee0
#define SELABEL_DB_TUPLE	9
Packit 3feee0
#define SELABEL_DB_LANGUAGE	10
Packit 3feee0
#define SELABEL_DB_EXCEPTION 11
Packit 3feee0
#define SELABEL_DB_DATATYPE 12
Packit 3feee0
Packit 3feee0
#ifdef __cplusplus
Packit 3feee0
}
Packit 3feee0
#endif
Packit 3feee0
#endif	/* _SELABEL_H_ */