From 614c18d24bc1bb19c884138c8c16099d1b8484d2 Mon Sep 17 00:00:00 2001 From: Andrew Bartlett Date: Mon, 5 Jan 2004 02:04:37 +0000 Subject: rpc_client/cli_lsarpc.c: rpc_parse/parse_lsa.c: nsswitch/winbindd_rpc.c: nsswitch/winbindd.h: - Add const libads/ads_ldap.c: - Cleanup function for use nsswitch/winbindd_ads.c: - Use new utility function ads_sid_to_dn - Don't search for 'dn=', rather call the ads_search_retry_dn() nsswitch/winbindd_ads.c: include/rpc_ds.h: rpc_client/cli_ds.c: - Fixup braindamage in cli_ds_enum_domain_trusts(): - This function was returning a UNISTR2 up to the caller, and was doing nasty (invalid, per valgrind) things with memcpy() - Create a new structure that represents this informaiton in a useful way and use talloc. Andrew Bartlett (This used to be commit 06c3f15aa166bb567d8be0a8bc4b095b167ab371) --- source3/libads/ads_ldap.c | 39 ++++++++++++++++++++++----------------- 1 file changed, 22 insertions(+), 17 deletions(-) (limited to 'source3/libads') diff --git a/source3/libads/ads_ldap.c b/source3/libads/ads_ldap.c index 776bdd2359..944cb1599c 100644 --- a/source3/libads/ads_ldap.c +++ b/source3/libads/ads_ldap.c @@ -152,12 +152,13 @@ done: return status; } + /* convert a sid to a DN */ -NTSTATUS ads_sid_to_dn(ADS_STRUCT *ads, - TALLOC_CTX *mem_ctx, - const DOM_SID *sid, - char **dn) +ADS_STATUS ads_sid_to_dn(ADS_STRUCT *ads, + TALLOC_CTX *mem_ctx, + const DOM_SID *sid, + char **dn) { ADS_STATUS rc; LDAPMessage *msg = NULL; @@ -165,24 +166,28 @@ NTSTATUS ads_sid_to_dn(ADS_STRUCT *ads, char *ldap_exp; char *sidstr = NULL; int count; - char *dn2; - NTSTATUS status = NT_STATUS_UNSUCCESSFUL; + char *dn2 = NULL; + + const char *attr[] = { + "dn", + NULL + }; if (!(sidstr = sid_binstring(sid))) { DEBUG(1,("ads_sid_to_dn: sid_binstring failed!\n")); - status = NT_STATUS_NO_MEMORY; + rc = ADS_ERROR_NT(NT_STATUS_NO_MEMORY); goto done; } if(!(ldap_exp = talloc_asprintf(mem_ctx, "(objectSid=%s)", sidstr))) { DEBUG(1,("ads_sid_to_dn: talloc_asprintf failed!\n")); - status = NT_STATUS_NO_MEMORY; + rc = ADS_ERROR_NT(NT_STATUS_NO_MEMORY); goto done; } - rc = ads_search_retry(ads, (void **)&msg, ldap_exp, NULL); + rc = ads_search_retry(ads, (void **)&msg, ldap_exp, attr); + if (!ADS_ERR_OK(rc)) { - status = ads_ntstatus(rc); DEBUG(1,("ads_sid_to_dn ads_search: %s\n", ads_errstr(rc))); goto done; } @@ -191,7 +196,7 @@ NTSTATUS ads_sid_to_dn(ADS_STRUCT *ads, fstring sid_string; DEBUG(1,("ads_sid_to_dn (sid=%s): Not found (count=%d)\n", sid_to_string(sid_string, sid), count)); - status = NT_STATUS_UNSUCCESSFUL; + rc = ADS_ERROR_NT(NT_STATUS_UNSUCCESSFUL); goto done; } @@ -200,30 +205,30 @@ NTSTATUS ads_sid_to_dn(ADS_STRUCT *ads, dn2 = ads_get_dn(ads, entry); if (!dn2) { - status = NT_STATUS_NO_MEMORY; + rc = ADS_ERROR_NT(NT_STATUS_NO_MEMORY); goto done; } *dn = talloc_strdup(mem_ctx, dn2); if (!*dn) { - SAFE_FREE(dn2); - status = NT_STATUS_NO_MEMORY; + ads_memfree(ads, dn2); + rc = ADS_ERROR_NT(NT_STATUS_NO_MEMORY); goto done; } - status = NT_STATUS_OK; + rc = ADS_ERROR_NT(NT_STATUS_OK); DEBUG(3,("ads sid_to_dn mapped %s\n", dn2)); SAFE_FREE(dn2); done: if (msg) ads_msgfree(ads, msg); + if (dn2) ads_memfree(ads, dn2); SAFE_FREE(sidstr); - return status; + return rc; } - #endif -- cgit