summaryrefslogtreecommitdiff
path: root/source3/passdb/pdb_ads.c
diff options
context:
space:
mode:
authorVolker Lendecke <vl@samba.org>2009-06-29 22:28:19 +0200
committerVolker Lendecke <vl@samba.org>2009-07-04 12:54:22 +0200
commit98fb2a18f9d805a16514f24a5a0d87aa4a3573ff (patch)
tree3e60ab228ec41e9ee3cd9b9702f7ad5fbbe0ed67 /source3/passdb/pdb_ads.c
parentbc1e93cc80874dd89ade863e38effda80a99fd47 (diff)
downloadsamba-98fb2a18f9d805a16514f24a5a0d87aa4a3573ff.tar.gz
samba-98fb2a18f9d805a16514f24a5a0d87aa4a3573ff.tar.bz2
samba-98fb2a18f9d805a16514f24a5a0d87aa4a3573ff.zip
pdb_ads: Fetch the domain GUID
Diffstat (limited to 'source3/passdb/pdb_ads.c')
-rw-r--r--source3/passdb/pdb_ads.c8
1 files changed, 7 insertions, 1 deletions
diff --git a/source3/passdb/pdb_ads.c b/source3/passdb/pdb_ads.c
index 1f3788c94f..2063a554f5 100644
--- a/source3/passdb/pdb_ads.c
+++ b/source3/passdb/pdb_ads.c
@@ -23,6 +23,7 @@ struct pdb_ads_state {
struct sockaddr_un socket_address;
struct tldap_context *ld;
struct dom_sid domainsid;
+ struct GUID domainguid;
char *domaindn;
char *configdn;
char *netbiosname;
@@ -2135,7 +2136,7 @@ static NTSTATUS pdb_ads_connect(struct pdb_ads_state *state,
{
const char *rootdse_attrs[2] = {
"defaultNamingContext", "configurationNamingContext" };
- const char *domain_attrs[1] = { "objectSid" };
+ const char *domain_attrs[2] = { "objectSid", "objectGUID" };
const char *ncname_attrs[1] = { "netbiosname" };
struct tldap_message **rootdse, **domain, **ncname;
TALLOC_CTX *frame = talloc_stackframe();
@@ -2206,6 +2207,11 @@ static NTSTATUS pdb_ads_connect(struct pdb_ads_state *state,
status = NT_STATUS_INTERNAL_DB_CORRUPTION;
goto done;
}
+ if (!tldap_pull_guid(domain[0], "objectGUID", &state->domainguid)) {
+ DEBUG(10, ("Could not retrieve domain GUID\n"));
+ status = NT_STATUS_INTERNAL_DB_CORRUPTION;
+ goto done;
+ }
DEBUG(10, ("Domain SID: %s\n", sid_string_dbg(&state->domainsid)));
/*