/* * Copyright 2002 Sun Microsystems, Inc. All rights reserved. * Use is subject to license terms. */ #pragma ident "%Z%%M% %I% %E% SMI" /* * WARNING WARNING WARNING WARNING WARNING WARNING WARNING WARNING WARNING * * Openvision retains the copyright to derivative works of * this source code. Do *NOT* create a derivative of this * source code before consulting with your legal department. * Do *NOT* integrate *ANY* of this source code into another * product before consulting with your legal department. * * For further information, read the top-level Openvision * copyright which is contained in the top-level MIT Kerberos * copyright. * * WARNING WARNING WARNING WARNING WARNING WARNING WARNING WARNING WARNING * */ /* * Data Types for policys, and principal information that * exist in the respective databases. * * $Header: /cvs/krbdev/krb5/src/lib/kadm5/adb.h,v 1.21 1998/02/14 02:34:09 tlyu Exp $ * * This file was originally created with rpcgen. * It has been hacked up since then. */ #ifndef __ADB_H__ #define __ADB_H__ #include #include /* SUNWresync121 - no need to change to gssrpc/ */ #include "k5-int.h" #include #include #include #include #include typedef long osa_adb_ret_t; #define OSA_ADB_POLICY_DB_MAGIC 0x12345A00 #define OSA_ADB_PRINC_DB_MAGIC 0x12345B00 #define OSA_ADB_SHARED 0x7001 #define OSA_ADB_EXCLUSIVE 0x7002 #define OSA_ADB_PERMANENT 0x7003 #define OSA_ADB_PRINC_VERSION_MASK 0x12345C00 #define OSA_ADB_PRINC_VERSION_1 0x12345C01 #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; char *filename; osa_adb_lock_t lock; } osa_adb_db_ent, *osa_adb_db_t, *osa_adb_princ_t, *osa_adb_policy_t; /* an osa_pw_hist_ent stores all the key_datas for a single password */ typedef struct _osa_pw_hist_t { int n_key_data; krb5_key_data *key_data; } osa_pw_hist_ent, *osa_pw_hist_t; typedef struct _osa_princ_ent_t { int version; char *policy; long aux_attributes; unsigned int old_key_len; unsigned int old_key_next; krb5_kvno admin_history_kvno; osa_pw_hist_ent *old_keys; } osa_princ_ent_rec, *osa_princ_ent_t; typedef struct _osa_policy_ent_t { int version; char *name; rpc_u_int32 pw_min_life; rpc_u_int32 pw_max_life; rpc_u_int32 pw_min_length; rpc_u_int32 pw_min_classes; rpc_u_int32 pw_history_num; rpc_u_int32 policy_refcnt; } osa_policy_ent_rec, *osa_policy_ent_t; typedef void (*osa_adb_iter_princ_func) (void *, osa_princ_ent_t); typedef void (*osa_adb_iter_policy_func) (void *, osa_policy_ent_t); /* * Return Code (the rest are in adb_err.h) */ #define OSA_ADB_OK 0 /* * xdr functions */ bool_t xdr_osa_princ_ent_rec(XDR *xdrs, osa_princ_ent_t objp); bool_t xdr_osa_policy_ent_rec(XDR *xdrs, osa_policy_ent_t objp); /* * Functions */ osa_adb_ret_t osa_adb_create_db(char *filename, char *lockfile, int magic); osa_adb_ret_t osa_adb_destroy_db(char *filename, char *lockfile, int magic); osa_adb_ret_t osa_adb_init_db(osa_adb_db_t *dbp, char *filename, char *lockfile, int magic); osa_adb_ret_t osa_adb_fini_db(osa_adb_db_t db, int magic); osa_adb_ret_t osa_adb_get_lock(osa_adb_db_t db, int mode); osa_adb_ret_t osa_adb_release_lock(osa_adb_db_t db); osa_adb_ret_t osa_adb_open_and_lock(osa_adb_princ_t db, int locktype); osa_adb_ret_t osa_adb_close_and_unlock(osa_adb_princ_t db); osa_adb_ret_t osa_adb_create_policy_db(kadm5_config_params *params); osa_adb_ret_t osa_adb_destroy_policy_db(kadm5_config_params *params); osa_adb_ret_t osa_adb_open_princ(osa_adb_princ_t *db, char *filename); osa_adb_ret_t osa_adb_open_policy(osa_adb_policy_t *db, kadm5_config_params *rparams); osa_adb_ret_t osa_adb_close_princ(osa_adb_princ_t db); osa_adb_ret_t osa_adb_close_policy(osa_adb_policy_t db); osa_adb_ret_t osa_adb_create_princ(osa_adb_princ_t db, osa_princ_ent_t entry); osa_adb_ret_t osa_adb_create_policy(osa_adb_policy_t db, osa_policy_ent_t entry); osa_adb_ret_t osa_adb_destroy_princ(osa_adb_princ_t db, kadm5_princ_t name); osa_adb_ret_t osa_adb_destroy_policy(osa_adb_policy_t db, kadm5_policy_t name); osa_adb_ret_t osa_adb_get_princ(osa_adb_princ_t db, kadm5_princ_t name, osa_princ_ent_t *entry); osa_adb_ret_t osa_adb_get_policy(osa_adb_policy_t db, kadm5_policy_t name, osa_policy_ent_t *entry); osa_adb_ret_t osa_adb_put_princ(osa_adb_princ_t db, osa_princ_ent_t entry); osa_adb_ret_t osa_adb_put_policy(osa_adb_policy_t db, osa_policy_ent_t entry); osa_adb_ret_t osa_adb_iter_policy(osa_adb_policy_t db, osa_adb_iter_policy_func func, void * data); osa_adb_ret_t osa_adb_iter_princ(osa_adb_princ_t db, osa_adb_iter_princ_func func, void *data); void osa_free_policy_ent(osa_policy_ent_t val); void osa_free_princ_ent(osa_princ_ent_t val); #endif /* __ADB_H__ */