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
|
/** BEGIN COPYRIGHT BLOCK
* Copyright 2001 Sun Microsystems, Inc.
* Portions copyright 1999, 2001-2003 Netscape Communications Corporation.
* All rights reserved.
* END COPYRIGHT BLOCK **/
#ifndef ACL_USER_CACHE_H
#define ACL_USER_CACHE_H
#ifdef NSPR20
#include <plhash.h>
#else
#include <nspr/prhash.h>
#endif
#include <sys/types.h>
#include <time.h>
/* Removed for new ns security integration
#include <sec.h>
*/
#include <key.h>
#include <cert.h>
#include <prclist.h>
typedef struct {
PRCList list; /* pointer to next & prev obj */
char *uid; /* unique within a database */
char *userdn; /* LDAP DN if using LDAP db */
char *passwd; /* password */
SECItem *derCert; /* raw certificate data */
char *group; /* group recently checked for membership */
time_t time; /* last time when the cache was validated */
PRHashTable *hashtable; /* hash table where this obj is being used */
} UserCacheObj;
NSPR_BEGIN_EXTERN_C
/* Set the number of seconds the cache is valid */
extern int acl_usr_cache_set_timeout (const int nsec);
/* Is the cache enabled? */
extern int acl_usr_cache_enabled();
/* initialize user cache */
extern int acl_usr_cache_init ();
/* Creates a new user obj entry */
extern int acl_usr_cache_insert (const char *uid, const char *dbname,
const char *dn, const char *passwd,
const char *group, const SECItem *derCert,
const time_t time);
/* Add group to the user's cache obj. */
extern int acl_usr_cache_set_group (const char *uid, const char *dbname,
const char *group, const time_t time);
/* Add userdn to the user's cache obj. */
extern int acl_usr_cache_set_userdn (const char *uid, const char *dbname,
const char *userdn, const time_t time);
/* Returns LAS_EVAL_TRUE if the user's password matches -- also returns the dn */
extern int acl_usr_cache_passwd_check (const char *uid, const char *dbname,
const char *passwd,
const time_t time, char **dn,
pool_handle_t *pool);
/* Returns LAS_EVAL_TRUE if the user is a member of the group */
extern int acl_usr_cache_group_check (const char *uid, const char *dbname,
const char *group, const time_t time);
/* Returns LAS_EVAL_TRUE if the user is a member of the group */
extern int acl_usr_cache_group_len_check (const char *uid, const char *dbname,
const char *group,
const int len,
const time_t time);
/* Returns LAS_EVAL_TRUE if the user's cache is valid and has a group */
extern int acl_usr_cache_get_group (const char *uid, const char *dbname,
const time_t time, char **group,
pool_handle_t *pool);
/* Returns LAS_EVAL_TRUE if the user is a member of the group */
extern int acl_usr_cache_userdn_check (const char *uid, const char *dbname,
const char *userdn, const time_t time);
/* Returns LAS_EVAL_TRUE if the user's cache is valid and has userdn */
extern int acl_usr_cache_get_userdn (const char *uid, const char *dbname,
const time_t time, char **userdn,
pool_handle_t *pool);
/* Creates a new user obj entry for cert to user mapping */
extern int acl_cert_cache_insert (void *cert, const char *dbname,
const char *uid, const char *dn,
const time_t time);
/* Returns LAS_EVAL_TRUE if the user's cache is valid and returns uid */
extern int acl_cert_cache_get_uid (void *cert, const char *dbname,
const time_t time, char **uid,
char **dn, pool_handle_t *pool);
NSPR_END_EXTERN_C
#endif /* ACL_USER_CACHE_H */
|