1
0
mirror of https://github.com/samba-team/samba.git synced 2024-12-31 17:18:04 +03:00

Use pidl for _samr_LookupRids().

Guenther
(This used to be commit fe3a02d44c)
This commit is contained in:
Günther Deschner 2008-02-06 21:29:17 +01:00
parent 7329bd24f9
commit d69a0b9f14
2 changed files with 49 additions and 70 deletions

View File

@ -258,29 +258,7 @@ static bool api_samr_chgpasswd_user(pipes_struct *p)
static bool api_samr_lookup_rids(pipes_struct *p)
{
SAMR_Q_LOOKUP_RIDS q_u;
SAMR_R_LOOKUP_RIDS r_u;
prs_struct *data = &p->in_data.data;
prs_struct *rdata = &p->out_data.rdata;
ZERO_STRUCT(q_u);
ZERO_STRUCT(r_u);
/* grab the samr lookup names */
if(!samr_io_q_lookup_rids("", &q_u, data, 0)) {
DEBUG(0,("api_samr_lookup_rids: unable to unmarshall SAMR_Q_LOOKUP_RIDS.\n"));
return False;
}
r_u.status = _samr_lookup_rids(p, &q_u, &r_u);
/* store the response in the SMB stream */
if(!samr_io_r_lookup_rids("", &r_u, rdata, 0)) {
DEBUG(0,("api_samr_lookup_rids: unable to marshall SAMR_R_LOOKUP_RIDS.\n"));
return False;
}
return True;
return proxy_samr_call(p, NDR_SAMR_LOOKUPRIDS);
}
/*******************************************************************

View File

@ -103,6 +103,15 @@ static const struct generic_mapping ali_generic_mapping = {
GENERIC_RIGHTS_ALIAS_EXECUTE,
GENERIC_RIGHTS_ALIAS_ALL_ACCESS};
/*******************************************************************
inits a structure.
********************************************************************/
static void init_lsa_String(struct lsa_String *name, const char *s)
{
name->string = s;
}
/*******************************************************************
*******************************************************************/
@ -1684,60 +1693,54 @@ makes a SAMR_R_LOOKUP_RIDS structure.
********************************************************************/
static bool make_samr_lookup_rids(TALLOC_CTX *ctx, uint32 num_names,
const char **names, UNIHDR **pp_hdr_name,
UNISTR2 **pp_uni_name)
const char **names,
struct lsa_String **lsa_name_array_p)
{
uint32 i;
UNIHDR *hdr_name=NULL;
UNISTR2 *uni_name=NULL;
struct lsa_String *lsa_name_array = NULL;
uint32_t i;
*pp_uni_name = NULL;
*pp_hdr_name = NULL;
*lsa_name_array_p = NULL;
if (num_names != 0) {
hdr_name = TALLOC_ZERO_ARRAY(ctx, UNIHDR, num_names);
if (hdr_name == NULL)
return False;
uni_name = TALLOC_ZERO_ARRAY(ctx,UNISTR2, num_names);
if (uni_name == NULL)
return False;
lsa_name_array = TALLOC_ZERO_ARRAY(ctx, struct lsa_String, num_names);
if (!lsa_name_array) {
return false;
}
}
for (i = 0; i < num_names; i++) {
DEBUG(10, ("names[%d]:%s\n", i, names[i] && *names[i] ? names[i] : ""));
init_unistr2(&uni_name[i], names[i], UNI_FLAGS_NONE);
init_uni_hdr(&hdr_name[i], &uni_name[i]);
init_lsa_String(&lsa_name_array[i], names[i]);
}
*pp_uni_name = uni_name;
*pp_hdr_name = hdr_name;
*lsa_name_array_p = lsa_name_array;
return True;
return true;
}
/*******************************************************************
_samr_lookup_rids
_samr_LookupRids
********************************************************************/
NTSTATUS _samr_lookup_rids(pipes_struct *p, SAMR_Q_LOOKUP_RIDS *q_u, SAMR_R_LOOKUP_RIDS *r_u)
NTSTATUS _samr_LookupRids(pipes_struct *p,
struct samr_LookupRids *r)
{
NTSTATUS status;
const char **names;
enum lsa_SidType *attrs = NULL;
uint32 *wire_attrs = NULL;
UNIHDR *hdr_name = NULL;
UNISTR2 *uni_name = NULL;
DOM_SID pol_sid;
int num_rids = (int)q_u->num_rids1;
int num_rids = (int)r->in.num_rids;
uint32 acc_granted;
int i;
struct lsa_Strings names_array;
struct samr_Ids types_array;
struct lsa_String *lsa_names = NULL;
r_u->status = NT_STATUS_OK;
DEBUG(5,("_samr_lookup_rids: %d\n", __LINE__));
DEBUG(5,("_samr_LookupRids: %d\n", __LINE__));
/* find the policy handle. open a policy on it. */
if (!get_lsa_policy_samr_sid(p, &q_u->pol, &pol_sid, &acc_granted, NULL))
if (!get_lsa_policy_samr_sid(p, r->in.domain_handle, &pol_sid, &acc_granted, NULL))
return NT_STATUS_INVALID_HANDLE;
if (num_rids > 1000) {
@ -1760,28 +1763,36 @@ NTSTATUS _samr_lookup_rids(pipes_struct *p, SAMR_Q_LOOKUP_RIDS *q_u, SAMR_R_LOOK
}
become_root(); /* lookup_sid can require root privs */
r_u->status = pdb_lookup_rids(&pol_sid, num_rids, q_u->rid,
names, attrs);
status = pdb_lookup_rids(&pol_sid, num_rids, r->in.rids,
names, attrs);
unbecome_root();
if ( NT_STATUS_EQUAL(r_u->status, NT_STATUS_NONE_MAPPED) && (num_rids == 0) ) {
r_u->status = NT_STATUS_OK;
if (NT_STATUS_EQUAL(status, NT_STATUS_NONE_MAPPED) && (num_rids == 0)) {
status = NT_STATUS_OK;
}
if(!make_samr_lookup_rids(p->mem_ctx, num_rids, names,
&hdr_name, &uni_name))
if (!make_samr_lookup_rids(p->mem_ctx, num_rids, names,
&lsa_names)) {
return NT_STATUS_NO_MEMORY;
}
/* Convert from enum lsa_SidType to uint32 for wire format. */
for (i = 0; i < num_rids; i++) {
wire_attrs[i] = (uint32)attrs[i];
}
init_samr_r_lookup_rids(r_u, num_rids, hdr_name, uni_name, wire_attrs);
names_array.count = num_rids;
names_array.names = lsa_names;
DEBUG(5,("_samr_lookup_rids: %d\n", __LINE__));
types_array.count = num_rids;
types_array.ids = wire_attrs;
return r_u->status;
*r->out.names = names_array;
*r->out.types = types_array;
DEBUG(5,("_samr_LookupRids: %d\n", __LINE__));
return status;
}
/*******************************************************************
@ -5224,16 +5235,6 @@ NTSTATUS _samr_LookupNames(pipes_struct *p,
/****************************************************************
****************************************************************/
NTSTATUS _samr_LookupRids(pipes_struct *p,
struct samr_LookupRids *r)
{
p->rng_fault_state = true;
return NT_STATUS_NOT_IMPLEMENTED;
}
/****************************************************************
****************************************************************/
NTSTATUS _samr_SetMemberAttributesOfGroup(pipes_struct *p,
struct samr_SetMemberAttributesOfGroup *r)
{