root/usr/src/lib/krb5/plugins/kdb/db2/policy_db.h
/*
 * Data Types for policy and principal information that
 * exists in the respective databases.
 *
 * $Header$
 *
 * This file was originally created with rpcgen.
 * It has been hacked up since then.
 */

#ifndef __ADB_H__
#define __ADB_H__

#include <sys/types.h>
#include <errno.h>
#include <krb5.h>
#include <kdb.h>
/* Okay, this is a bit obscure.  The libdb2 configure script doesn't
   detect it, but on Tru64 5.1, netinet/in.h causes sys/bittypes.h to
   be included, and that has a typedef for u_int32_t.  Because the
   configure script doesn't detect it, it causes db-config.h to have a
   #define for u_int32_t, so including db.h and then netinet/in.h
   causes compilation to fail.

   Since gssrpc/types.h includes netinet/in.h, including that first
   will cause the typedef to be seen before the macro definition,
   which still isn't quite right, but is close enough for now.

   A better fix might be for db.h to include netinet/in.h if that's
   where we find u_int32_t.  */
/* Solaris Kerberos: gssrpc not supported */
#if 0 /************** Begin IFDEF'ed OUT *******************************/
#include <gssrpc/types.h>
#include <gssrpc/xdr.h>
#else
#include <rpc/types.h>
#include <rpc/xdr.h>
#endif /**************** END IFDEF'ed OUT *******************************/
#include <db.h>
#include <kdb/adb_err.h>
#include <com_err.h>

typedef long            osa_adb_ret_t;

#define OSA_ADB_POLICY_DB_MAGIC 0x12345A00

#define OSA_ADB_POLICY_VERSION_MASK     0x12345D00
#define OSA_ADB_POLICY_VERSION_1        0x12345D01



typedef struct _osa_adb_db_lock_ent_t {
     FILE     *lockfile;
     char     *filename;
     int      refcnt, lockmode, lockcnt;
     krb5_context context;
} osa_adb_lock_ent, *osa_adb_lock_t;

typedef struct _osa_adb_db_ent_t {
     int        magic;
     DB         *db;
     HASHINFO   info;
     BTREEINFO  btinfo;
     char       *filename;
     osa_adb_lock_t lock;
     int        opencnt;
} osa_adb_db_ent, *osa_adb_db_t, *osa_adb_princ_t, *osa_adb_policy_t;

/*
 * Return Code (the rest are in adb_err.h)
 */

#define OSA_ADB_OK              0

/*
 * Functions
 */

krb5_error_code osa_adb_create_db(char *filename, char *lockfile, int magic);
krb5_error_code osa_adb_destroy_db(char *filename, char *lockfile, int magic);
krb5_error_code   osa_adb_rename_db(char *filefrom, char *lockfrom,
                                  char *fileto, char *lockto, int magic);
krb5_error_code osa_adb_init_db(osa_adb_db_t *dbp, char *filename,
                                char *lockfile, int magic);
krb5_error_code osa_adb_fini_db(osa_adb_db_t db, int magic);
krb5_error_code osa_adb_get_lock(osa_adb_db_t db, int mode);
krb5_error_code osa_adb_release_lock(osa_adb_db_t db);
krb5_error_code osa_adb_open_and_lock(osa_adb_princ_t db, int locktype);
krb5_error_code osa_adb_close_and_unlock(osa_adb_princ_t db);
krb5_error_code osa_adb_close_policy(osa_adb_policy_t db);
krb5_error_code osa_adb_create_policy(osa_adb_policy_t db,
                                      osa_policy_ent_t entry);
krb5_error_code osa_adb_destroy_policy(osa_adb_policy_t db,
                                       char * name);
krb5_error_code osa_adb_get_policy(osa_adb_policy_t db,
                                   char * name,
                                   osa_policy_ent_t *entry,
                                   int *cnt);
krb5_error_code osa_adb_put_policy(osa_adb_policy_t db,
                                   osa_policy_ent_t entry);
krb5_error_code osa_adb_iter_policy(osa_adb_policy_t db,
                                    osa_adb_iter_policy_func func,
                                    void * data);
void            osa_free_policy_ent(osa_policy_ent_t val);

bool_t  xdr_osa_policy_ent_rec(XDR *xdrs, osa_policy_ent_t objp);

#endif /* __ADB_H__ */