annotate src/auth/passdb-cache.c @ 5259:228eacfb2647 HEAD

Added more debug logging.
author Timo Sirainen <tss@iki.fi>
date Sat, 10 Mar 2007 15:24:15 +0200
parents 83f361144a8a
children 6c48466c23fa
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
2798
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
1 /* Copyright (C) 2004 Timo Sirainen */
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
2
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
3 #include "common.h"
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
4 #include "password-scheme.h"
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
5 #include "passdb.h"
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
6 #include "passdb-cache.h"
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
7
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
8 #include <stdlib.h>
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
9
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
10 struct auth_cache *passdb_cache = NULL;
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
11
3863
55df57c028d4 Added "bool" type and changed all ints that were used as booleans to bool.
Timo Sirainen <tss@iki.fi>
parents: 3728
diff changeset
12 bool passdb_cache_verify_plain(struct auth_request *request, const char *key,
55df57c028d4 Added "bool" type and changed all ints that were used as booleans to bool.
Timo Sirainen <tss@iki.fi>
parents: 3728
diff changeset
13 const char *password,
55df57c028d4 Added "bool" type and changed all ints that were used as booleans to bool.
Timo Sirainen <tss@iki.fi>
parents: 3728
diff changeset
14 enum passdb_result *result_r, int use_expired)
2798
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
15 {
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
16 const char *value, *cached_pw, *scheme, *const *list;
4658
3b49b9ec87dc auth_cache: Try to handle changing passwords automatically: If password
Timo Sirainen <tss@iki.fi>
parents: 3918
diff changeset
17 struct auth_cache_node *node;
3863
55df57c028d4 Added "bool" type and changed all ints that were used as booleans to bool.
Timo Sirainen <tss@iki.fi>
parents: 3728
diff changeset
18 int ret;
55df57c028d4 Added "bool" type and changed all ints that were used as booleans to bool.
Timo Sirainen <tss@iki.fi>
parents: 3728
diff changeset
19 bool expired;
2798
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
20
3728
64ed35c97678 Don't crash if cache key isn't set but cache is enabled.
Timo Sirainen <tss@iki.fi>
parents: 3655
diff changeset
21 if (passdb_cache == NULL || key == NULL)
2798
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
22 return FALSE;
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
23
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
24 /* value = password \t ... */
4658
3b49b9ec87dc auth_cache: Try to handle changing passwords automatically: If password
Timo Sirainen <tss@iki.fi>
parents: 3918
diff changeset
25 value = auth_cache_lookup(passdb_cache, request, key, &node, &expired);
5259
228eacfb2647 Added more debug logging.
Timo Sirainen <tss@iki.fi>
parents: 5153
diff changeset
26 if (value == NULL || (expired && !use_expired)) {
228eacfb2647 Added more debug logging.
Timo Sirainen <tss@iki.fi>
parents: 5153
diff changeset
27 auth_request_log_debug(request, "cache",
228eacfb2647 Added more debug logging.
Timo Sirainen <tss@iki.fi>
parents: 5153
diff changeset
28 value == NULL ? "miss" : "expired");
2798
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
29 return FALSE;
5259
228eacfb2647 Added more debug logging.
Timo Sirainen <tss@iki.fi>
parents: 5153
diff changeset
30 }
228eacfb2647 Added more debug logging.
Timo Sirainen <tss@iki.fi>
parents: 5153
diff changeset
31 auth_request_log_debug(request, "cache", "hit");
2798
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
32
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
33 if (*value == '\0') {
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
34 /* negative cache entry */
3646
f50496e14ac8 Added some more verbosity to cache lookups.
Timo Sirainen <tss@iki.fi>
parents: 3431
diff changeset
35 auth_request_log_info(request, "cache", "User unknown");
2798
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
36 *result_r = PASSDB_RESULT_USER_UNKNOWN;
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
37 return TRUE;
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
38 }
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
39
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
40 list = t_strsplit(value, "\t");
3431
27fb8c9202e2 Auth cache wasn't working if password wasn't given (ie. didn't work for
Timo Sirainen <tss@iki.fi>
parents: 3274
diff changeset
41
2798
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
42 cached_pw = list[0];
3431
27fb8c9202e2 Auth cache wasn't working if password wasn't given (ie. didn't work for
Timo Sirainen <tss@iki.fi>
parents: 3274
diff changeset
43 if (*cached_pw == '\0') {
27fb8c9202e2 Auth cache wasn't working if password wasn't given (ie. didn't work for
Timo Sirainen <tss@iki.fi>
parents: 3274
diff changeset
44 /* NULL password */
3646
f50496e14ac8 Added some more verbosity to cache lookups.
Timo Sirainen <tss@iki.fi>
parents: 3431
diff changeset
45 auth_request_log_info(request, "cache", "NULL password access");
5128
365ff0cfd03f If last login was valid and the current one wasn't, we returned "not found
Timo Sirainen <tss@iki.fi>
parents: 4658
diff changeset
46 ret = 1;
365ff0cfd03f If last login was valid and the current one wasn't, we returned "not found
Timo Sirainen <tss@iki.fi>
parents: 4658
diff changeset
47 } else {
365ff0cfd03f If last login was valid and the current one wasn't, we returned "not found
Timo Sirainen <tss@iki.fi>
parents: 4658
diff changeset
48 scheme = password_get_scheme(&cached_pw);
365ff0cfd03f If last login was valid and the current one wasn't, we returned "not found
Timo Sirainen <tss@iki.fi>
parents: 4658
diff changeset
49 i_assert(scheme != NULL);
3161
6a3254e3c3de Moved cache handling from sql/ldap-specific code to generic auth-request
Timo Sirainen <tss@iki.fi>
parents: 3158
diff changeset
50
5128
365ff0cfd03f If last login was valid and the current one wasn't, we returned "not found
Timo Sirainen <tss@iki.fi>
parents: 4658
diff changeset
51 ret = auth_request_password_verify(request, password, cached_pw,
365ff0cfd03f If last login was valid and the current one wasn't, we returned "not found
Timo Sirainen <tss@iki.fi>
parents: 4658
diff changeset
52 scheme, "cache");
2798
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
53
5128
365ff0cfd03f If last login was valid and the current one wasn't, we returned "not found
Timo Sirainen <tss@iki.fi>
parents: 4658
diff changeset
54 if (ret == 0 && node->last_success) {
365ff0cfd03f If last login was valid and the current one wasn't, we returned "not found
Timo Sirainen <tss@iki.fi>
parents: 4658
diff changeset
55 /* the last authentication was successful. assume that
365ff0cfd03f If last login was valid and the current one wasn't, we returned "not found
Timo Sirainen <tss@iki.fi>
parents: 4658
diff changeset
56 the password was changed and cache is expired. */
365ff0cfd03f If last login was valid and the current one wasn't, we returned "not found
Timo Sirainen <tss@iki.fi>
parents: 4658
diff changeset
57 node->last_success = FALSE;
365ff0cfd03f If last login was valid and the current one wasn't, we returned "not found
Timo Sirainen <tss@iki.fi>
parents: 4658
diff changeset
58 return FALSE;
365ff0cfd03f If last login was valid and the current one wasn't, we returned "not found
Timo Sirainen <tss@iki.fi>
parents: 4658
diff changeset
59 }
4658
3b49b9ec87dc auth_cache: Try to handle changing passwords automatically: If password
Timo Sirainen <tss@iki.fi>
parents: 3918
diff changeset
60 }
3b49b9ec87dc auth_cache: Try to handle changing passwords automatically: If password
Timo Sirainen <tss@iki.fi>
parents: 3918
diff changeset
61 node->last_success = ret > 0;
3b49b9ec87dc auth_cache: Try to handle changing passwords automatically: If password
Timo Sirainen <tss@iki.fi>
parents: 3918
diff changeset
62
5128
365ff0cfd03f If last login was valid and the current one wasn't, we returned "not found
Timo Sirainen <tss@iki.fi>
parents: 4658
diff changeset
63 /* save the extra_fields only after we know we're using the
365ff0cfd03f If last login was valid and the current one wasn't, we returned "not found
Timo Sirainen <tss@iki.fi>
parents: 4658
diff changeset
64 cached data */
5153
83f361144a8a Added auth_request_set_fields() and used it instead of duplicating the code
Timo Sirainen <tss@iki.fi>
parents: 5134
diff changeset
65 auth_request_set_fields(request, list + 1, NULL);
5128
365ff0cfd03f If last login was valid and the current one wasn't, we returned "not found
Timo Sirainen <tss@iki.fi>
parents: 4658
diff changeset
66
2798
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
67 *result_r = ret > 0 ? PASSDB_RESULT_OK :
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
68 PASSDB_RESULT_PASSWORD_MISMATCH;
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
69 return TRUE;
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
70 }
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
71
3863
55df57c028d4 Added "bool" type and changed all ints that were used as booleans to bool.
Timo Sirainen <tss@iki.fi>
parents: 3728
diff changeset
72 bool passdb_cache_lookup_credentials(struct auth_request *request,
55df57c028d4 Added "bool" type and changed all ints that were used as booleans to bool.
Timo Sirainen <tss@iki.fi>
parents: 3728
diff changeset
73 const char *key, const char **password_r,
55df57c028d4 Added "bool" type and changed all ints that were used as booleans to bool.
Timo Sirainen <tss@iki.fi>
parents: 3728
diff changeset
74 const char **scheme_r,
55df57c028d4 Added "bool" type and changed all ints that were used as booleans to bool.
Timo Sirainen <tss@iki.fi>
parents: 3728
diff changeset
75 enum passdb_result *result_r,
55df57c028d4 Added "bool" type and changed all ints that were used as booleans to bool.
Timo Sirainen <tss@iki.fi>
parents: 3728
diff changeset
76 bool use_expired)
2798
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
77 {
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
78 const char *value, *const *list;
4658
3b49b9ec87dc auth_cache: Try to handle changing passwords automatically: If password
Timo Sirainen <tss@iki.fi>
parents: 3918
diff changeset
79 struct auth_cache_node *node;
3863
55df57c028d4 Added "bool" type and changed all ints that were used as booleans to bool.
Timo Sirainen <tss@iki.fi>
parents: 3728
diff changeset
80 bool expired;
2798
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
81
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
82 if (passdb_cache == NULL)
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
83 return FALSE;
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
84
4658
3b49b9ec87dc auth_cache: Try to handle changing passwords automatically: If password
Timo Sirainen <tss@iki.fi>
parents: 3918
diff changeset
85 value = auth_cache_lookup(passdb_cache, request, key, &node, &expired);
5259
228eacfb2647 Added more debug logging.
Timo Sirainen <tss@iki.fi>
parents: 5153
diff changeset
86 if (value == NULL || (expired && !use_expired)) {
228eacfb2647 Added more debug logging.
Timo Sirainen <tss@iki.fi>
parents: 5153
diff changeset
87 auth_request_log_debug(request, "cache",
228eacfb2647 Added more debug logging.
Timo Sirainen <tss@iki.fi>
parents: 5153
diff changeset
88 value == NULL ? "miss" : "expired");
2798
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
89 return FALSE;
5259
228eacfb2647 Added more debug logging.
Timo Sirainen <tss@iki.fi>
parents: 5153
diff changeset
90 }
228eacfb2647 Added more debug logging.
Timo Sirainen <tss@iki.fi>
parents: 5153
diff changeset
91 auth_request_log_debug(request, "cache", "hit");
2798
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
92
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
93 if (*value == '\0') {
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
94 /* negative cache entry */
3655
62fc6883faeb Fixes and cleanups to credentials handling. Also fixed auth caching to work
Timo Sirainen <tss@iki.fi>
parents: 3646
diff changeset
95 *result_r = PASSDB_RESULT_USER_UNKNOWN;
62fc6883faeb Fixes and cleanups to credentials handling. Also fixed auth caching to work
Timo Sirainen <tss@iki.fi>
parents: 3646
diff changeset
96 *password_r = NULL;
2798
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
97 *scheme_r = NULL;
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
98 return TRUE;
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
99 }
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
100
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
101 list = t_strsplit(value, "\t");
5153
83f361144a8a Added auth_request_set_fields() and used it instead of duplicating the code
Timo Sirainen <tss@iki.fi>
parents: 5134
diff changeset
102 auth_request_set_fields(request, list + 1, NULL);
2798
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
103
3655
62fc6883faeb Fixes and cleanups to credentials handling. Also fixed auth caching to work
Timo Sirainen <tss@iki.fi>
parents: 3646
diff changeset
104 *result_r = PASSDB_RESULT_OK;
62fc6883faeb Fixes and cleanups to credentials handling. Also fixed auth caching to work
Timo Sirainen <tss@iki.fi>
parents: 3646
diff changeset
105 *password_r = list[0];
62fc6883faeb Fixes and cleanups to credentials handling. Also fixed auth caching to work
Timo Sirainen <tss@iki.fi>
parents: 3646
diff changeset
106 *scheme_r = password_get_scheme(password_r);
5134
b2070dffa074 If looking up credentials for NULL passwords, return "scheme not available"
Timo Sirainen <tss@iki.fi>
parents: 5128
diff changeset
107 i_assert(*scheme_r != NULL || *password_r == '\0');
b2070dffa074 If looking up credentials for NULL passwords, return "scheme not available"
Timo Sirainen <tss@iki.fi>
parents: 5128
diff changeset
108
b2070dffa074 If looking up credentials for NULL passwords, return "scheme not available"
Timo Sirainen <tss@iki.fi>
parents: 5128
diff changeset
109 if (*password_r == '\0') {
b2070dffa074 If looking up credentials for NULL passwords, return "scheme not available"
Timo Sirainen <tss@iki.fi>
parents: 5128
diff changeset
110 *password_r = NULL;
b2070dffa074 If looking up credentials for NULL passwords, return "scheme not available"
Timo Sirainen <tss@iki.fi>
parents: 5128
diff changeset
111 *result_r = PASSDB_RESULT_SCHEME_NOT_AVAILABLE;
b2070dffa074 If looking up credentials for NULL passwords, return "scheme not available"
Timo Sirainen <tss@iki.fi>
parents: 5128
diff changeset
112 }
2798
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
113 return TRUE;
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
114 }
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
115
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
116 void passdb_cache_init(void)
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
117 {
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
118 const char *env;
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
119 size_t max_size;
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
120 unsigned int cache_ttl;
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
121
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
122 env = getenv("CACHE_SIZE");
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
123 if (env == NULL)
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
124 return;
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
125
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
126 max_size = (size_t)strtoul(env, NULL, 10) * 1024;
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
127 if (max_size == 0)
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
128 return;
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
129
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
130 env = getenv("CACHE_TTL");
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
131 if (env == NULL)
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
132 return;
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
133
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
134 cache_ttl = (unsigned int)strtoul(env, NULL, 10);
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
135 if (cache_ttl == 0)
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
136 return;
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
137
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
138 passdb_cache = auth_cache_new(max_size, cache_ttl);
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
139 }
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
140
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
141 void passdb_cache_deinit(void)
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
142 {
2811
253fae0aa95f Don't try to free cache if it doesn't exist.
Timo Sirainen <tss@iki.fi>
parents: 2798
diff changeset
143 if (passdb_cache != NULL)
3879
928229f8b3e6 deinit, unref, destroy, close, free, etc. functions now take a pointer to
Timo Sirainen <tss@iki.fi>
parents: 3863
diff changeset
144 auth_cache_free(&passdb_cache);
2798
54b29901a793 Added simple LRU cache for auth requests. Currently only for sql passdb.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
145 }