From f3b227c0d2abb0d4f02fa2313ff59750a35a4cd2 Mon Sep 17 00:00:00 2001 From: Volker Lendecke Date: Sun, 7 Jun 2009 12:04:56 +0200 Subject: Return full info in pdb_ads_search_users() --- source3/passdb/pdb_ads.c | 22 +++++++++++++++++----- 1 file changed, 17 insertions(+), 5 deletions(-) (limited to 'source3/passdb') diff --git a/source3/passdb/pdb_ads.c b/source3/passdb/pdb_ads.c index c55140ed93..5ea8158284 100644 --- a/source3/passdb/pdb_ads.c +++ b/source3/passdb/pdb_ads.c @@ -856,8 +856,8 @@ static bool pdb_ads_search_users(struct pdb_methods *m, struct pdb_ads_state *state = talloc_get_type_abort( m->private_data, struct pdb_ads_state); struct pdb_ads_search_state *sstate; - const char * attrs[] = { "objectSid", "sAMAccountName", - "userAccountControl" }; + const char * attrs[] = { "objectSid", "sAMAccountName", "displayName", + "userAccountControl", "description" }; struct tldap_message **users; int i, rc, num_users; @@ -901,9 +901,21 @@ static bool pdb_ads_search_users(struct pdb_methods *m, } sid_peek_rid(&sid, &e->rid); e->acct_flags = ACB_NORMAL; - e->account_name = "Name"; - e->fullname = "Full Name"; - e->description = "Beschreibung"; + e->account_name = tldap_talloc_single_attribute( + users[i], "samAccountName", sstate->entries); + if (e->account_name == NULL) { + return false; + } + e->fullname = tldap_talloc_single_attribute( + users[i], "displayName", sstate->entries); + if (e->fullname == NULL) { + e->fullname = ""; + } + e->description = tldap_talloc_single_attribute( + users[i], "description", sstate->entries); + if (e->description == NULL) { + e->description = ""; + } sstate->num_entries += 1; if (sstate->num_entries >= num_users) { -- cgit