1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
|
/*
* Data Types for policys, and principal information that
* exist 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 <rpc/types.h>
#include "k5-int.h"
#include <krb5/kdb.h>
#include <db.h>
#include <kadm5/admin.h>
#include <kadm5/adb_err.h>
#include <com_err.h>
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__ */
|