summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrew Tridgell <tridge@samba.org>2001-12-19 13:33:08 +0000
committerAndrew Tridgell <tridge@samba.org>2001-12-19 13:33:08 +0000
commit1bf5c1a46f4c3f44054ce8fcbc551cdb72683f2b (patch)
tree110a266042a17e57e0d1a4e745d2b5f98d5110ae
parentc0ff2743790c78962b111f9be69a1642185b528e (diff)
downloadsamba-1bf5c1a46f4c3f44054ce8fcbc551cdb72683f2b.tar.gz
use "ads server" option if set for primary domain
-rw-r--r--source/nsswitch/winbindd_ads.c14
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;