mirror of
https://github.com/samba-team/samba.git
synced 2025-01-10 01:18:15 +03:00
778a5414b1
The ads_do_search_all_args() function attempts to string together several
LDAPMessage structures, returned across several paged ldap requests, into a
single LDAPMessage structure. It does this by pulling entries off the second
LDAPMessage structure and appending them to the first via the OpenLDAP specific
ldap_add_result_entry() call.
The problem with this approach is it skips non-entry messages such as the
result, and controls. These messages are leaked.
The short term solution as suggested by Volker is to replace the ads_*_entry()
calls with ads_*_message() calls so we don't leak any messages.
This fixes the leak but doesn't remove the dependence on the OpenLDAP specific
implementation of ldap_add_result_entry().
(This used to be commit f1a5405409
)
123 lines
4.8 KiB
C
123 lines
4.8 KiB
C
/*
|
|
* Prototypes for ads
|
|
*/
|
|
|
|
void ads_msgfree(ADS_STRUCT *ads, LDAPMessage *msg);
|
|
char *ads_get_dn(ADS_STRUCT *ads, LDAPMessage *msg);
|
|
char *ads_get_dn_canonical(ADS_STRUCT *ads, LDAPMessage *msg);
|
|
|
|
char *ads_pull_string(ADS_STRUCT *ads, TALLOC_CTX *mem_ctx, LDAPMessage *msg,
|
|
const char *field);
|
|
char **ads_pull_strings(ADS_STRUCT *ads, TALLOC_CTX *mem_ctx,
|
|
LDAPMessage *msg, const char *field,
|
|
size_t *num_values);
|
|
char **ads_pull_strings_range(ADS_STRUCT *ads,
|
|
TALLOC_CTX *mem_ctx,
|
|
LDAPMessage *msg, const char *field,
|
|
char **current_strings,
|
|
const char **next_attribute,
|
|
size_t *num_strings,
|
|
bool *more_strings);
|
|
bool ads_pull_uint32(ADS_STRUCT *ads, LDAPMessage *msg, const char *field,
|
|
uint32 *v);
|
|
bool ads_pull_guid(ADS_STRUCT *ads, LDAPMessage *msg, struct GUID *guid);
|
|
bool ads_pull_sid(ADS_STRUCT *ads, LDAPMessage *msg, const char *field,
|
|
DOM_SID *sid);
|
|
int ads_pull_sids(ADS_STRUCT *ads, TALLOC_CTX *mem_ctx,
|
|
LDAPMessage *msg, const char *field, DOM_SID **sids);
|
|
bool ads_pull_sd(ADS_STRUCT *ads, TALLOC_CTX *mem_ctx,
|
|
LDAPMessage *msg, const char *field, SEC_DESC **sd);
|
|
char *ads_pull_username(ADS_STRUCT *ads, TALLOC_CTX *mem_ctx,
|
|
LDAPMessage *msg);
|
|
int ads_pull_sids_from_extendeddn(ADS_STRUCT *ads,
|
|
TALLOC_CTX *mem_ctx,
|
|
LDAPMessage *msg,
|
|
const char *field,
|
|
enum ads_extended_dn_flags flags,
|
|
DOM_SID **sids);
|
|
|
|
ADS_STATUS ads_find_machine_acct(ADS_STRUCT *ads, LDAPMessage **res,
|
|
const char *machine);
|
|
ADS_STATUS ads_find_printer_on_server(ADS_STRUCT *ads, LDAPMessage **res,
|
|
const char *printer,
|
|
const char *servername);
|
|
ADS_STATUS ads_find_printers(ADS_STRUCT *ads, LDAPMessage **res);
|
|
ADS_STATUS ads_find_user_acct(ADS_STRUCT *ads, LDAPMessage **res,
|
|
const char *user);
|
|
|
|
ADS_STATUS ads_do_search(ADS_STRUCT *ads, const char *bind_path, int scope,
|
|
const char *expr,
|
|
const char **attrs, LDAPMessage **res);
|
|
ADS_STATUS ads_search(ADS_STRUCT *ads, LDAPMessage **res,
|
|
const char *expr, const char **attrs);
|
|
ADS_STATUS ads_search_dn(ADS_STRUCT *ads, LDAPMessage **res,
|
|
const char *dn, const char **attrs);
|
|
ADS_STATUS ads_do_search_all_args(ADS_STRUCT *ads, const char *bind_path,
|
|
int scope, const char *expr,
|
|
const char **attrs, void *args,
|
|
LDAPMessage **res);
|
|
ADS_STATUS ads_do_search_all(ADS_STRUCT *ads, const char *bind_path,
|
|
int scope, const char *expr,
|
|
const char **attrs, LDAPMessage **res);
|
|
ADS_STATUS ads_do_search_retry(ADS_STRUCT *ads, const char *bind_path,
|
|
int scope,
|
|
const char *expr,
|
|
const char **attrs, LDAPMessage **res);
|
|
ADS_STATUS ads_do_search_retry_args(ADS_STRUCT *ads, const char *bind_path,
|
|
int scope, const char *expr,
|
|
const char **attrs, void *args,
|
|
LDAPMessage **res);
|
|
ADS_STATUS ads_search_retry(ADS_STRUCT *ads, LDAPMessage **res,
|
|
const char *expr, const char **attrs);
|
|
ADS_STATUS ads_search_retry_dn(ADS_STRUCT *ads, LDAPMessage **res,
|
|
const char *dn,
|
|
const char **attrs);
|
|
ADS_STATUS ads_search_retry_extended_dn(ADS_STRUCT *ads, LDAPMessage **res,
|
|
const char *dn,
|
|
const char **attrs,
|
|
enum ads_extended_dn_flags flags);
|
|
ADS_STATUS ads_search_retry_extended_dn_ranged(ADS_STRUCT *ads, TALLOC_CTX *mem_ctx,
|
|
const char *dn,
|
|
const char **attrs,
|
|
enum ads_extended_dn_flags flags,
|
|
char ***strings,
|
|
size_t *num_strings);
|
|
ADS_STATUS ads_search_retry_sid(ADS_STRUCT *ads, LDAPMessage **res,
|
|
const DOM_SID *sid,
|
|
const char **attrs);
|
|
|
|
|
|
LDAPMessage *ads_first_entry(ADS_STRUCT *ads, LDAPMessage *res);
|
|
LDAPMessage *ads_next_entry(ADS_STRUCT *ads, LDAPMessage *res);
|
|
LDAPMessage *ads_first_message(ADS_STRUCT *ads, LDAPMessage *res);
|
|
LDAPMessage *ads_next_message(ADS_STRUCT *ads, LDAPMessage *res);
|
|
void ads_process_results(ADS_STRUCT *ads, LDAPMessage *res,
|
|
bool (*fn)(ADS_STRUCT *,char *, void **, void *),
|
|
void *data_area);
|
|
void ads_dump(ADS_STRUCT *ads, LDAPMessage *res);
|
|
|
|
ADS_STATUS ads_parse_gpo(ADS_STRUCT *ads,
|
|
TALLOC_CTX *mem_ctx,
|
|
LDAPMessage *res,
|
|
const char *gpo_dn,
|
|
struct GROUP_POLICY_OBJECT *gpo);
|
|
ADS_STATUS ads_search_retry_dn_sd_flags(ADS_STRUCT *ads, LDAPMessage **res,
|
|
uint32 sd_flags,
|
|
const char *dn,
|
|
const char **attrs);
|
|
ADS_STATUS ads_do_search_all_sd_flags(ADS_STRUCT *ads, const char *bind_path,
|
|
int scope, const char *expr,
|
|
const char **attrs, uint32 sd_flags,
|
|
LDAPMessage **res);
|
|
ADS_STATUS ads_get_tokensids(ADS_STRUCT *ads,
|
|
TALLOC_CTX *mem_ctx,
|
|
const char *dn,
|
|
DOM_SID *user_sid,
|
|
DOM_SID *primary_group_sid,
|
|
DOM_SID **sids,
|
|
size_t *num_sids);
|
|
ADS_STATUS ads_get_joinable_ous(ADS_STRUCT *ads,
|
|
TALLOC_CTX *mem_ctx,
|
|
char ***ous,
|
|
size_t *num_ous);
|