diff options
author | Michael Adam <obnox@samba.org> | 2007-06-26 13:45:07 +0000 |
---|---|---|
committer | Gerald (Jerry) Carter <jerry@samba.org> | 2007-10-10 12:23:36 -0500 |
commit | 062d8c61294a1e9f8588fa8af31954dd286c7bde (patch) | |
tree | 9f5536fbeea476c800e092b265970c15460bb9ba /source | |
parent | eb1ec508ace3a5eeb53cf47be44047bd9228cd19 (diff) | |
download | samba-062d8c61294a1e9f8588fa8af31954dd286c7bde.tar.gz samba-062d8c61294a1e9f8588fa8af31954dd286c7bde.tar.xz samba-062d8c61294a1e9f8588fa8af31954dd286c7bde.zip |
r23610: Move some winbindd_cache specific flags and actions
back to winbindd_cache.c. The generic mechanism
should open the cache tdb readonly and with default
flags.
Michael
Diffstat (limited to 'source')
-rw-r--r-- | source/lib/util_tdb.c | 8 | ||||
-rw-r--r-- | source/nsswitch/winbindd_cache.c | 20 |
2 files changed, 20 insertions, 8 deletions
diff --git a/source/lib/util_tdb.c b/source/lib/util_tdb.c index cb53b7f2e37..7a0cce6c25a 100644 --- a/source/lib/util_tdb.c +++ b/source/lib/util_tdb.c @@ -1005,12 +1005,7 @@ static int tdb_validate_child(const char *tdb_path, v_status.unknown_key = False; v_status.success = True; - tdb = tdb_open_log(tdb_path, - WINBINDD_CACHE_TDB_DEFAULT_HASH_SIZE, - lp_winbind_offline_logon() - ? TDB_DEFAULT - : (TDB_DEFAULT | TDB_CLEAR_IF_FIRST), - O_RDWR|O_CREAT, 0600); + tdb = tdb_open_log(tdb_path, 0, TDB_DEFAULT, O_RDONLY, 0); if (!tdb) { v_status.tdb_error = True; v_status.success = False; @@ -1182,4 +1177,3 @@ int tdb_validate(const char *tdb_path, tdb_validate_data_func validate_fn) return ret; } - diff --git a/source/nsswitch/winbindd_cache.c b/source/nsswitch/winbindd_cache.c index 122432d95b2..cfd182666e3 100644 --- a/source/nsswitch/winbindd_cache.c +++ b/source/nsswitch/winbindd_cache.c @@ -3279,14 +3279,32 @@ static void validate_panic(const char *const why) int winbindd_validate_cache(void) { - int ret; + int ret = -1; + const char *tdb_path = lock_path("winbindd_cache.tdb"); + TDB_CONTEXT *tdb = NULL; DEBUG(10, ("winbindd_validate_cache: replacing panic function\n")); smb_panic_fn = validate_panic; + + tdb = tdb_open_log(tdb_path, + WINBINDD_CACHE_TDB_DEFAULT_HASH_SIZE, + ( lp_winbind_offline_logon() + ? TDB_DEFAULT + : TDB_DEFAULT | TDB_CLEAR_IF_FIRST ), + O_RDWR|O_CREAT, + 0600); + if (!tdb) { + DEBUG(0, ("winbindd_validate_cache: " + "error opening/initializing tdb\n")); + goto done; + } + tdb_close(tdb); + ret = tdb_validate(lock_path("winbindd_cache.tdb"), cache_traverse_validate_fn); +done: DEBUG(10, ("winbindd_validate_cache: restoring panic function\n")); smb_panic_fn = smb_panic; return ret; |