|
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
|