mirror of
https://github.com/samba-team/samba.git
synced 2025-01-25 06:04:04 +03:00
r20166: we have a dom_sid_add_rid() function that adds the rid after allocating
enough memory for the new sub_auth element. the old version wrote behind the buffer. also make the output sid a pointer. metze (This used to be commit b9901d5f8c9aa777bafd3a670d27209552bc56b7)
This commit is contained in:
parent
32a0486739
commit
bdafdec2bb
@ -406,13 +406,12 @@ NTSTATUS libnet_LookupName_recv(struct composite_context *c, TALLOC_CTX *mem_ctx
|
|||||||
|
|
||||||
if (NT_STATUS_IS_OK(status)) {
|
if (NT_STATUS_IS_OK(status)) {
|
||||||
s = talloc_get_type(c->private_data, struct lookup_name_state);
|
s = talloc_get_type(c->private_data, struct lookup_name_state);
|
||||||
|
|
||||||
ZERO_STRUCT(io->out.domain_sid);
|
|
||||||
io->out.rid = 0;
|
io->out.rid = 0;
|
||||||
|
io->out.sid = NULL;
|
||||||
io->out.sidstr = NULL;
|
io->out.sidstr = NULL;
|
||||||
|
|
||||||
if (*s->lookup.out.count > 0) {
|
if (*s->lookup.out.count > 0) {
|
||||||
int num_auths;
|
|
||||||
struct lsa_RefDomainList *domains = s->lookup.out.domains;
|
struct lsa_RefDomainList *domains = s->lookup.out.domains;
|
||||||
struct lsa_TransSidArray *sids = s->lookup.out.sids;
|
struct lsa_TransSidArray *sids = s->lookup.out.sids;
|
||||||
|
|
||||||
@ -421,14 +420,12 @@ NTSTATUS libnet_LookupName_recv(struct composite_context *c, TALLOC_CTX *mem_ctx
|
|||||||
if (sids->count > 0) {
|
if (sids->count > 0) {
|
||||||
io->out.rid = sids->sids[0].rid;
|
io->out.rid = sids->sids[0].rid;
|
||||||
io->out.sid_type = sids->sids[0].sid_type;
|
io->out.sid_type = sids->sids[0].sid_type;
|
||||||
}
|
if (domains->count > 0) {
|
||||||
|
io->out.sid = dom_sid_add_rid(mem_ctx, domains->domains[0].sid, io->out.rid);
|
||||||
if (domains->count > 0) {
|
NT_STATUS_HAVE_NO_MEMORY(io->out.sid);
|
||||||
io->out.domain_sid = *domains->domains[0].sid;
|
io->out.sidstr = dom_sid_string(mem_ctx, io->out.sid);
|
||||||
num_auths = io->out.domain_sid.num_auths++;
|
NT_STATUS_HAVE_NO_MEMORY(io->out.sidstr);
|
||||||
io->out.domain_sid.sub_auths[num_auths] = io->out.rid;
|
}
|
||||||
|
|
||||||
io->out.sidstr = dom_sid_string(mem_ctx, &io->out.domain_sid);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -438,6 +435,7 @@ NTSTATUS libnet_LookupName_recv(struct composite_context *c, TALLOC_CTX *mem_ctx
|
|||||||
io->out.error_string = talloc_asprintf(mem_ctx, "Error: %s", nt_errstr(status));
|
io->out.error_string = talloc_asprintf(mem_ctx, "Error: %s", nt_errstr(status));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
talloc_free(c);
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -49,7 +49,7 @@ struct libnet_LookupName {
|
|||||||
const char *domain_name;
|
const char *domain_name;
|
||||||
} in;
|
} in;
|
||||||
struct {
|
struct {
|
||||||
struct dom_sid domain_sid;
|
struct dom_sid *sid;
|
||||||
int rid;
|
int rid;
|
||||||
enum lsa_SidType sid_type;
|
enum lsa_SidType sid_type;
|
||||||
const char *sidstr;
|
const char *sidstr;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user