From: Gerald Carter Date: Mon, 21 May 2007 19:12:14 +0000 (+0000) Subject: r23046: Few missing merges from cleaning out the Centeris winbindd tree. X-Git-Tag: samba-misc-tags/initial-v3-0-unstable~395 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=3d48a7e72d9268fd495e0ca4b6e73bed5bb57214;p=thirdparty%2Fsamba.git r23046: Few missing merges from cleaning out the Centeris winbindd tree. Nothing of major interest. Will fix a few problems with one way trusts. --- diff --git a/source/nsswitch/winbindd.c b/source/nsswitch/winbindd.c index 790d59c0865..ed0bdeb13ad 100644 --- a/source/nsswitch/winbindd.c +++ b/source/nsswitch/winbindd.c @@ -1164,6 +1164,10 @@ int main(int argc, char **argv, char **envp) wcache_tdc_clear(); + /* clear the cached list of trusted domains */ + + wcache_tdc_clear(); + if (!init_domain_list()) { DEBUG(0,("unable to initalize domain list\n")); exit(1); diff --git a/source/nsswitch/winbindd_rpc.c b/source/nsswitch/winbindd_rpc.c index ee8044a6678..4a6448348e9 100644 --- a/source/nsswitch/winbindd_rpc.c +++ b/source/nsswitch/winbindd_rpc.c @@ -458,6 +458,12 @@ static NTSTATUS query_user(struct winbindd_domain *domain, return NT_STATUS_OK; } + if ( !winbindd_can_contact_domain( domain ) ) { + DEBUG(10,("query_user: No incoming trust for domain %s\n", + domain->name)); + return NT_STATUS_OK; + } + /* no cache; hit the wire */ result = cm_connect_sam(domain, mem_ctx, &cli, &dom_pol); diff --git a/source/nsswitch/winbindd_util.c b/source/nsswitch/winbindd_util.c index 231e11ae458..2bec404a137 100644 --- a/source/nsswitch/winbindd_util.c +++ b/source/nsswitch/winbindd_util.c @@ -148,6 +148,16 @@ static struct winbindd_domain *add_trusted_domain(const char *domain_name, const return domain; } + /* See if we found a match. Check if we need to update the + SID. */ + + if ( domain ) { + if ( sid_equal( &domain->sid, &global_sid_NULL ) ) + sid_copy( &domain->sid, sid ); + + return domain; + } + /* Create new domain entry */ if ((domain = SMB_MALLOC_P(struct winbindd_domain)) == NULL) diff --git a/source/passdb/pdb_interface.c b/source/passdb/pdb_interface.c index 819e98b38b9..7f0555c9910 100644 --- a/source/passdb/pdb_interface.c +++ b/source/passdb/pdb_interface.c @@ -1307,7 +1307,7 @@ static BOOL pdb_default_sid_to_id(struct pdb_methods *methods, goto done; } - /* check for "Unix User" */ + /* check for "Unix Group" */ if ( sid_peek_check_rid(&global_sid_Unix_Groups, sid, &rid) ) { id->gid = rid;