#ifndef KRB5_KDB_DB2_H
#define KRB5_KDB_DB2_H
#include "policy_db.h"
typedef struct _krb5_db2_context {
krb5_boolean db_inited;
char * db_name;
DB * db;
krb5_boolean hashfirst;
char * db_lf_name;
int db_lf_file;
time_t db_lf_time;
int db_locks_held;
int db_lock_mode;
krb5_boolean db_nb_locks;
krb5_keyblock *db_master_key;
osa_adb_policy_t policy_db;
krb5_boolean tempdb;
} krb5_db2_context;
#define KRB5_DB2_MAX_RETRY 5
#define KDB2_LOCK_EXT ".ok"
#define KDB2_TEMP_LOCK_EXT "~.ok"
krb5_error_code krb5_db2_db_init
(krb5_context);
krb5_error_code krb5_db2_db_fini
(krb5_context);
krb5_error_code krb5_db2_db_get_age
(krb5_context,
char *,
time_t * );
krb5_error_code krb5_db2_db_create
(krb5_context,
char *,
krb5_int32);
krb5_error_code krb5_db2_db_destroy
(krb5_context,
char * );
krb5_error_code krb5_db2_db_rename
(krb5_context,
char *,
char * );
krb5_error_code krb5_db2_db_get_principal
(krb5_context,
krb5_const_principal,
krb5_db_entry *,
int *,
krb5_boolean * );
krb5_error_code krb5_db2_db_free_principal
(krb5_context,
krb5_db_entry *,
int );
krb5_error_code krb5_db2_db_put_principal
(krb5_context,
krb5_db_entry *,
int *,
char **db_args
);
krb5_error_code krb5_db2_db_iterate_ext
(krb5_context,
krb5_error_code (*) (krb5_pointer,
krb5_db_entry *),
krb5_pointer, int, int );
krb5_error_code krb5_db2_db_iterate
(krb5_context,char *,
krb5_error_code (*) (krb5_pointer,
krb5_db_entry *),
krb5_pointer );
krb5_error_code krb5_db2_db_set_nonblocking
(krb5_context,
krb5_boolean,
krb5_boolean * );
krb5_boolean krb5_db2_db_set_lockmode
(krb5_context,
krb5_boolean );
krb5_error_code krb5_db2_db_open_database
(krb5_context);
krb5_error_code krb5_db2_db_close_database
(krb5_context);
krb5_error_code
krb5_db2_set_master_key_ext ( krb5_context kcontext,
char *pwd,
krb5_keyblock *key);
krb5_error_code
krb5_db2_db_set_mkey( krb5_context context,
krb5_keyblock *key);
krb5_error_code
krb5_db2_db_get_mkey( krb5_context context,
krb5_keyblock **key);
krb5_error_code
krb5_db2_db_put_principal( krb5_context context,
krb5_db_entry *entries,
register int *nentries,
char **db_args);
krb5_error_code
krb5_db2_db_delete_principal(krb5_context context,
krb5_const_principal searchfor,
int *nentries);
krb5_error_code krb5_db2_lib_init(void);
krb5_error_code krb5_db2_lib_cleanup(void);
krb5_error_code
krb5_db2_db_unlock(krb5_context);
krb5_error_code
krb5_db2_promote_db(krb5_context kcontext,
char *conf_section,
char **db_args);
krb5_error_code
krb5_db2_db_set_option ( krb5_context kcontext,
int option,
void *value );
krb5_error_code
krb5_db2_db_lock( krb5_context context,
int in_mode);
krb5_error_code
krb5_db2_open( krb5_context kcontext,
char *conf_section,
char **db_args,
int mode );
krb5_error_code krb5_db2_create( krb5_context kcontext,
char *conf_section,
char **db_args );
krb5_error_code krb5_db2_destroy( krb5_context kcontext,
char *conf_section,
char **db_args );
const char * krb5_db2_err2str( krb5_context kcontext,
long err_code );
void *
krb5_db2_alloc( krb5_context kcontext,
void *ptr,
size_t size );
void
krb5_db2_free( krb5_context kcontext,
void *ptr );
krb5_error_code
krb5_db2_create_policy(krb5_context context, osa_policy_ent_t entry);
krb5_error_code krb5_db2_get_policy ( krb5_context kcontext,
char *name,
osa_policy_ent_t *policy,
int *cnt);
krb5_error_code krb5_db2_put_policy ( krb5_context kcontext,
osa_policy_ent_t policy );
krb5_error_code krb5_db2_iter_policy ( krb5_context kcontext,
char *match_entry,
osa_adb_iter_policy_func func,
void *data );
krb5_error_code krb5_db2_delete_policy ( krb5_context kcontext,
char *policy );
void krb5_db2_free_policy( krb5_context kcontext,
osa_policy_ent_t entry );
#endif