Blame src/database_policydb.h

Packit Service 102278
/*
Packit Service 102278
 * Copyright (C) 2006 Tresys Technology, LLC
Packit Service 102278
 *
Packit Service 102278
 *  This library is free software; you can redistribute it and/or
Packit Service 102278
 *  modify it under the terms of the GNU Lesser General Public
Packit Service 102278
 *  License as published by the Free Software Foundation; either
Packit Service 102278
 *  version 2.1 of the License, or (at your option) any later version.
Packit Service 102278
 *
Packit Service 102278
 *  This library is distributed in the hope that it will be useful,
Packit Service 102278
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 102278
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit Service 102278
 *  Lesser General Public License for more details.
Packit Service 102278
 *
Packit Service 102278
 *  You should have received a copy of the GNU Lesser General Public
Packit Service 102278
 *  License along with this library; if not, write to the Free Software
Packit Service 102278
 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
Packit Service 102278
 */
Packit Service 102278
Packit Service 102278
/* Copyright (C) 2005 Red Hat, Inc. */
Packit Service 102278
Packit Service 102278
#ifndef _SEMANAGE_DATABASE_POLICYDB_INTERNAL_H_
Packit Service 102278
#define _SEMANAGE_DATABASE_POLICYDB_INTERNAL_H_
Packit Service 102278
Packit Service 102278
#include <sepol/handle.h>
Packit Service 102278
#include <sepol/policydb.h>
Packit Service 102278
#include "database.h"
Packit Service 102278
#include "handle.h"
Packit Service 102278
Packit Service 102278
struct dbase_policydb;
Packit Service 102278
typedef struct dbase_policydb dbase_policydb_t;
Packit Service 102278
Packit Service 102278
typedef int (*record_policydb_table_add_t) (sepol_handle_t * h,
Packit Service 102278
					    sepol_policydb_t * p,
Packit Service 102278
					    const record_key_t * rkey,
Packit Service 102278
					    const record_t * record);
Packit Service 102278
Packit Service 102278
typedef int (*record_policydb_table_modify_t) (sepol_handle_t * h,
Packit Service 102278
					       sepol_policydb_t * p,
Packit Service 102278
					       const record_key_t * rkey,
Packit Service 102278
					       const record_t * record);
Packit Service 102278
Packit Service 102278
typedef int (*record_policydb_table_set_t) (sepol_handle_t * h,
Packit Service 102278
					    sepol_policydb_t * p,
Packit Service 102278
					    const record_key_t * rkey,
Packit Service 102278
					    const record_t * record);
Packit Service 102278
Packit Service 102278
typedef int (*record_policydb_table_query_t) (sepol_handle_t * h,
Packit Service 102278
					      const sepol_policydb_t * p,
Packit Service 102278
					      const record_key_t * rkey,
Packit Service 102278
					      record_t ** response);
Packit Service 102278
Packit Service 102278
typedef int (*record_policydb_table_count_t) (sepol_handle_t * h,
Packit Service 102278
					      const sepol_policydb_t * p,
Packit Service 102278
					      unsigned int *response);
Packit Service 102278
Packit Service 102278
typedef int (*record_policydb_table_exists_t) (sepol_handle_t * h,
Packit Service 102278
					       const sepol_policydb_t * p,
Packit Service 102278
					       const record_key_t * rkey,
Packit Service 102278
					       int *response);
Packit Service 102278
Packit Service 102278
typedef int (*record_policydb_table_iterate_t) (sepol_handle_t * h,
Packit Service 102278
						const sepol_policydb_t * p,
Packit Service 102278
						int (*fn) (const record_t * r,
Packit Service 102278
							   void *fn_arg),
Packit Service 102278
						void *arg);
Packit Service 102278
Packit Service 102278
/* POLICYDB extension to RECORD interface - method table */
Packit Service 102278
typedef struct record_policydb_table {
Packit Service 102278
	/* Add policy record */
Packit Service 102278
	record_policydb_table_add_t add;
Packit Service 102278
	/* Modify policy record, or add if 
Packit Service 102278
	 * the key isn't found */
Packit Service 102278
	record_policydb_table_modify_t modify;
Packit Service 102278
	/* Set policy record */
Packit Service 102278
	record_policydb_table_set_t set;
Packit Service 102278
	/* Query policy record  - return the record
Packit Service 102278
	 * or NULL if it isn't found */
Packit Service 102278
	record_policydb_table_query_t query;
Packit Service 102278
	/* Count records */
Packit Service 102278
	record_policydb_table_count_t count;
Packit Service 102278
	/* Check if a record exists */
Packit Service 102278
	record_policydb_table_exists_t exists;
Packit Service 102278
	/* Iterate over records */
Packit Service 102278
	record_policydb_table_iterate_t iterate;
Packit Service 102278
} record_policydb_table_t;
Packit Service 102278
Packit Service 102278
/* Initialize database */
Packit Service 102278
extern int dbase_policydb_init(semanage_handle_t * handle,
Packit Service 102278
			       const char *path_ro,
Packit Service 102278
			       const char *path_rw,
Packit Service 102278
			       record_table_t * rtable,
Packit Service 102278
			       record_policydb_table_t * rptable,
Packit Service 102278
			       dbase_policydb_t ** dbase);
Packit Service 102278
Packit Service 102278
/* Attach to a shared policydb.
Packit Service 102278
 * This implies drop_cache().
Packit Service 102278
 * and prevents flush() and drop_cache()
Packit Service 102278
 * until detached. */
Packit Service 102278
extern void dbase_policydb_attach(dbase_policydb_t * dbase,
Packit Service 102278
				  sepol_policydb_t * policydb);
Packit Service 102278
Packit Service 102278
/* Detach from a shared policdb.
Packit Service 102278
 * This implies drop_cache. */
Packit Service 102278
extern void dbase_policydb_detach(dbase_policydb_t * dbase);
Packit Service 102278
Packit Service 102278
/* Release allocated resources */
Packit Service 102278
extern void dbase_policydb_release(dbase_policydb_t * dbase);
Packit Service 102278
Packit Service 102278
/* POLICYDB database - method table implementation */
Packit Service 102278
extern dbase_table_t SEMANAGE_POLICYDB_DTABLE;
Packit Service 102278
Packit Service 102278
#endif