diff options
author | Jeremy Allison <jra@samba.org> | 2006-10-11 18:54:40 +0000 |
---|---|---|
committer | Gerald (Jerry) Carter <jerry@samba.org> | 2007-10-10 12:15:25 -0500 |
commit | 37be6913fefcd9988f6c15a7b24a0a3429851ea6 (patch) | |
tree | 31293060b457375b6f32132944134f9f3e6ca7d3 /source3/libsmb | |
parent | a0dd125859e4e118c8bc3c2da258d69868aa786c (diff) | |
download | samba-37be6913fefcd9988f6c15a7b24a0a3429851ea6.tar.gz samba-37be6913fefcd9988f6c15a7b24a0a3429851ea6.tar.bz2 samba-37be6913fefcd9988f6c15a7b24a0a3429851ea6.zip |
r19249: Attempt to fix a site lookup bug found by Guenther.
- "The problem is, with a fresh system, we don't know our sitename,
therefor we do a stupid DNS query for all DCs. The reply we get is a
round-robin list of all 21 DCs, we just pick the first, contact that
and safe that INET.COM#1C query in the name cache for later use...
What we need to do if we don't yet know our sitename, is to contact to
any DC, get the CLDAP reply to tell us in which site we are, then flush
the namecache and requery DNS including the sitename"
Implement the flushing of the #1C entries for a given NetBIOS name/realm
when looking up the site value.
Jeremy.
(This used to be commit b2d1e44f59d32c91b1d48eacd1a158ba7b65762d)
Diffstat (limited to 'source3/libsmb')
-rw-r--r-- | source3/libsmb/namecache.c | 32 | ||||
-rw-r--r-- | source3/libsmb/namequery_dc.c | 3 |
2 files changed, 35 insertions, 0 deletions
diff --git a/source3/libsmb/namecache.c b/source3/libsmb/namecache.c index bd4b3caeb7..02956fa137 100644 --- a/source3/libsmb/namecache.c +++ b/source3/libsmb/namecache.c @@ -142,6 +142,10 @@ BOOL namecache_store(const char *name, int name_type, } key = namecache_key(name, name_type); + if (!key) { + return False; + } + expiry = time(NULL) + lp_name_cache_timeout(); /* @@ -198,6 +202,9 @@ BOOL namecache_fetch(const char *name, int name_type, struct ip_service **ip_lis * Use gencache interface - lookup the key */ key = namecache_key(name, name_type); + if (!key) { + return False; + } if (!gencache_get(key, &value, &timeout)) { DEBUG(5, ("no entry for %s#%02X found.\n", name, name_type)); @@ -218,6 +225,31 @@ BOOL namecache_fetch(const char *name, int name_type, struct ip_service **ip_lis return *num_names > 0; /* true only if some ip has been fetched */ } +/** + * Remove a namecache entry. Needed for site support. + * + **/ + +BOOL namecache_delete(const char *name, int name_type) +{ + BOOL ret; + char *key; + + if (!gencache_init()) + return False; + + if (name_type > 255) { + return False; /* Don't fetch non-real name types. */ + } + + key = namecache_key(name, name_type); + if (!key) { + return False; + } + ret = gencache_del(key); + SAFE_FREE(key); + return ret; +} /** * Delete single namecache entry. Look at the diff --git a/source3/libsmb/namequery_dc.c b/source3/libsmb/namequery_dc.c index cf01fb269e..5280118ab8 100644 --- a/source3/libsmb/namequery_dc.c +++ b/source3/libsmb/namequery_dc.c @@ -72,6 +72,9 @@ static BOOL ads_dc_name(const char *domain, SAFE_FREE(sitename); sitename = sitename_fetch(); ads_destroy(&ads); + /* Ensure we don't cache the DC we just connected to. */ + namecache_delete(realm, 0x1C); + namecache_delete(domain, 0x1C); continue; } |