diff options
author | Andrew Tridgell <tridge@samba.org> | 2001-12-19 13:33:08 +0000 |
---|---|---|
committer | Andrew Tridgell <tridge@samba.org> | 2001-12-19 13:33:08 +0000 |
commit | 1bf5c1a46f4c3f44054ce8fcbc551cdb72683f2b (patch) | |
tree | 110a266042a17e57e0d1a4e745d2b5f98d5110ae | |
parent | c0ff2743790c78962b111f9be69a1642185b528e (diff) | |
download | samba-1bf5c1a46f4c3f44054ce8fcbc551cdb72683f2b.tar.gz |
use "ads server" option if set for primary domain
-rw-r--r-- | source/nsswitch/winbindd_ads.c | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/source/nsswitch/winbindd_ads.c b/source/nsswitch/winbindd_ads.c index e144fffc59c..8d0c78b2d5c 100644 --- a/source/nsswitch/winbindd_ads.c +++ b/source/nsswitch/winbindd_ads.c @@ -102,6 +102,7 @@ static ADS_STRUCT *ads_cached_connection(struct winbindd_domain *domain) ADS_STATUS status; char *ccache; struct in_addr server_ip; + char *sname; if (domain->private) { return (ADS_STRUCT *)domain->private; @@ -112,12 +113,17 @@ static ADS_STRUCT *ads_cached_connection(struct winbindd_domain *domain) SETENV("KRB5CCNAME", ccache, 1); unlink(ccache); - if (!resolve_name(domain->name, &server_ip, 0x1b)) { - DEBUG(1,("Can't find PDC for domain %s\n", domain->name)); - return NULL; + if (resolve_name(domain->name, &server_ip, 0x1b)) { + sname = inet_ntoa(server_ip); + } else { + if (strcasecmp(domain->name, lp_workgroup()) != 0) { + DEBUG(1,("can't find domain controller for %s\n", domain->name)); + return NULL; + } + sname = NULL; } - ads = ads_init(primary_realm, inet_ntoa(server_ip), NULL, NULL); + ads = ads_init(primary_realm, sname, NULL, NULL); if (!ads) { DEBUG(1,("ads_init for domain %s failed\n", domain->name)); return NULL; |